.tool-page {
max-width: 720px;
margin: 0 auto;
}
.tool-header {
text-align: center;
margin-bottom: var(--space-8);
}
.tool-header__icon {
font-size: 48px;
margin-bottom: var(--space-3);
}
.tool-header__title {
font-size: var(--font-size-3xl);
font-weight: 700;
}
.tool-header__description {
color: var(--text-secondary);
margin-top: var(--space-2);
font-size: var(--font-size-lg);
}
.tool-header__badge {
display: inline-block;
padding: var(--space-1) var(--space-3);
border-radius: var(--radius-full);
font-size: var(--font-size-xs);
font-weight: 600;
text-transform: uppercase;
letter-spacing: 0.5px;
margin-top: var(--space-3);
}
.tool-header__badge--social {
background: rgba(139, 92, 246, 0.1);
color: var(--color-cat-social);
}
.tool-header__badge--ai {
background: rgba(6, 182, 212, 0.1);
color: var(--color-cat-ai);
}
.tool-card {
background: var(--bg-primary);
border-radius: var(--radius-xl);
box-shadow: var(--shadow-lg);
padding: var(--space-8);
margin-bottom: var(--space-6);
}
@media (max-width: 640px) {
.tool-card { padding: var(--space-5); }
}
.tool-result {
margin-top: var(--space-6);
padding-top: var(--space-6);
border-top: 1px solid var(--border-light);
animation: fadeInUp 0.4s ease;
}
.tool-result__content {
background: var(--bg-secondary);
border-radius: var(--radius-lg);
padding: var(--space-5);
margin-bottom: var(--space-4);
font-size: var(--font-size-lg);
line-height: 1.7;
white-space: pre-wrap;
word-break: break-word;
}
.tool-result__winner {
text-align: center;
font-size: var(--font-size-3xl);
font-weight: 700;
color: var(--accent);
padding: var(--space-8) 0;
}
.tool-actions {
display: flex;
gap: var(--space-3);
flex-wrap: wrap;
justify-content: center;
}
.ai-quota {
display: flex;
align-items: center;
justify-content: space-between;
padding: var(--space-3) var(--space-4);
background: var(--bg-tertiary);
border-radius: var(--radius-md);
font-size: var(--font-size-sm);
margin-bottom: var(--space-5);
}
.ai-quota__count {
font-weight: 600;
color: var(--accent);
}
.ai-quota__cta {
font-weight: 600;
cursor: pointer;
}
.chips {
display: flex;
flex-wrap: wrap;
gap: var(--space-2);
margin: var(--space-4) 0;
}
.chip {
display: inline-flex;
align-items: center;
gap: var(--space-2);
padding: var(--space-2) var(--space-3);
background: var(--accent-bg);
color: var(--accent-text);
border-radius: var(--radius-full);
font-size: var(--font-size-sm);
font-weight: 500;
}
.chip__remove {
background: none;
border: none;
cursor: pointer;
color: var(--text-tertiary);
font-size: 16px;
padding: 0;
line-height: 1;
}
.chip__remove:hover { color: var(--error); }
.char-counter {
text-align: right;
font-size: var(--font-size-xs);
color: var(--text-tertiary);
margin-top: var(--space-1);
}
.char-counter--warning { color: var(--warning); }
.char-counter--error { color: var(--error); }
.tool-grid {
display: grid;
grid-template-columns: 1fr;
gap: var(--space-4);
}
@media (min-width: 640px) { .tool-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .tool-grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1280px) { .tool-grid { grid-template-columns: repeat(4, 1fr); } }
.tool-card-link {
text-decoration: none;
color: inherit;
}
.tool-card-item {
background: var(--bg-primary);
border-radius: var(--radius-lg);
padding: var(--space-5);
box-shadow: var(--shadow-sm);
transition: all var(--transition-base);
cursor: pointer;
text-align: center;
}
.tool-card-item:hover {
box-shadow: var(--shadow-lg);
transform: translateY(-2px);
}
.tool-card-item__icon { font-size: 36px; margin-bottom: var(--space-3); }
.tool-card-item__title { font-weight: 600; margin-bottom: var(--space-1); }
.tool-card-item__desc { font-size: var(--font-size-sm); color: var(--text-secondary); line-height: 1.5; }
.share-buttons {
display: flex;
gap: var(--space-2);
flex-wrap: wrap;
margin-top: var(--space-4);
}
.share-btn {
padding: var(--space-2) var(--space-4);
border-radius: var(--radius-full);
font-size: var(--font-size-sm);
font-weight: 500;
text-decoration: none;
color: #fff;
transition: opacity var(--transition-fast);
}
.share-btn:hover { opacity: 0.9; color: #fff; }
.share-btn--whatsapp { background: #25D366; }
.share-btn--telegram { background: #0088CC; }
.share-btn--twitter { background: #000; }
.share-btn--copy { background: var(--accent); }
.hero {
text-align: center;
padding: var(--space-12) 0 var(--space-8);
}
.hero__title {
font-size: var(--font-size-4xl);
font-weight: 700;
margin-bottom: var(--space-3);
}
.hero__icon { display: inline; }
.hero__tagline {
font-size: var(--font-size-xl);
color: var(--accent);
font-weight: 600;
}
.hero__sub {
color: var(--text-secondary);
font-size: var(--font-size-base);
margin-top: var(--space-2);
}
@media (max-width: 640px) {
.hero { padding: var(--space-8) 0 var(--space-6); }
.hero__title { font-size: var(--font-size-2xl); }
.hero__tagline { font-size: var(--font-size-lg); }
}
.homepage-section {
margin-bottom: var(--space-10);
}
.homepage-section__title {
font-size: var(--font-size-xl);
font-weight: 600;
margin-bottom: var(--space-5);
}
.tool-card-item__badge {
display: inline-block;
padding: 2px 8px;
border-radius: var(--radius-full);
font-size: var(--font-size-xs);
font-weight: 600;
vertical-align: middle;
}
.tool-card-item__badge--ai {
background: rgba(6, 182, 212, 0.15);
color: #0891B2;
}
.onboarding-banner {
text-align: center;
margin-bottom: var(--space-8);
background: var(--accent-bg);
border: 1px solid var(--accent-light);
}
.cta-section {
text-align: center;
margin-top: var(--space-10);
margin-bottom: var(--space-6);
padding: var(--space-10);
background: var(--accent-bg);
}
.breadcrumb {
display: flex;
align-items: center;
gap: var(--space-2);
font-size: var(--font-size-sm);
color: var(--text-tertiary);
margin-bottom: var(--space-6);
flex-wrap: wrap;
}
.breadcrumb a { color: var(--text-secondary); }
.breadcrumb a:hover { color: var(--accent); }
.breadcrumb__sep { color: var(--text-tertiary); }
.breadcrumb__current { color: var(--text-primary); font-weight: 500; }
.poll-option {
position: relative;
padding: var(--space-3) var(--space-4);
margin-bottom: var(--space-2);
border-radius: var(--radius-md);
background: var(--bg-tertiary);
overflow: hidden;
transition: all var(--transition-fast);
}
.poll-option:hover:not(.poll-option--voted) {
background: var(--accent-bg);
}
.poll-option__bar {
position: absolute;
left: 0; top: 0; bottom: 0;
background: var(--accent-bg);
border-radius: var(--radius-md);
transition: width var(--transition-slow);
z-index: 0;
}
.poll-option__text {
position: relative;
z-index: 1;
font-weight: 500;
}
.poll-option__pct {
position: relative;
z-index: 1;
float: right;
font-weight: 600;
color: var(--accent);
}
.countdown-display {
display: flex;
justify-content: center;
gap: var(--space-5);
margin: var(--space-6) 0;
}
.countdown-unit {
text-align: center;
}
.countdown-unit span {
display: block;
font-size: var(--font-size-4xl);
font-weight: 700;
color: var(--accent);
line-height: 1;
}
.countdown-unit small {
display: block;
font-size: var(--font-size-sm);
color: var(--text-tertiary);
margin-top: var(--space-1);
text-transform: uppercase;
letter-spacing: 1px;
}
.ad-slot {
min-height: 0;
margin: var(--space-4) 0;
text-align: center;
}
.legal-page h1 {
font-size: var(--font-size-3xl);
margin-bottom: var(--space-2);
}
.legal-content h2 {
font-size: var(--font-size-lg);
font-weight: 600;
margin-top: var(--space-6);
margin-bottom: var(--space-3);
color: var(--accent);
}
.legal-content p {
margin-bottom: var(--space-3);
color: var(--text-secondary);
}
.tool-favorite {
position: absolute;
top: var(--space-4);
right: var(--space-4);
font-size: 20px;
}
.tool-header {
position: relative;
}
.tool-share-section {
margin-top: var(--space-6);
padding: var(--space-6);
background: var(--bg-primary);
border-radius: var(--radius-lg);
box-shadow: var(--shadow-sm);
}
.picker-input-row {
display: flex;
gap: var(--space-2);
}
.picker-input-row .input {
flex: 1;
font-size: 16px;
}
.picker-input-row .btn {
min-width: 44px;
min-height: 44px;
font-size: var(--font-size-xl);
padding: 0;
flex-shrink: 0;
}
.picker-bulk {
margin-top: var(--space-3);
}
.picker-bulk summary {
cursor: pointer;
color: var(--accent);
font-size: var(--font-size-sm);
font-weight: 500;
user-select: none;
}
.picker-bulk summary:hover {
text-decoration: underline;
}
.picker-bulk .textarea {
margin-top: var(--space-2);
font-size: 16px;
}
.picker-bulk .btn {
margin-top: var(--space-2);
}
.picker-chips {
display: flex;
flex-wrap: wrap;
gap: var(--space-2);
margin-top: var(--space-4);
min-height: 32px;
}
.picker-chip {
display: inline-flex;
align-items: center;
gap: var(--space-1);
background: var(--accent-light);
color: var(--accent-text);
padding: var(--space-1) var(--space-3);
border-radius: var(--radius-full);
font-size: var(--font-size-sm);
font-weight: 500;
animation: chipIn 200ms ease;
transition: opacity var(--transition-fast), transform var(--transition-fast);
}
.picker-chip--eliminated {
opacity: 0.4;
text-decoration: line-through;
background: var(--bg-tertiary);
color: var(--text-tertiary);
}
.picker-chip__remove {
background: none;
border: none;
color: inherit;
cursor: pointer;
font-size: var(--font-size-base);
line-height: 1;
padding: 0 2px;
opacity: 0.6;
transition: opacity var(--transition-fast);
}
.picker-chip__remove:hover {
opacity: 1;
}
.picker-chip__badge {
font-size: var(--font-size-xs);
opacity: 0.7;
}
@keyframes chipIn {
from { transform: scale(0.8); opacity: 0; }
to { transform: scale(1); opacity: 1; }
}
.picker-count {
font-size: var(--font-size-sm);
color: var(--text-secondary);
margin-top: var(--space-2);
}
.picker-params {
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: var(--space-3);
margin-top: var(--space-4);
padding: var(--space-4);
background: var(--bg-secondary);
border-radius: var(--radius-md);
}
.picker-params label {
font-size: var(--font-size-xs);
font-weight: 600;
text-transform: uppercase;
letter-spacing: 0.05em;
color: var(--text-secondary);
margin-bottom: var(--space-1);
display: block;
}
.picker-params .select {
width: 100%;
font-size: 16px;
min-height: 40px;
}
.picker-anim {
display: flex;
justify-content: center;
align-items: center;
min-height: 120px;
margin: var(--space-6) 0;
}
.picker-anim__slot {
font-size: var(--font-size-3xl);
font-weight: 700;
color: var(--accent);
text-align: center;
min-width: 200px;
padding: var(--space-4);
}
.picker-anim__slot--spinning {
animation: slotSpin 80ms ease;
}
.picker-anim__slot--reveal {
animation: slotReveal 400ms ease;
}
@keyframes slotSpin {
0% { opacity: 0.3; transform: translateY(-8px); }
100% { opacity: 1; transform: translateY(0); }
}
@keyframes slotReveal {
0% { transform: scale(0.7); opacity: 0; }
50% { transform: scale(1.15); }
100% { transform: scale(1); opacity: 1; }
}
.tool-result--animate {
animation: resultSlideIn 500ms ease;
}
@keyframes resultSlideIn {
from { opacity: 0; transform: translateY(20px); }
to { opacity: 1; transform: translateY(0); }
}
.picker-result__badge {
font-size: var(--font-size-sm);
font-weight: 600;
text-transform: uppercase;
letter-spacing: 0.1em;
color: var(--accent);
margin-bottom: var(--space-3);
}
.picker-result__winners {
display: flex;
flex-wrap: wrap;
gap: var(--space-3);
justify-content: center;
margin-bottom: var(--space-4);
}
.picker-winner {
display: flex;
align-items: center;
gap: var(--space-2);
background: var(--accent-bg);
border: 2px solid var(--accent);
border-radius: var(--radius-lg);
padding: var(--space-3) var(--space-5);
animation: winnerPop 500ms ease;
}
.picker-winner__icon {
font-size: var(--font-size-2xl);
}
.picker-winner__name {
font-size: var(--font-size-2xl);
font-weight: 700;
color: var(--text-primary);
}
@keyframes winnerPop {
0% { transform: scale(0); }
60% { transform: scale(1.1); }
100% { transform: scale(1); }
}
.picker-result__meta {
font-size: var(--font-size-sm);
color: var(--text-secondary);
text-align: center;
margin-bottom: var(--space-4);
}
.picker-history {
margin-top: var(--space-6);
padding: var(--space-4);
background: var(--bg-secondary);
border-radius: var(--radius-md);
}
.picker-history h3 {
font-size: var(--font-size-base);
margin-bottom: var(--space-3);
}
.picker-history ol {
padding-left: var(--space-5);
font-size: var(--font-size-sm);
color: var(--text-secondary);
}
.picker-history ol li {
margin-bottom: var(--space-1);
}
.confetti {
position: absolute;
width: 8px;
height: 8px;
border-radius: 2px;
opacity: 0;
pointer-events: none;
animation: confettiFall 1.2s ease forwards;
}
@keyframes confettiFall {
0% { opacity: 1; transform: translateY(0) rotate(0deg); }
100% { opacity: 0; transform: translateY(120px) rotate(720deg); }
}
.seo-content {
margin-top: var(--space-10);
padding-top: var(--space-8);
border-top: 1px solid var(--border-light);
color: var(--text-secondary);
font-size: var(--font-size-sm);
line-height: 1.7;
content-visibility: auto;
contain-intrinsic-size: 0 500px;
}
.seo-content h2 {
font-size: var(--font-size-xl);
color: var(--text-primary);
margin-bottom: var(--space-3);
}
.seo-content h3 {
font-size: var(--font-size-lg);
color: var(--text-primary);
margin: var(--space-6) 0 var(--space-2);
}
.seo-content p {
margin-bottom: var(--space-3);
}
.seo-faq {
margin-top: var(--space-6);
}
.seo-faq__item {
margin-bottom: var(--space-4);
padding: var(--space-3);
background: var(--bg-secondary);
border-radius: var(--radius-md);
}
.seo-faq__item h4 {
font-size: var(--font-size-base);
color: var(--text-primary);
margin-bottom: var(--space-1);
}
.seo-faq__item p {
margin: 0;
}
@media (max-width: 640px) {
.picker-params {
grid-template-columns: 1fr;
gap: var(--space-2);
}
.picker-anim__slot {
font-size: var(--font-size-2xl);
}
.picker-winner__name {
font-size: var(--font-size-xl);
}
.picker-winner {
padding: var(--space-2) var(--space-4);
}
.tool-result__actions {
flex-direction: column;
}
.tool-result__actions .btn {
width: 100%;
min-height: 44px;
}
}
[dir="rtl"] .picker-input-row {
flex-direction: row-reverse;
}
[dir="rtl"] .picker-chip__remove {
margin-right: 0;
margin-left: var(--space-1);
}
[dir="rtl"] .picker-history ol {
padding-left: 0;
padding-right: var(--space-5);
}
.tool-header__badge--calculator { background: var(--color-cat-calc); color: #fff; }
.tool-header__badge--utility { background: var(--color-cat-util); color: #fff; }
.input-with-icon {
position: relative;
display: flex;
align-items: center;
}
.input-icon {
position: absolute;
left: var(--space-3);
color: var(--text-secondary);
font-weight: 600;
pointer-events: none;
z-index: 1;
}
.input-icon--right {
left: auto;
right: var(--space-3);
}
.input--icon-left {
padding-left: var(--space-8);
}
.input--color {
width: 48px;
height: 40px;
padding: 2px;
cursor: pointer;
border-radius: var(--radius-md);
}
.tip-presets {
display: flex;
gap: var(--space-2);
flex-wrap: wrap;
}
.stepper {
display: flex;
align-items: center;
gap: var(--space-2);
max-width: 160px;
}
.stepper__btn {
width: 40px;
height: 40px;
border: 1px solid var(--border);
border-radius: var(--radius-md);
background: var(--bg-tertiary);
color: var(--text-primary);
font-size: var(--font-size-lg);
font-weight: 600;
cursor: pointer;
transition: all var(--transition-fast);
display: flex;
align-items: center;
justify-content: center;
}
.stepper__btn:hover {
background: var(--accent);
color: var(--text-inverse);
border-color: var(--accent);
}
.stepper__input {
width: 60px;
text-align: center;
font-weight: 600;
}
.tip-result {
background: var(--bg-secondary);
border-radius: var(--radius-lg);
padding: var(--space-5);
}
.tip-result__row {
display: flex;
justify-content: space-between;
align-items: center;
padding: var(--space-2) 0;
}
.tip-result__row--total {
padding-top: var(--space-3);
}
.tip-result__label {
color: var(--text-secondary);
font-size: var(--font-size-sm);
}
.tip-result__value {
font-weight: 600;
font-size: var(--font-size-lg);
}
.tip-result__value--accent {
color: var(--accent);
}
.tip-result__value--lg {
font-size: var(--font-size-2xl);
color: var(--text-primary);
}
.tip-result__divider {
height: 1px;
background: var(--border);
margin: var(--space-2) 0;
}
.currency-pair {
display: flex;
align-items: flex-end;
gap: var(--space-3);
}
.currency-pair__col {
flex: 1;
}
.currency-pair__swap {
width: 44px;
height: 44px;
border: 1px solid var(--border);
border-radius: var(--radius-full);
background: var(--bg-tertiary);
color: var(--accent);
font-size: var(--font-size-xl);
cursor: pointer;
transition: all var(--transition-fast);
flex-shrink: 0;
margin-bottom: 2px;
display: flex;
align-items: center;
justify-content: center;
}
.currency-pair__swap:hover {
background: var(--accent);
color: var(--text-inverse);
transform: rotate(180deg);
}
.currency-result {
display: flex;
align-items: center;
justify-content: center;
gap: var(--space-4);
flex-wrap: wrap;
padding: var(--space-6) var(--space-4);
background: var(--bg-secondary);
border-radius: var(--radius-lg);
text-align: center;
}
.currency-result__flag {
font-size: 2rem;
}
.currency-result__amount {
font-size: var(--font-size-3xl);
font-weight: 700;
color: var(--text-primary);
display: block;
}
.currency-result__code {
font-size: var(--font-size-sm);
color: var(--text-secondary);
font-weight: 500;
}
.currency-result__arrow {
font-size: var(--font-size-2xl);
color: var(--accent);
}
.currency-result__rate {
width: 100%;
text-align: center;
font-size: var(--font-size-sm);
color: var(--text-secondary);
margin-top: var(--space-2);
}
.currency-result__updated {
width: 100%;
text-align: center;
font-size: var(--font-size-xs);
color: var(--text-tertiary);
}
.rates-table {
margin-top: var(--space-6);
}
.rates-table__title {
font-size: var(--font-size-base);
font-weight: 600;
margin-bottom: var(--space-3);
color: var(--text-secondary);
}
.rates-table__grid {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
gap: var(--space-2);
}
.rates-table__item {
display: flex;
justify-content: space-between;
padding: var(--space-2) var(--space-3);
background: var(--bg-secondary);
border-radius: var(--radius-sm);
font-size: var(--font-size-sm);
}
.qr-types {
display: flex;
gap: var(--space-2);
flex-wrap: wrap;
}
.qr-result {
display: flex;
justify-content: center;
padding: var(--space-6);
background: #fff;
border-radius: var(--radius-lg);
}
.qr-result__canvas {
display: flex;
align-items: center;
justify-content: center;
}
.qr-result__canvas canvas,
.qr-result__canvas img {
border-radius: var(--radius-sm);
}
.char-count {
display: block;
text-align: right;
font-size: var(--font-size-xs);
color: var(--text-tertiary);
margin-top: var(--space-1);
}
.range {
width: 100%;
height: 6px;
-webkit-appearance: none;
background: var(--bg-tertiary);
border-radius: var(--radius-full);
outline: none;
}
.range::-webkit-slider-thumb {
-webkit-appearance: none;
width: 22px;
height: 22px;
border-radius: 50%;
background: var(--accent);
cursor: pointer;
box-shadow: var(--shadow-md);
}
.range::-moz-range-thumb {
width: 22px;
height: 22px;
border-radius: 50%;
background: var(--accent);
cursor: pointer;
border: none;
}
.range-labels {
display: flex;
justify-content: space-between;
font-size: var(--font-size-xs);
color: var(--text-tertiary);
margin-top: var(--space-1);
}
.checkbox-grid {
display: grid;
grid-template-columns: repeat(2, 1fr);
gap: var(--space-2);
}
@media (min-width: 640px) {
.checkbox-grid { grid-template-columns: repeat(4, 1fr); }
}
.checkbox-card {
display: flex;
flex-direction: column;
align-items: center;
padding: var(--space-3);
border: 2px solid var(--border);
border-radius: var(--radius-md);
cursor: pointer;
transition: all var(--transition-fast);
text-align: center;
}
.checkbox-card:has(input:checked) {
border-color: var(--accent);
background: var(--accent-bg);
}
.checkbox-card input {
position: absolute;
opacity: 0;
pointer-events: none;
}
.checkbox-card__label {
font-size: var(--font-size-xl);
font-weight: 700;
font-family: var(--font-mono);
color: var(--text-primary);
}
.checkbox-card__desc {
font-size: var(--font-size-xs);
color: var(--text-secondary);
margin-top: var(--space-1);
}
.checkbox-inline {
display: flex;
align-items: center;
gap: var(--space-2);
cursor: pointer;
font-size: var(--font-size-sm);
color: var(--text-secondary);
}
.checkbox-inline input { width: 18px; height: 18px; accent-color: var(--accent); }
.pwd-strength {
margin-bottom: var(--space-4);
}
.pwd-strength__bar {
height: 6px;
background: var(--bg-tertiary);
border-radius: var(--radius-full);
overflow: hidden;
}
.pwd-strength__fill {
height: 100%;
border-radius: var(--radius-full);
transition: all var(--transition-base);
}
.pwd-strength__label {
font-size: var(--font-size-sm);
font-weight: 600;
margin-top: var(--space-1);
display: block;
}
.pwd-list {
display: flex;
flex-direction: column;
gap: var(--space-2);
}
.pwd-item {
display: flex;
align-items: center;
gap: var(--space-2);
background: var(--bg-secondary);
padding: var(--space-3);
border-radius: var(--radius-md);
}
.pwd-item__text {
flex: 1;
font-family: var(--font-mono);
font-size: var(--font-size-sm);
word-break: break-all;
color: var(--text-primary);
user-select: all;
}
.textarea--lg {
min-height: 200px;
font-size: var(--font-size-base);
line-height: 1.7;
}
.counter-stats {
display: grid;
grid-template-columns: repeat(2, 1fr);
gap: var(--space-3);
margin-top: var(--space-5);
}
@media (min-width: 640px) {
.counter-stats { grid-template-columns: repeat(4, 1fr); }
}
.counter-stat {
background: var(--bg-secondary);
border-radius: var(--radius-md);
padding: var(--space-4);
text-align: center;
}
.counter-stat__value {
display: block;
font-size: var(--font-size-2xl);
font-weight: 700;
color: var(--accent);
line-height: 1;
}
.counter-stat__label {
display: block;
font-size: var(--font-size-xs);
color: var(--text-secondary);
margin-top: var(--space-2);
text-transform: uppercase;
letter-spacing: 0.5px;
}
.keyword-density {
margin-top: var(--space-6);
}
.keyword-density__title {
font-size: var(--font-size-base);
font-weight: 600;
margin-bottom: var(--space-3);
color: var(--text-secondary);
}
.keyword-item {
display: grid;
grid-template-columns: 100px 40px 1fr 50px;
gap: var(--space-2);
align-items: center;
padding: var(--space-2) 0;
font-size: var(--font-size-sm);
}
.keyword-item__word {
font-weight: 600;
color: var(--text-primary);
overflow: hidden;
text-overflow: ellipsis;
}
.keyword-item__count {
color: var(--text-tertiary);
text-align: center;
}
.keyword-item__bar {
height: 6px;
background: var(--bg-tertiary);
border-radius: var(--radius-full);
overflow: hidden;
}
.keyword-item__fill {
height: 100%;
background: var(--accent);
border-radius: var(--radius-full);
}
.keyword-item__pct {
color: var(--accent);
font-weight: 600;
text-align: right;
}
.unit-categories {
display: flex;
gap: var(--space-2);
flex-wrap: wrap;
}
.unit-result {
display: flex;
align-items: center;
justify-content: center;
gap: var(--space-3);
flex-wrap: wrap;
padding: var(--space-6) var(--space-4);
background: var(--bg-secondary);
border-radius: var(--radius-lg);
text-align: center;
}
.unit-result__from,
.unit-result__to {
font-size: var(--font-size-xl);
font-weight: 700;
color: var(--text-primary);
}
.unit-result__to {
color: var(--accent);
}
.unit-result__arrow {
font-size: var(--font-size-xl);
color: var(--text-tertiary);
}
.unit-all {
margin-top: var(--space-5);
}
.unit-all__title {
font-size: var(--font-size-base);
font-weight: 600;
margin-bottom: var(--space-3);
color: var(--text-secondary);
}
.unit-all__grid {
display: grid;
grid-template-columns: 1fr;
gap: var(--space-2);
}
@media (min-width: 640px) {
.unit-all__grid { grid-template-columns: repeat(2, 1fr); }
}
.unit-all__item {
display: flex;
justify-content: space-between;
padding: var(--space-2) var(--space-3);
background: var(--bg-secondary);
border-radius: var(--radius-sm);
font-size: var(--font-size-sm);
}
.unit-all__label { color: var(--text-secondary); }
.unit-all__value { font-weight: 600; color: var(--text-primary); font-family: var(--font-mono); }
.tool-form__row {
display: flex;
gap: var(--space-4);
align-items: flex-end;
}
@media (max-width: 639px) {
.tool-form__row { flex-direction: column; align-items: stretch; }
.currency-pair { flex-direction: column; align-items: center; }
.currency-pair__swap { transform: rotate(90deg); }
.currency-pair__swap:hover { transform: rotate(270deg); }
}
.chip {
display: inline-flex;
align-items: center;
padding: var(--space-2) var(--space-3);
border: 1px solid var(--border);
border-radius: var(--radius-full);
background: var(--bg-secondary);
color: var(--text-secondary);
font-size: var(--font-size-sm);
cursor: pointer;
transition: all var(--transition-fast);
white-space: nowrap;
}
.chip:hover {
border-color: var(--accent);
color: var(--accent);
}
.chip--active {
background: var(--accent);
border-color: var(--accent);
color: var(--text-inverse);
}
.tool-header__badge--generator { background: var(--color-cat-gen); color: #fff; }
.pct-modes { display: flex; gap: var(--space-2); flex-wrap: wrap; }
.pct-form { margin-top: var(--space-4); }
.pct-sentence {
display: flex;
align-items: center;
gap: var(--space-2);
flex-wrap: wrap;
font-size: var(--font-size-lg);
color: var(--text-secondary);
}
.input--inline {
width: 100px;
text-align: center;
font-size: var(--font-size-lg);
font-weight: 600;
}
.select--inline {
width: 60px;
text-align: center;
font-size: var(--font-size-lg);
font-weight: 700;
}
.pct-result {
background: var(--bg-secondary);
border-radius: var(--radius-lg);
padding: var(--space-6);
text-align: center;
}
.pct-result__answer {
font-size: var(--font-size-4xl);
font-weight: 700;
color: var(--accent);
line-height: 1.2;
}
.pct-result__formula {
font-size: var(--font-size-sm);
color: var(--text-tertiary);
margin-top: var(--space-2);
font-family: var(--font-mono);
}
.unit-toggle { display: flex; gap: var(--space-2); }
.input-suffix {
font-size: var(--font-size-sm);
color: var(--text-tertiary);
margin-top: var(--space-1);
display: block;
}
.text-muted { color: var(--text-tertiary); font-size: var(--font-size-sm); }
.bmi-result {
text-align: center;
padding: var(--space-6);
background: var(--bg-secondary);
border-radius: var(--radius-lg);
margin-bottom: var(--space-4);
}
.bmi-result__value {
font-size: 4rem;
font-weight: 700;
line-height: 1;
}
.bmi-result__label {
font-size: var(--font-size-xl);
font-weight: 600;
margin-top: var(--space-2);
}
.bmi-gauge {
position: relative;
margin: var(--space-4) 0;
}
.bmi-gauge__bar {
display: flex;
height: 28px;
border-radius: var(--radius-full);
overflow: hidden;
}
.bmi-gauge__zone {
display: flex;
align-items: center;
justify-content: center;
font-size: var(--font-size-xs);
color: #fff;
font-weight: 600;
}
.bmi-gauge__zone--under { background: var(--info); }
.bmi-gauge__zone--normal { background: var(--success); }
.bmi-gauge__zone--over { background: var(--warning); }
.bmi-gauge__zone--obese { background: var(--error); }
.bmi-gauge__pointer {
position: absolute;
top: -20px;
transform: translateX(-50%);
font-size: var(--font-size-lg);
transition: left var(--transition-base);
}
.bmi-info {
text-align: center;
font-size: var(--font-size-sm);
color: var(--text-secondary);
margin: var(--space-3) 0;
}
.bmi-disclaimer {
font-size: var(--font-size-xs);
color: var(--text-tertiary);
text-align: center;
font-style: italic;
margin-top: var(--space-4);
}
.age-main {
text-align: center;
padding: var(--space-6);
background: var(--bg-secondary);
border-radius: var(--radius-lg);
margin-bottom: var(--space-4);
}
.age-main__number {
font-size: 5rem;
font-weight: 700;
color: var(--accent);
line-height: 1;
}
.age-main__label {
font-size: var(--font-size-lg);
color: var(--text-secondary);
margin-top: var(--space-1);
}
.age-main__detail {
font-size: var(--font-size-sm);
color: var(--text-tertiary);
margin-top: var(--space-1);
}
.age-birthday {
display: flex;
align-items: center;
gap: var(--space-3);
padding: var(--space-4);
background: var(--accent-bg);
border-radius: var(--radius-md);
margin-bottom: var(--space-4);
}
.age-birthday__icon { font-size: 2rem; }
.age-birthday__text { font-size: var(--font-size-sm); color: var(--text-secondary); }
.color-input-row {
display: flex;
gap: var(--space-3);
align-items: center;
}
.input--color-lg {
width: 64px;
height: 48px;
padding: 4px;
border-radius: var(--radius-md);
cursor: pointer;
}
.input--mono {
font-family: var(--font-mono);
font-weight: 600;
font-size: var(--font-size-lg);
letter-spacing: 1px;
max-width: 160px;
}
.color-preview {
height: 120px;
border-radius: var(--radius-lg);
display: flex;
align-items: center;
justify-content: center;
margin-bottom: var(--space-4);
transition: background var(--transition-fast);
}
.color-preview__text {
font-size: var(--font-size-2xl);
font-weight: 700;
font-family: var(--font-mono);
}
.color-formats {
display: flex;
flex-direction: column;
gap: var(--space-2);
margin-bottom: var(--space-6);
}
.color-format {
display: flex;
align-items: center;
gap: var(--space-3);
padding: var(--space-3);
background: var(--bg-secondary);
border-radius: var(--radius-md);
cursor: pointer;
transition: background var(--transition-fast);
}
.color-format:hover { background: var(--bg-tertiary); }
.color-format__label {
font-weight: 600;
font-size: var(--font-size-xs);
color: var(--text-tertiary);
width: 36px;
text-transform: uppercase;
}
.color-format__value {
flex: 1;
font-family: var(--font-mono);
font-size: var(--font-size-sm);
color: var(--text-primary);
}
.color-format__copy { opacity: 0.4; }
.color-palettes { margin-bottom: var(--space-4); }
.color-palettes__title {
font-size: var(--font-size-base);
font-weight: 600;
color: var(--text-secondary);
margin-bottom: var(--space-4);
}
.palette-section { margin-bottom: var(--space-4); }
.palette-section__label {
font-size: var(--font-size-xs);
color: var(--text-tertiary);
text-transform: uppercase;
letter-spacing: 0.5px;
margin-bottom: var(--space-2);
}
.palette-row {
display: flex;
gap: var(--space-1);
flex-wrap: wrap;
}
.palette-swatch {
flex: 1;
min-width: 60px;
height: 48px;
border-radius: var(--radius-sm);
display: flex;
align-items: center;
justify-content: center;
font-size: var(--font-size-xs);
font-family: var(--font-mono);
font-weight: 600;
cursor: pointer;
transition: transform var(--transition-fast);
}
.palette-swatch:hover { transform: scale(1.05); }
.lorem-stats {
font-size: var(--font-size-sm);
color: var(--text-tertiary);
margin-bottom: var(--space-3);
}
.lorem-output {
background: var(--bg-secondary);
border-radius: var(--radius-md);
padding: var(--space-4);
font-size: var(--font-size-sm);
line-height: 1.7;
color: var(--text-primary);
max-height: 400px;
overflow-y: auto;
white-space: pre-wrap;
font-family: var(--font-mono);
}
.pomo-settings {
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: var(--space-3);
margin-bottom: var(--space-4);
}
@media (max-width: 639px) {
.pomo-settings { grid-template-columns: 1fr; }
}
.pomo-timer {
text-align: center;
padding: var(--space-6) 0;
}
.pomo-circle {
position: relative;
width: 260px;
height: 260px;
margin: 0 auto var(--space-6);
}
.pomo-circle__svg {
width: 100%;
height: 100%;
transform: rotate(-90deg);
}
.pomo-circle__bg {
fill: none;
stroke: var(--bg-tertiary);
stroke-width: 8;
}
.pomo-circle__progress {
fill: none;
stroke: var(--accent);
stroke-width: 8;
stroke-linecap: round;
transition: stroke-dashoffset 0.5s ease, stroke 0.3s;
}
.pomo-circle--work .pomo-circle__progress { stroke: var(--error); }
.pomo-circle--break .pomo-circle__progress { stroke: var(--success); }
.pomo-circle__content {
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
text-align: center;
}
.pomo-circle__time {
font-size: 3.5rem;
font-weight: 700;
font-family: var(--font-mono);
color: var(--text-primary);
line-height: 1;
}
.pomo-circle__phase {
font-size: var(--font-size-sm);
color: var(--text-secondary);
margin-top: var(--space-2);
}
.pomo-controls {
display: flex;
gap: var(--space-3);
justify-content: center;
align-items: center;
margin-bottom: var(--space-4);
}
.btn-lg {
padding: var(--space-3) var(--space-8);
font-size: var(--font-size-lg);
}
.pomo-sessions {
display: flex;
align-items: center;
justify-content: center;
gap: var(--space-2);
font-size: var(--font-size-lg);
margin-bottom: var(--space-4);
}
.pomo-sessions__label {
font-size: var(--font-size-sm);
color: var(--text-tertiary);
}
.pomo-stats {
display: grid;
grid-template-columns: repeat(2, 1fr);
gap: var(--space-3);
max-width: 300px;
margin: 0 auto;
}
.common-optional { font-weight: 400; color: var(--text-tertiary); }
.case-grid {
display: grid;
grid-template-columns: repeat(2, 1fr);
gap: var(--space-3);
}
@media (max-width: 639px) {
.case-grid { grid-template-columns: 1fr; }
}
.case-card {
background: var(--bg-secondary);
border-radius: var(--radius-md);
padding: var(--space-3);
}
.case-card__label {
font-size: var(--font-size-xs);
color: var(--text-tertiary);
text-transform: uppercase;
letter-spacing: 0.5px;
margin-bottom: var(--space-1);
}
.case-card__output {
font-size: var(--font-size-sm);
color: var(--text-primary);
word-break: break-word;
min-height: 20px;
margin-bottom: var(--space-2);
line-height: 1.5;
}
.btn-xs {
padding: 2px 8px;
font-size: var(--font-size-xs);
}
.date-result {
background: var(--bg-secondary);
border-radius: var(--radius-lg);
padding: var(--space-6);
text-align: center;
}
.date-result__main {
font-size: var(--font-size-2xl);
font-weight: 700;
color: var(--accent);
}
.date-result__sub {
font-size: var(--font-size-sm);
color: var(--text-secondary);
margin-top: var(--space-2);
}
.base-grid {
display: grid;
grid-template-columns: 1fr;
gap: var(--space-3);
}
.base-field {
display: flex;
align-items: center;
gap: var(--space-2);
}
.base-field__label {
font-size: var(--font-size-sm);
font-weight: 600;
color: var(--text-secondary);
min-width: 130px;
}
.base-field .input { flex: 1; }
.base-info {
margin-top: var(--space-4);
padding: var(--space-3);
background: var(--bg-secondary);
border-radius: var(--radius-md);
}
.base-ref-grid {
display: grid;
grid-template-columns: 1fr;
gap: 1px;
background: var(--border-light);
border-radius: var(--radius-md);
overflow: hidden;
font-size: var(--font-size-xs);
font-family: var(--font-mono);
}
.base-ref-row {
display: grid;
grid-template-columns: repeat(4, 1fr);
background: var(--bg-primary);
padding: var(--space-2);
cursor: pointer;
transition: background var(--transition-fast);
}
.base-ref-row:hover { background: var(--bg-secondary); }
.base-ref-row--header {
background: var(--bg-tertiary);
font-weight: 600;
color: var(--text-tertiary);
cursor: default;
}
.base-ref-row--header:hover { background: var(--bg-tertiary); }
.diff-inputs {
display: grid;
grid-template-columns: 1fr 1fr;
gap: var(--space-3);
}
@media (max-width: 639px) {
.diff-inputs { grid-template-columns: 1fr; }
}
.textarea--mono {
font-family: var(--font-mono);
font-size: var(--font-size-sm);
}
.diff-stats {
display: flex;
gap: var(--space-3);
margin-bottom: var(--space-4);
flex-wrap: wrap;
}
.diff-stat {
font-size: var(--font-size-sm);
font-weight: 600;
padding: var(--space-1) var(--space-3);
border-radius: var(--radius-full);
background: var(--bg-secondary);
}
.diff-stat--add { background: var(--success-bg); color: var(--success); }
.diff-stat--remove { background: var(--error-bg); color: var(--error); }
.diff-output {
font-family: var(--font-mono);
font-size: var(--font-size-sm);
line-height: 1.7;
}
.diff-line {
padding: 2px var(--space-3);
border-radius: 2px;
}
.diff-line--add { background: var(--success-bg); color: var(--success); }
.diff-line--remove { background: var(--error-bg); color: var(--error); text-decoration: line-through; }
.diff-inline-wrap { word-break: break-word; line-height: 2; }
.diff-inline--add {
background: var(--success-bg);
color: var(--success);
padding: 1px 2px;
border-radius: 2px;
}
.diff-inline--remove {
background: var(--error-bg);
color: var(--error);
text-decoration: line-through;
padding: 1px 2px;
border-radius: 2px;
}
.ratio-presets { display: flex; gap: var(--space-2); flex-wrap: wrap; }
.tool-form__label--sm {
font-size: var(--font-size-xs);
color: var(--text-tertiary);
margin-bottom: var(--space-1);
display: block;
}
.ratio-preview-wrap {
display: flex;
justify-content: center;
padding: var(--space-6);
background: var(--bg-secondary);
border-radius: var(--radius-lg);
}
.ratio-preview {
border: 2px solid var(--accent);
border-radius: var(--radius-sm);
display: flex;
align-items: center;
justify-content: center;
background: var(--accent-bg);
transition: width var(--transition-base), height var(--transition-base);
}
.ratio-preview span {
font-weight: 700;
color: var(--accent);
font-size: var(--font-size-lg);
}
.ratio-suggestions { display: flex; gap: var(--space-2); flex-wrap: wrap; }
.chip--sm {
font-size: var(--font-size-xs);
padding: 2px 8px;
}
.stopwatch-container {
text-align: center;
padding: var(--space-4) 0;
}
.sw-display {
margin-bottom: var(--space-6);
}
.sw-display__time {
font-size: 5rem;
font-weight: 700;
font-family: var(--font-mono);
color: var(--text-primary);
line-height: 1;
letter-spacing: 2px;
}
@media (max-width: 639px) {
.sw-display__time { font-size: 3rem; }
}
.sw-controls {
display: flex;
gap: var(--space-3);
justify-content: center;
flex-wrap: wrap;
margin-bottom: var(--space-6);
}
.sw-btn { min-width: 120px; }
.sw-laps-header {
display: grid;
grid-template-columns: 60px 1fr 1fr;
gap: var(--space-2);
padding: var(--space-2) var(--space-3);
font-size: var(--font-size-xs);
font-weight: 600;
color: var(--text-tertiary);
text-transform: uppercase;
border-bottom: 1px solid var(--border);
text-align: left;
}
.sw-laps-body {
max-height: 300px;
overflow-y: auto;
}
.sw-lap {
display: grid;
grid-template-columns: 60px 1fr 1fr;
gap: var(--space-2);
padding: var(--space-2) var(--space-3);
font-family: var(--font-mono);
font-size: var(--font-size-sm);
border-bottom: 1px solid var(--border-light);
text-align: left;
}
.sw-lap--best { background: var(--success-bg); }
.sw-lap--best .sw-lap__time { color: var(--success); font-weight: 600; }
.sw-lap--worst { background: var(--error-bg); }
.sw-lap--worst .sw-lap__time { color: var(--error); font-weight: 600; }
.sw-lap__num { color: var(--text-tertiary); }
.md-editor {
border: 1px solid var(--border);
border-radius: var(--radius-lg);
overflow: hidden;
}
.md-toolbar {
display: flex;
gap: 2px;
padding: var(--space-2);
background: var(--bg-tertiary);
border-bottom: 1px solid var(--border);
flex-wrap: wrap;
}
.md-toolbar__btn {
width: 32px; height: 32px;
display: flex; align-items: center; justify-content: center;
border: none; background: transparent;
border-radius: var(--radius-sm);
cursor: pointer; font-size: var(--font-size-sm);
color: var(--text-secondary);
transition: all var(--transition-fast);
}
.md-toolbar__btn:hover { background: var(--bg-secondary); color: var(--text-primary); }
.md-toolbar__sep {
width: 1px; height: 24px; align-self: center;
background: var(--border); margin: 0 var(--space-1);
}
.md-split {
display: grid;
grid-template-columns: 1fr 1fr;
min-height: 400px;
}
@media (max-width: 767px) {
.md-split { grid-template-columns: 1fr; }
}
.md-pane { position: relative; }
.md-pane__label {
position: absolute; top: var(--space-2); right: var(--space-2);
font-size: var(--font-size-xs); color: var(--text-tertiary);
background: var(--bg-primary); padding: 2px 8px;
border-radius: var(--radius-sm); z-index: 1;
}
.md-textarea {
border: none; border-radius: 0;
border-right: 1px solid var(--border);
resize: none; height: 100%; min-height: 400px;
}
.md-preview {
padding: var(--space-4);
overflow-y: auto;
max-height: 500px;
font-size: var(--font-size-sm);
line-height: 1.7;
}
.md-preview h1 { font-size: var(--font-size-2xl); margin: var(--space-4) 0 var(--space-2); border-bottom: 1px solid var(--border); padding-bottom: var(--space-2); }
.md-preview h2 { font-size: var(--font-size-xl); margin: var(--space-3) 0 var(--space-2); }
.md-preview h3 { font-size: var(--font-size-lg); margin: var(--space-3) 0 var(--space-2); }
.md-preview pre {
background: var(--bg-tertiary); padding: var(--space-3);
border-radius: var(--radius-md); overflow-x: auto;
font-family: var(--font-mono); font-size: var(--font-size-xs);
}
.md-preview code {
background: var(--bg-tertiary); padding: 1px 4px;
border-radius: 3px; font-family: var(--font-mono);
font-size: 0.9em;
}
.md-preview pre code { background: none; padding: 0; }
.md-preview blockquote {
border-left: 3px solid var(--accent);
padding-left: var(--space-4); margin: var(--space-3) 0;
color: var(--text-secondary); font-style: italic;
}
.md-preview hr { border: none; border-top: 1px solid var(--border); margin: var(--space-4) 0; }
.md-preview ul, .md-preview ol { padding-left: var(--space-6); }
.md-preview a { color: var(--accent); text-decoration: underline; }
.md-preview img { border-radius: var(--radius-md); }
.url-result {
background: var(--bg-secondary);
padding: var(--space-4);
border-radius: var(--radius-md);
}
.url-result--error { color: var(--error); }
.url-result__code {
font-family: var(--font-mono);
font-size: var(--font-size-sm);
word-break: break-all;
line-height: 1.6;
}
.url-result__meta {
font-size: var(--font-size-xs);
color: var(--text-tertiary);
margin-top: var(--space-2);
}
.url-parts { display: grid; gap: 1px; }
.url-part {
display: grid;
grid-template-columns: 120px 1fr;
gap: var(--space-3);
padding: var(--space-2) var(--space-3);
background: var(--bg-secondary);
border-radius: var(--radius-sm);
}
.url-part--header {
background: var(--accent-bg);
font-weight: 600;
margin-top: var(--space-3);
}
.url-part--param { padding-left: var(--space-6); }
.url-part__key { font-weight: 600; color: var(--text-secondary); font-size: var(--font-size-sm); }
.url-part__val { font-family: var(--font-mono); font-size: var(--font-size-sm); word-break: break-all; }
.checkbox-inline {
display: flex; align-items: center; gap: var(--space-2);
font-size: var(--font-size-sm); color: var(--text-secondary);
cursor: pointer;
}
.dec-question {
text-align: center;
font-size: var(--font-size-lg);
color: var(--text-secondary);
margin-bottom: var(--space-4);
}
.dec-result {
text-align: center;
padding: var(--space-8) var(--space-4);
background: var(--bg-secondary);
border-radius: var(--radius-xl);
transition: transform var(--transition-base);
}
.dec-result--reveal {
animation: decReveal 0.5s ease;
}
@keyframes decReveal {
0% { transform: scale(0.8); opacity: 0.5; }
50% { transform: scale(1.1); }
100% { transform: scale(1); opacity: 1; }
}
.dec-result__icon { font-size: 4rem; margin-bottom: var(--space-3); }
.dec-result__text {
font-size: var(--font-size-3xl);
font-weight: 700;
transition: color var(--transition-fast);
}
.dec-history { margin-top: var(--space-4); }
.dec-history__title {
font-size: var(--font-size-xs);
color: var(--text-tertiary);
text-transform: uppercase;
margin-bottom: var(--space-2);
}
.dec-history__item {
display: inline-block;
padding: var(--space-1) var(--space-3);
background: var(--bg-secondary);
border-radius: var(--radius-full);
font-size: var(--font-size-sm);
margin: 2px;
}
.grade-table__header {
display: grid;
grid-template-columns: 2fr 1fr 1fr 40px;
gap: var(--space-2);
padding: var(--space-2) var(--space-3);
font-size: var(--font-size-xs);
font-weight: 600;
color: var(--text-tertiary);
text-transform: uppercase;
border-bottom: 1px solid var(--border);
}
.grade-row {
display: grid;
grid-template-columns: 2fr 1fr 1fr 40px;
gap: var(--space-2);
padding: var(--space-2) var(--space-3);
align-items: center;
border-bottom: 1px solid var(--border-light);
}
.input--sm { padding: var(--space-2); font-size: var(--font-size-sm); }
.grade-result {
text-align: center;
padding: var(--space-6);
background: var(--bg-secondary);
border-radius: var(--radius-xl);
}
.grade-result__avg {
font-size: 4rem;
font-weight: 700;
line-height: 1;
}
.grade-result__label {
font-size: var(--font-size-sm);
color: var(--text-tertiary);
margin-top: var(--space-1);
}
.grade-result__mention {
font-size: var(--font-size-lg);
margin-top: var(--space-3);
}
.tz-result {
display: flex;
align-items: center;
justify-content: center;
gap: var(--space-6);
padding: var(--space-6);
background: var(--bg-secondary);
border-radius: var(--radius-xl);
text-align: center;
}
@media (max-width: 639px) {
.tz-result { flex-direction: column; gap: var(--space-3); }
.tz-result__arrow { transform: rotate(90deg); }
}
.tz-result__time {
font-size: var(--font-size-3xl);
font-weight: 700;
font-family: var(--font-mono);
color: var(--accent);
}
.tz-result__zone {
font-size: var(--font-size-xs);
color: var(--text-secondary);
margin-top: var(--space-1);
}
.tz-result__arrow {
font-size: var(--font-size-2xl);
color: var(--text-tertiary);
}
.tz-diff {
text-align: center;
margin-top: var(--space-3);
font-size: var(--font-size-sm);
color: var(--text-tertiary);
}
.tz-world {
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: var(--space-3);
}
@media (max-width: 639px) {
.tz-world { grid-template-columns: repeat(2, 1fr); }
}
.tz-clock {
text-align: center;
padding: var(--space-3);
background: var(--bg-secondary);
border-radius: var(--radius-md);
}
.tz-clock__time {
font-size: var(--font-size-xl);
font-weight: 700;
font-family: var(--font-mono);
color: var(--text-primary);
}
.tz-clock__city {
font-size: var(--font-size-xs);
color: var(--text-tertiary);
margin-top: var(--space-1);
}
.json-status {
display: flex;
flex-direction: column;
gap: var(--space-2);
}
.json-status__badge {
display: inline-block;
padding: var(--space-1) var(--space-3);
border-radius: var(--radius-full);
font-size: var(--font-size-sm);
font-weight: 600;
}
.json-status__badge--valid { background: var(--success-bg); color: var(--success); }
.json-status__badge--error { background: var(--error-bg); color: var(--error); }
.json-error {
font-family: var(--font-mono);
font-size: var(--font-size-sm);
color: var(--error);
margin-top: var(--space-2);
}
.json-error-pos {
font-size: var(--font-size-xs);
color: var(--text-tertiary);
}
.json-output {
max-height: 500px;
overflow: auto;
}
.json-highlighted {
background: var(--bg-secondary);
padding: var(--space-4);
border-radius: var(--radius-md);
font-family: var(--font-mono);
font-size: var(--font-size-xs);
line-height: 1.6;
white-space: pre-wrap;
word-break: break-word;
margin: 0;
}
.json-key { color: #7C3AED; }
.json-string { color: #059669; }
.json-number { color: #D97706; }
.json-boolean { color: #2563EB; }
.json-null { color: #9CA3AF; }
[data-theme="dark"] .json-key { color: #A78BFA; }
[data-theme="dark"] .json-string { color: #34D399; }
[data-theme="dark"] .json-number { color: #FBBF24; }
[data-theme="dark"] .json-boolean { color: #60A5FA; }
.json-tree {
font-family: var(--font-mono);
font-size: var(--font-size-xs);
padding: var(--space-3);
background: var(--bg-secondary);
border-radius: var(--radius-md);
max-height: 400px;
overflow: auto;
}
.json-tree__node { padding-left: var(--space-4); }
.json-tree__key { color: var(--accent); font-weight: 600; }
.json-tree__type {
color: var(--text-tertiary);
font-size: var(--font-size-xs);
margin-left: var(--space-1);
}
.json-tree__val { color: var(--success); }
.hash-grid { display: grid; gap: var(--space-3); }
.hash-card {
display: grid;
grid-template-columns: auto 1fr auto;
gap: var(--space-3);
align-items: center;
padding: var(--space-3) var(--space-4);
background: var(--bg-secondary);
border-radius: var(--radius-md);
}
.hash-card__header { min-width: 70px; }
.hash-card__name { font-weight: 700; font-size: var(--font-size-sm); }
.hash-card__bits {
display: block;
font-size: var(--font-size-xs);
color: var(--text-tertiary);
}
.hash-card__value {
font-family: var(--font-mono);
font-size: var(--font-size-xs);
word-break: break-all;
line-height: 1.5;
color: var(--accent);
}
.hash-card__copy { justify-self: end; }
.hash-compare { padding-top: var(--space-4); border-top: 1px solid var(--border-light); }
.css-grid {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
gap: var(--space-3);
}
.css-field {
background: var(--bg-secondary);
padding: var(--space-3);
border-radius: var(--radius-md);
}
.css-field__label {
display: block;
font-weight: 700;
font-size: var(--font-size-sm);
color: var(--accent);
margin-bottom: var(--space-2);
font-family: var(--font-mono);
}
.css-field__input { width: 100%; }
.input-group {
display: flex;
align-items: center;
gap: var(--space-2);
}
.input-group__suffix {
font-size: var(--font-size-sm);
color: var(--text-tertiary);
font-weight: 600;
white-space: nowrap;
}
.css-ref { display: grid; gap: 2px; }
.css-ref__row {
display: grid;
grid-template-columns: 80px 1fr;
gap: var(--space-3);
padding: var(--space-2) var(--space-3);
font-size: var(--font-size-sm);
}
.css-ref__row code {
font-family: var(--font-mono);
color: var(--accent);
font-weight: 600;
}
.screen-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: var(--space-4); }
.screen-section {
background: var(--bg-secondary);
padding: var(--space-4);
border-radius: var(--radius-lg);
}
.screen-section__title {
font-weight: 700;
font-size: var(--font-size-sm);
margin-bottom: var(--space-3);
padding-bottom: var(--space-2);
border-bottom: 1px solid var(--border-light);
}
.screen-row {
display: flex;
justify-content: space-between;
padding: var(--space-1) 0;
font-size: var(--font-size-sm);
}
.screen-row__key { color: var(--text-secondary); }
.screen-row__val { font-weight: 600; font-family: var(--font-mono); font-size: var(--font-size-xs); text-align: right; max-width: 60%; word-break: break-word; }
.screen-preview {
display: flex;
align-items: center;
justify-content: center;
padding: var(--space-6);
background: var(--bg-secondary);
border-radius: var(--radius-lg);
}
.screen-preview__inner {
border: 2px solid var(--accent);
border-radius: var(--radius-sm);
display: flex;
align-items: center;
justify-content: center;
font-size: var(--font-size-xs);
font-family: var(--font-mono);
color: var(--accent);
background: var(--accent-bg);
}
.screen-devices {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
gap: var(--space-2);
}
.screen-device {
display: flex;
flex-direction: column;
padding: var(--space-2) var(--space-3);
background: var(--bg-secondary);
border-radius: var(--radius-md);
font-size: var(--font-size-xs);
}
.screen-device--match { background: var(--accent-bg); border: 1px solid var(--accent); }
.screen-device__name { font-weight: 600; }
.screen-device__size { font-family: var(--font-mono); color: var(--text-secondary); }
.screen-device__dpr { color: var(--text-tertiary); }
.grad-preview {
width: 100%; height: 200px;
border-radius: var(--radius-lg);
background: linear-gradient(90deg, #8B5CF6, #06B6D4);
margin-bottom: var(--space-4);
box-shadow: var(--shadow-lg);
}
.grad-stops { display: grid; gap: var(--space-2); }
.grad-stop {
display: flex; align-items: center; gap: var(--space-2);
}
.grad-stop__color {
width: 40px; height: 36px;
border: none; padding: 0; cursor: pointer;
border-radius: var(--radius-sm);
background: none;
}
.grad-stop__pos {
font-size: var(--font-size-xs);
color: var(--text-tertiary);
min-width: 36px;
text-align: right;
}
.grad-css {
display: block;
font-family: var(--font-mono);
font-size: var(--font-size-sm);
background: var(--bg-tertiary);
padding: var(--space-3);
border-radius: var(--radius-md);
word-break: break-all;
color: var(--accent);
line-height: 1.6;
}
.grad-presets {
display: flex; flex-wrap: wrap; gap: var(--space-2);
}
.grad-preset {
width: 48px; height: 32px;
border-radius: var(--radius-sm);
cursor: pointer;
transition: transform var(--transition-fast);
box-shadow: var(--shadow-sm);
}
.grad-preset:hover { transform: scale(1.15); }
.dice-count {
font-size: var(--font-size-2xl);
font-weight: 700;
min-width: 40px;
text-align: center;
}
.dice-display {
display: flex; justify-content: center; flex-wrap: wrap;
gap: var(--space-3);
min-height: 80px;
padding: var(--space-4);
}
.dice-face {
font-size: 3rem;
line-height: 1;
transition: transform 0.15s ease;
}
.dice-face--num {
display: flex; align-items: center; justify-content: center;
width: 64px; height: 64px;
background: var(--bg-tertiary);
border-radius: var(--radius-md);
border: 2px solid var(--border);
font-size: var(--font-size-xl);
font-weight: 700;
font-family: var(--font-mono);
}
.dice-face--rolling { animation: diceShake 0.08s infinite alternate; }
.dice-face--final { animation: dicePop 0.3s ease; }
@keyframes diceShake { from { transform: rotate(-5deg) scale(0.95); } to { transform: rotate(5deg) scale(1.05); } }
@keyframes dicePop { 0% { transform: scale(0.5); } 60% { transform: scale(1.15); } 100% { transform: scale(1); } }
.dice-total {
text-align: center;
padding: var(--space-3);
}
.dice-total__number {
font-size: 3.5rem;
font-weight: 700;
color: var(--accent);
font-family: var(--font-mono);
}
.dice-formula {
text-align: center;
font-size: var(--font-size-sm);
color: var(--text-tertiary);
font-family: var(--font-mono);
}
.dice-history { display: grid; gap: var(--space-1); }
.dice-history__item {
display: flex; align-items: center; gap: var(--space-3);
padding: var(--space-2);
font-size: var(--font-size-sm);
border-bottom: 1px solid var(--border-light);
}
.dice-history__formula { font-weight: 600; min-width: 60px; }
.dice-history__values { flex: 1; color: var(--text-secondary); font-family: var(--font-mono); }
.dice-history__total { font-weight: 700; color: var(--accent); }
.rom-result { text-align: center; padding: var(--space-6); }
.rom-result__value {
font-size: 3rem; font-weight: 700;
color: var(--accent);
font-family: var(--font-mono);
letter-spacing: 2px;
}
.rom-result__breakdown {
margin-top: var(--space-2);
font-size: var(--font-size-sm);
color: var(--text-tertiary);
font-family: var(--font-mono);
}
.rom-ref { display: grid; gap: 0; }
.rom-ref__row {
display: grid; grid-template-columns: 1fr 1fr;
padding: var(--space-2) var(--space-3);
font-size: var(--font-size-sm);
border-bottom: 1px solid var(--border-light);
font-family: var(--font-mono);
}
.rom-ref__row--header {
font-weight: 600; font-family: var(--font-sans);
background: var(--bg-tertiary);
border-radius: var(--radius-sm);
color: var(--text-tertiary);
}
.regex-input {
display: flex; align-items: center; gap: 0;
}
.regex-input__slash {
padding: var(--space-2) var(--space-2);
font-size: var(--font-size-xl);
color: var(--accent);
font-family: var(--font-mono);
font-weight: 700;
}
.regex-input__field {
flex: 1;
font-family: var(--font-mono);
font-size: var(--font-size-base);
}
.regex-input__flags {
width: 60px;
font-family: var(--font-mono);
text-align: center;
}
.regex-flags {
display: flex; flex-wrap: wrap; gap: var(--space-3);
font-size: var(--font-size-sm);
}
.regex-flags code {
background: var(--accent-bg);
padding: 1px 4px;
border-radius: 3px;
color: var(--accent);
}
.regex-result {
font-family: var(--font-mono);
font-size: var(--font-size-sm);
background: var(--bg-secondary);
padding: var(--space-3);
border-radius: var(--radius-md);
white-space: pre-wrap;
line-height: 1.8;
min-height: 60px;
word-break: break-word;
}
.regex-highlight {
background: rgba(139, 92, 246, 0.25);
color: var(--accent);
border-radius: 2px;
padding: 1px 2px;
}
.regex-info { margin-top: var(--space-2); }
.regex-info__count {
font-size: var(--font-size-sm);
font-weight: 600;
color: var(--accent);
}
.regex-matches { display: grid; gap: var(--space-1); margin-top: var(--space-3); }
.regex-match {
display: flex; align-items: center; gap: var(--space-2);
padding: var(--space-2);
font-size: var(--font-size-xs);
background: var(--bg-secondary);
border-radius: var(--radius-sm);
}
.regex-match__idx { color: var(--text-tertiary); min-width: 28px; }
.regex-match__val { color: var(--accent); font-family: var(--font-mono); }
.regex-match__pos { color: var(--text-tertiary); }
.regex-match__group {
font-family: var(--font-mono);
color: var(--text-secondary);
background: var(--bg-tertiary);
padding: 1px 4px;
border-radius: 3px;
}
.regex-cheat {
display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
gap: var(--space-1);
}
.regex-cheat__row {
font-size: var(--font-size-xs);
padding: var(--space-1) var(--space-2);
}
.regex-cheat__row code {
background: var(--accent-bg);
padding: 1px 4px;
border-radius: 3px;
color: var(--accent);
font-family: var(--font-mono);
margin-right: var(--space-1);
}
.emoji-cats {
display: flex; flex-wrap: wrap; gap: var(--space-1);
margin-bottom: var(--space-3);
}
.emoji-cat {
width: 36px; height: 36px;
display: flex; align-items: center; justify-content: center;
font-size: 1.2rem;
border: none; background: var(--bg-secondary);
border-radius: var(--radius-sm);
cursor: pointer;
transition: all var(--transition-fast);
}
.emoji-cat:hover { background: var(--bg-tertiary); }
.emoji-cat--active { background: var(--accent-bg); box-shadow: 0 0 0 2px var(--accent); }
.emoji-grid {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(40px, 1fr));
gap: var(--space-1);
max-height: 320px;
overflow-y: auto;
padding: var(--space-2);
background: var(--bg-secondary);
border-radius: var(--radius-md);
}
.emoji-item {
width: 40px; height: 40px;
display: flex; align-items: center; justify-content: center;
font-size: 1.4rem;
border: none; background: none;
cursor: pointer;
border-radius: var(--radius-sm);
transition: all var(--transition-fast);
}
.emoji-item:hover { background: var(--bg-tertiary); transform: scale(1.2); }
.emoji-clip {
display: flex; align-items: center; gap: var(--space-3);
}
.emoji-clip__text {
flex: 1;
min-height: 40px;
padding: var(--space-2) var(--space-3);
background: var(--bg-secondary);
border-radius: var(--radius-md);
font-size: 1.4rem;
letter-spacing: 2px;
word-break: break-word;
}
.emoji-clip__actions { display: flex; gap: var(--space-2); }
.chart-rows { display: grid; gap: var(--space-2); }
.chart-row {
display: flex; align-items: center; gap: var(--space-2);
}
.chart-row__label { flex: 1; }
.chart-row__value { width: 100px; }
.tts-progress {
margin-top: var(--space-4);
text-align: center;
}
.tts-progress__bar {
height: 6px;
background: var(--bg-tertiary);
border-radius: var(--radius-full);
overflow: hidden;
margin-bottom: var(--space-2);
}
.tts-progress__fill {
height: 100%;
background: var(--accent);
border-radius: var(--radius-full);
transition: width 0.2s ease;
width: 0%;
}
.tts-progress__word {
font-size: var(--font-size-lg);
font-weight: 600;
color: var(--accent);
min-height: 28px;
}
.evt-list { display: grid; gap: var(--space-3); }
.evt-card {
background: var(--bg-secondary);
border-radius: var(--radius-lg);
padding: var(--space-4);
border-left: 4px solid var(--accent);
}
.evt-card--past { opacity: 0.5; border-left-color: var(--text-tertiary); }
.evt-card__header {
display: flex; align-items: center; gap: var(--space-2);
margin-bottom: var(--space-2);
}
.evt-card__cat { font-size: 1.4rem; }
.evt-card__name { font-weight: 600; flex: 1; }
.evt-card__actions { display: flex; gap: var(--space-1); }
.evt-card__date {
font-size: var(--font-size-xs);
color: var(--text-tertiary);
margin-bottom: var(--space-3);
}
.evt-card__countdown { text-align: center; }
.evt-card__units { display: flex; justify-content: center; gap: var(--space-4); }
.evt-unit { text-align: center; }
.evt-unit__num {
display: block;
font-size: var(--font-size-2xl);
font-weight: 700;
font-family: var(--font-mono);
color: var(--accent);
}
.evt-unit__label {
font-size: var(--font-size-xs);
color: var(--text-tertiary);
text-transform: uppercase;
}
.evt-card__past-label {
color: var(--text-tertiary);
font-style: italic;
}
.fib-sequence {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
gap: var(--space-2);
max-height: 400px;
overflow-y: auto;
}
.fib-item {
display: flex; align-items: center; gap: var(--space-2);
padding: var(--space-2);
background: var(--bg-secondary);
border-radius: var(--radius-sm);
font-size: var(--font-size-sm);
}
.fib-item__idx {
color: var(--text-tertiary);
font-family: var(--font-mono);
font-size: var(--font-size-xs);
min-width: 40px;
}
.fib-item__val {
font-weight: 600;
font-family: var(--font-mono);
flex: 1;
word-break: break-all;
}
.fib-item__ratio {
font-size: var(--font-size-xs);
color: var(--text-tertiary);
display: none;
}
@media (min-width: 640px) { .fib-item__ratio { display: block; } }
.fib-nth { text-align: center; padding: var(--space-6); }
.fib-nth__label { font-size: var(--font-size-sm); color: var(--text-tertiary); margin-bottom: var(--space-2); }
.fib-nth__value {
font-size: var(--font-size-xl);
font-weight: 700;
font-family: var(--font-mono);
color: var(--accent);
word-break: break-all;
line-height: 1.4;
}
.fib-nth__meta { font-size: var(--font-size-xs); color: var(--text-tertiary); margin-top: var(--space-2); }
.fib-check { text-align: center; padding: var(--space-6); }
.fib-check__icon { font-size: 2rem; margin-bottom: var(--space-2); }
.fib-check__msg { font-size: var(--font-size-lg); }
.fib-check__detail { font-size: var(--font-size-sm); color: var(--text-tertiary); margin-top: var(--space-2); }
.fib-golden { text-align: center; padding: var(--space-4); }
.fib-golden__symbol { font-size: 3rem; font-weight: 700; color: var(--accent); font-family: serif; }
.fib-golden__value { font-family: var(--font-mono); font-size: var(--font-size-lg); margin: var(--space-2) 0; }
.fib-golden__formula { font-family: var(--font-mono); color: var(--text-secondary); }
.fib-golden__desc { font-size: var(--font-size-sm); color: var(--text-tertiary); margin-top: var(--space-3); max-width: 400px; margin-inline: auto; }
.lp-meta { display: grid; gap: 0; }
.lp-meta__row {
display: grid;
grid-template-columns: 130px 1fr;
gap: var(--space-3);
padding: var(--space-2) var(--space-3);
border-bottom: 1px solid var(--border-light);
font-size: var(--font-size-sm);
}
.lp-meta__key { font-weight: 600; color: var(--text-secondary); }
.lp-meta__val { word-break: break-word; }
.lp-meta__img { max-height: 20px; border-radius: 2px; vertical-align: middle; margin-right: var(--space-1); }
.lp-social-card {
border: 1px solid var(--border);
border-radius: var(--radius-lg);
overflow: hidden;
max-width: 500px;
}
.lp-social-card__img img { width: 100%; max-height: 260px; object-fit: cover; display: block; }
.lp-social-card__body { padding: var(--space-3); }
.lp-social-card__domain { font-size: var(--font-size-xs); color: var(--text-tertiary); text-transform: uppercase; }
.lp-social-card__title { font-weight: 600; margin: var(--space-1) 0; }
.lp-social-card__desc { font-size: var(--font-size-sm); color: var(--text-secondary); }
.crop-container {
position: relative;
display: inline-block;
max-width: 100%;
margin: var(--space-4) auto;
display: flex;
justify-content: center;
}
.crop-container canvas { display: block; cursor: crosshair; max-width: 100%; border-radius: var(--radius-md); }
.crop-info {
text-align: center;
font-size: var(--font-size-sm);
color: var(--text-tertiary);
font-family: var(--font-mono);
margin-top: var(--space-2);
}
.prob-panel { margin-top: var(--space-2); }
.prob-result { text-align: center; padding: var(--space-4); }
.prob-result__title { font-size: var(--font-size-sm); color: var(--text-secondary); margin-bottom: var(--space-2); }
.prob-result__pct {
font-size: 2.5rem;
font-weight: 700;
color: var(--accent);
font-family: var(--font-mono);
}
.prob-result__bar {
height: 8px;
background: var(--bg-tertiary);
border-radius: var(--radius-full);
overflow: hidden;
margin: var(--space-3) auto;
max-width: 300px;
}
.prob-result__fill {
height: 100%;
background: var(--accent);
border-radius: var(--radius-full);
transition: width 0.3s ease;
}
.prob-result__meta {
display: flex; justify-content: center; gap: var(--space-4); flex-wrap: wrap;
font-size: var(--font-size-sm);
color: var(--text-tertiary);
margin-top: var(--space-2);
}
.prob-result__detail {
font-size: var(--font-size-xs);
color: var(--text-tertiary);
font-family: var(--font-mono);
margin-top: var(--space-3);
}
.prob-combo {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
gap: var(--space-3);
}
.prob-combo__item {
text-align: center;
padding: var(--space-4);
background: var(--bg-secondary);
border-radius: var(--radius-md);
}
.prob-combo__label { font-size: var(--font-size-sm); color: var(--text-secondary); margin-bottom: var(--space-2); }
.prob-combo__value {
font-size: var(--font-size-xl);
font-weight: 700;
color: var(--accent);
font-family: var(--font-mono);
word-break: break-all;
}
.prob-combo__formula {
font-size: var(--font-size-xs);
color: var(--text-tertiary);
font-family: var(--font-mono);
margin-top: var(--space-2);
}
.cp-palette {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
gap: 0;
border-radius: var(--radius-lg);
overflow: hidden;
margin-bottom: var(--space-4);
}
.cp-swatch {
padding: var(--space-5) var(--space-3);
text-align: center;
cursor: pointer;
transition: transform var(--transition-fast);
min-height: 100px;
display: flex;
flex-direction: column;
justify-content: center;
}
.cp-swatch:hover { transform: scale(1.05); z-index: 1; }
.cp-swatch__hex { font-weight: 700; font-family: var(--font-mono); font-size: var(--font-size-sm); }
.cp-swatch__hsl, .cp-swatch__rgb { font-size: var(--font-size-xs); opacity: 0.75; margin-top: 2px; }
.cp-export { margin-top: var(--space-3); }
.cp-code {
background: var(--bg-tertiary);
padding: var(--space-3);
border-radius: var(--radius-md);
font-family: var(--font-mono);
font-size: var(--font-size-sm);
overflow-x: auto;
white-space: pre;
margin-bottom: var(--space-2);
}
.csv-stats {
display: flex;
gap: var(--space-4);
align-items: center;
font-size: var(--font-size-sm);
color: var(--text-secondary);
}
.csv-table {
width: 100%;
border-collapse: collapse;
font-size: var(--font-size-sm);
}
.csv-table th {
background: var(--accent-bg);
color: var(--accent-text);
padding: var(--space-2) var(--space-3);
text-align: left;
font-weight: 600;
white-space: nowrap;
cursor: pointer;
user-select: none;
position: sticky;
top: 0;
}
.csv-table th:hover { background: var(--accent-light); }
.csv-table td {
padding: var(--space-2) var(--space-3);
border-bottom: 1px solid var(--border-light);
max-width: 300px;
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
}
.csv-table tr:hover td { background: var(--bg-secondary); }
.file-drop--sm { padding: var(--space-3); font-size: var(--font-size-sm); }
.enc-strength { margin-top: var(--space-1); font-size: var(--font-size-xs); min-height: 16px; }
.enc-info {
display: flex;
gap: var(--space-2);
font-size: var(--font-size-xs);
color: var(--text-tertiary);
justify-content: center;
flex-wrap: wrap;
}
.textarea--mono { font-family: var(--font-mono); font-size: var(--font-size-sm); word-break: break-all; }
.tone-freq { display: flex; flex-direction: column; gap: var(--space-2); }
.tone-freq__display {
display: flex; align-items: center; gap: var(--space-2);
justify-content: center;
}
.tone-freq__note {
text-align: center;
font-size: var(--font-size-lg);
font-weight: 600;
color: var(--accent);
margin-top: var(--space-1);
}
.tone-presets { display: flex; gap: var(--space-2); flex-wrap: wrap; justify-content: center; }
.btn--playing { background: var(--error); }
.btn--playing:hover { background: var(--error); opacity: 0.9; }
.inv-items { border: 1px solid var(--border-light); border-radius: var(--radius-md); overflow: hidden; }
.inv-item-header {
display: flex;
gap: var(--space-2);
padding: var(--space-2) var(--space-3);
background: var(--bg-tertiary);
font-size: var(--font-size-xs);
font-weight: 600;
color: var(--text-tertiary);
text-transform: uppercase;
}
.inv-item-row {
display: flex;
gap: var(--space-2);
padding: var(--space-2) var(--space-3);
align-items: center;
border-top: 1px solid var(--border-light);
}
.inv-totals {
max-width: 320px;
margin-left: auto;
margin-top: var(--space-3);
}
.inv-total-row {
display: flex;
justify-content: space-between;
padding: var(--space-1) 0;
font-size: var(--font-size-sm);
color: var(--text-secondary);
}
.inv-total-row--grand {
border-top: 2px solid var(--accent);
padding-top: var(--space-2);
margin-top: var(--space-2);
font-size: var(--font-size-lg);
font-weight: 700;
color: var(--accent);
}
.typ-timer {
text-align: center;
margin-bottom: var(--space-4);
}
.typ-timer__value {
font-size: 3rem;
font-weight: 700;
font-family: var(--font-mono);
color: var(--accent);
}
.typ-timer--warn .typ-timer__value { color: var(--error); }
.typ-timer--done .typ-timer__value { color: var(--text-tertiary); }
.typ-timer__label {
display: block;
font-size: var(--font-size-xs);
color: var(--text-tertiary);
text-transform: uppercase;
}
.typ-text {
font-size: var(--font-size-lg);
line-height: 2;
padding: var(--space-4);
background: var(--bg-secondary);
border-radius: var(--radius-lg);
margin-bottom: var(--space-3);
min-height: 100px;
letter-spacing: 0.02em;
}
.typ-char { transition: color 0.05s; }
.typ-char--correct { color: var(--success); }
.typ-char--wrong { color: var(--error); background: rgba(239, 68, 68, 0.15); border-radius: 2px; }
.typ-char--cursor { border-left: 2px solid var(--accent); animation: typ-blink 1s infinite; }
@keyframes typ-blink { 0%, 100% { border-color: var(--accent); } 50% { border-color: transparent; } }
.typ-input {
font-family: var(--font-mono);
font-size: var(--font-size-lg);
letter-spacing: 0.02em;
}
.typ-results {
display: flex;
justify-content: center;
gap: var(--space-6);
flex-wrap: wrap;
}
.typ-stat { text-align: center; }
.typ-stat__value {
font-size: var(--font-size-2xl);
font-weight: 700;
font-family: var(--font-mono);
color: var(--text-primary);
}
.typ-stat--main .typ-stat__value { font-size: 3.5rem; color: var(--accent); }
.typ-stat__label {
font-size: var(--font-size-xs);
color: var(--text-tertiary);
text-transform: uppercase;
}
.loan-cards {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
gap: var(--space-3);
margin-bottom: var(--space-4);
}
.loan-card {
text-align: center;
padding: var(--space-3);
background: var(--bg-secondary);
border-radius: var(--radius-md);
}
.loan-card--main { background: var(--accent-bg); border: 1px solid var(--accent); }
.loan-card__label {
font-size: var(--font-size-xs);
color: var(--text-tertiary);
text-transform: uppercase;
margin-bottom: var(--space-1);
}
.loan-card__value {
font-size: var(--font-size-lg);
font-weight: 700;
font-family: var(--font-mono);
}
.loan-card--main .loan-card__value { font-size: var(--font-size-2xl); color: var(--accent); }
.loan-chart { text-align: center; margin: var(--space-4) 0; }
.loan-amort { max-height: 400px; overflow-y: auto; }
.tr-results { display: flex; flex-direction: column; gap: var(--space-3); }
.tr-card {
background: var(--bg-secondary);
border-radius: var(--radius-md);
overflow: hidden;
}
.tr-card__header {
display: flex;
justify-content: space-between;
align-items: center;
padding: var(--space-2) var(--space-3);
background: var(--bg-tertiary);
font-size: var(--font-size-sm);
font-weight: 600;
}
.tr-card__text {
padding: var(--space-3);
font-family: var(--font-mono);
font-size: var(--font-size-sm);
word-break: break-all;
line-height: 1.6;
}
.asc-output {
background: var(--bg-secondary);
padding: var(--space-4);
border-radius: var(--radius-lg);
font-family: var(--font-mono);
font-size: 12px;
line-height: 1.2;
overflow-x: auto;
white-space: pre;
min-height: 80px;
color: var(--accent);
}
.rt-box {
min-height: 280px;
border-radius: var(--radius-xl);
display: flex;
align-items: center;
justify-content: center;
cursor: pointer;
transition: background var(--transition-base);
background: var(--bg-secondary);
user-select: none;
}
.rt-box--waiting { background: #DC2626; }
.rt-box--ready { background: #10B981; }
.rt-box--result { background: var(--accent-bg); }
.rt-box--early { background: #F59E0B; }
.rt-box__content { text-align: center; }
.rt-box__icon { font-size: 4rem; margin-bottom: var(--space-2); }
.rt-box__text {
font-size: var(--font-size-3xl);
font-weight: 700;
color: var(--text-primary);
}
.rt-box--waiting .rt-box__text,
.rt-box--ready .rt-box__text,
.rt-box--early .rt-box__text { color: #fff; }
.rt-box__sub {
font-size: var(--font-size-sm);
color: var(--text-secondary);
margin-top: var(--space-1);
}
.rt-box--waiting .rt-box__sub,
.rt-box--ready .rt-box__sub,
.rt-box--early .rt-box__sub { color: rgba(255,255,255,0.8); }
.rt-history__header {
display: flex;
justify-content: space-between;
align-items: center;
margin-bottom: var(--space-3);
font-size: var(--font-size-sm);
color: var(--text-secondary);
}
.rt-bar-row {
display: flex;
align-items: center;
gap: var(--space-2);
margin-bottom: var(--space-1);
}
.rt-bar-label { font-size: var(--font-size-xs); color: var(--text-tertiary); width: 30px; }
.rt-bar-track { flex: 1; height: 8px; background: var(--bg-tertiary); border-radius: 4px; overflow: hidden; }
.rt-bar-fill { height: 100%; border-radius: 4px; transition: width 0.3s ease; }
.rt-bar-value { font-size: var(--font-size-xs); font-family: var(--font-mono); width: 55px; text-align: right; }
.pr-info {
display: flex;
gap: var(--space-2);
font-size: var(--font-size-xs);
color: var(--text-tertiary);
justify-content: center;
margin-bottom: var(--space-3);
flex-wrap: wrap;
}
.pr-canvas-wrap {
overflow-x: auto;
margin: var(--space-4) 0;
text-align: center;
}
.pr-ruler { display: inline-block; position: relative; }
.pr-ruler__label {
text-align: center;
font-size: var(--font-size-xs);
color: var(--text-tertiary);
font-family: var(--font-mono);
margin-bottom: var(--space-1);
}
.pr-measure-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
gap: var(--space-2);
font-size: var(--font-size-sm);
text-align: center;
}
.fc-list { display: flex; flex-direction: column; gap: var(--space-1); margin-top: var(--space-2); }
.fc-list-item {
display: flex;
align-items: center;
gap: var(--space-2);
padding: var(--space-2) var(--space-3);
background: var(--bg-secondary);
border-radius: var(--radius-md);
font-size: var(--font-size-sm);
}
.fc-list-item__front { flex: 1; font-weight: 600; }
.fc-list-item__sep { color: var(--accent); }
.fc-list-item__back { flex: 1; color: var(--text-secondary); }
.fc-decks { display: flex; flex-direction: column; gap: var(--space-2); }
.fc-deck-item {
display: flex;
justify-content: space-between;
align-items: center;
padding: var(--space-2) var(--space-3);
background: var(--bg-secondary);
border-radius: var(--radius-md);
font-size: var(--font-size-sm);
}
.fc-progress { height: 4px; background: var(--bg-tertiary); border-radius: 2px; margin-bottom: var(--space-4); }
.fc-progress__bar { height: 100%; background: var(--accent); border-radius: 2px; transition: width 0.3s ease; }
.fc-card {
perspective: 1000px;
min-height: 200px;
cursor: pointer;
margin-bottom: var(--space-3);
}
.fc-card__inner {
position: relative;
width: 100%;
min-height: 200px;
transition: transform 0.6s;
transform-style: preserve-3d;
}
.fc-card__inner--flipped { transform: rotateY(180deg); }
.fc-card__front, .fc-card__back {
position: absolute;
inset: 0;
backface-visibility: hidden;
display: flex;
align-items: center;
justify-content: center;
padding: var(--space-6);
border-radius: var(--radius-lg);
font-size: var(--font-size-xl);
font-weight: 600;
text-align: center;
word-break: break-word;
}
.fc-card__front {
background: var(--bg-secondary);
border: 2px solid var(--border);
}
.fc-card__back {
background: var(--accent-bg);
border: 2px solid var(--accent);
color: var(--accent);
transform: rotateY(180deg);
}
.fc-hint { text-align: center; font-size: var(--font-size-xs); color: var(--text-tertiary); margin-bottom: var(--space-3); }
.fc-nav {
display: flex;
justify-content: center;
align-items: center;
gap: var(--space-4);
margin-bottom: var(--space-3);
}
.fc-nav span { font-family: var(--font-mono); font-size: var(--font-size-sm); color: var(--text-secondary); }
.fc-confidence { display: flex; justify-content: center; gap: var(--space-2); }
.fc-done { text-align: center; padding: var(--space-10); }
.fc-done__icon { font-size: 4rem; margin-bottom: var(--space-3); }
.fc-done__text { font-size: var(--font-size-xl); font-weight: 600; color: var(--accent); }
.tc-unit { position: relative; }
.tc-unit__symbol { position: absolute; right: 12px; bottom: 12px; font-weight: 600; color: var(--text-tertiary); font-size: var(--font-size-sm); }
.tc-input { padding-right: 40px !important; font-family: var(--font-mono); }
.tc-presets { display: flex; flex-wrap: wrap; gap: var(--space-2); justify-content: center; }
.tc-thermo { height: 16px; background: var(--bg-tertiary); border-radius: 8px; overflow: hidden; margin-bottom: var(--space-2); }
.tc-thermo__bar { height: 100%; border-radius: 8px; transition: width 0.3s ease, background 0.3s ease; min-width: 4px; }
.tc-ref { text-align: center; font-size: var(--font-size-sm); color: var(--text-secondary); min-height: 20px; }
.tc-formulas { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: var(--space-2); margin-top: var(--space-4); }
.tc-formula { font-size: var(--font-size-xs); color: var(--text-tertiary); font-family: var(--font-mono); padding: var(--space-2); background: var(--bg-secondary); border-radius: var(--radius-sm); }
.sr-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: var(--space-2); }
.sr-card {
display: flex; align-items: center; gap: var(--space-2); padding: var(--space-2) var(--space-3);
background: var(--bg-secondary); border-radius: var(--radius-md); font-size: var(--font-size-sm);
}
.sr-card__icon { font-size: 1.1rem; }
.sr-card__label { color: var(--text-secondary); flex: 1; }
.sr-card__value { font-weight: 600; font-family: var(--font-mono); }
.sr-bp-list { display: flex; flex-wrap: wrap; gap: var(--space-2); justify-content: center; margin-top: var(--space-3); }
.sr-bp { padding: var(--space-1) var(--space-3); border-radius: var(--radius-full); font-size: var(--font-size-xs); background: var(--bg-tertiary); color: var(--text-tertiary); }
.sr-bp--active { background: var(--accent); color: #fff; font-weight: 600; }
.sr-responsive { display: grid; grid-template-columns: repeat(auto-fill, minmax(120px, 1fr)); gap: var(--space-2); }
.sr-resp-item { display: flex; flex-direction: column; align-items: center; gap: 2px; padding: var(--space-2); background: var(--bg-secondary); border-radius: var(--radius-md); cursor: pointer; font-size: var(--font-size-xs); transition: all var(--transition-fast); }
.sr-resp-item:hover { background: var(--accent-bg); transform: scale(1.03); }
.sr-resp-item span:first-child { font-size: 1.3rem; }
.sr-resp-item span:last-child { color: var(--text-tertiary); font-family: var(--font-mono); }
.sr-preview-frame { border: 2px dashed var(--accent); border-radius: var(--radius-md); overflow: hidden; margin: var(--space-3) auto; position: relative; }
.sr-preview-frame iframe { width: 100%; height: 100%; border: 0; }
.sr-preview-label { position: absolute; top: 4px; right: 8px; font-size: var(--font-size-xs); background: var(--accent); color: #fff; padding: 2px 8px; border-radius: var(--radius-full); }
.wb-toolbar { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: var(--space-2); }
.wb-tools { display: flex; gap: var(--space-1); flex-wrap: wrap; }
.wb-options { display: flex; align-items: center; gap: var(--space-2); flex-wrap: wrap; }
.wb-color { width: 32px; height: 32px; border: 2px solid var(--border); border-radius: var(--radius-sm); cursor: pointer; padding: 0; }
.wb-canvas-wrap { margin-top: var(--space-3); border: 2px solid var(--border); border-radius: var(--radius-lg); overflow: hidden; }
.wb-canvas-wrap canvas { display: block; width: 100%; cursor: crosshair; touch-action: none; }
.dw-opt { display: flex; align-items: center; gap: var(--space-2); margin-bottom: var(--space-1); }
.dw-opt__color { width: 12px; height: 12px; border-radius: 50%; flex-shrink: 0; }
.dw-wheel-area { text-align: center; margin: var(--space-4) 0; position: relative; }
.dw-pointer { font-size: 1.5rem; color: var(--accent); margin-bottom: -8px; position: relative; z-index: 1; }
.dw-wheel-area canvas { display: block; margin: 0 auto; }
.dw-spin-btn { margin-top: var(--space-3); }
.dw-result { text-align: center; }
.dw-result__text { font-size: var(--font-size-2xl); padding: var(--space-4); }
.file-drop--active { border-color: var(--accent); background: var(--accent-bg); }
.qr-success { text-align: center; }
.qr-success__label { font-weight: 600; color: var(--success); margin-bottom: var(--space-2); }
.qr-success__data { font-family: var(--font-mono); font-size: var(--font-size-sm); padding: var(--space-3); background: var(--bg-secondary); border-radius: var(--radius-md); word-break: break-all; margin-bottom: var(--space-3); }
.qr-success__actions { display: flex; gap: var(--space-2); justify-content: center; }
.qr-error { text-align: center; padding: var(--space-4); color: var(--text-secondary); }
.mt-grid { display: flex; flex-direction: column; gap: var(--space-1); }
.mt-row { display: grid; grid-template-columns: repeat(var(--mt-cols, 3), 1fr); gap: var(--space-1); }
.mt-cell { text-align: center; font-family: var(--font-mono); font-size: var(--font-size-sm); padding: var(--space-2) !important; }
.mt-result-grid { display: flex; flex-direction: column; gap: var(--space-1); max-width: 400px; margin: 0 auto; }
.mt-res-cell {
text-align: center; font-family: var(--font-mono); font-weight: 600; font-size: var(--font-size-sm);
padding: var(--space-2); background: var(--accent-bg); border-radius: var(--radius-sm); color: var(--accent);
}
.qt-input-row {
display: flex;
gap: var(--space-2);
align-items: stretch;
}
.qt-input-row .input { flex: 1; min-width: 0; }
.qt-input-row__add {
width: 48px; min-width: 48px; height: 48px;
font-size: 22px; font-weight: 700;
border-radius: var(--radius-md);
display: flex; align-items: center; justify-content: center;
padding: 0; background: var(--accent); color: #fff;
border: none; cursor: pointer;
transition: transform var(--transition-fast), background var(--transition-fast);
}
.qt-input-row__add:hover {
background: var(--accent-hover);
transform: scale(1.05);
}
.qt-bulk { margin-top: var(--space-2); }
.qt-bulk summary {
cursor: pointer; color: var(--accent);
font-size: var(--font-size-sm); font-weight: 500;
user-select: none; padding: var(--space-1) 0;
}
.qt-bulk summary:hover { text-decoration: underline; }
.qt-bulk .textarea { margin-top: var(--space-2); font-size: var(--font-size-sm); }
.qt-bulk .btn { margin-top: var(--space-2); }
.qt-chips {
display: flex; flex-wrap: wrap; gap: 8px;
margin-top: var(--space-3); min-height: 20px;
}
.qt-chip {
display: inline-flex; align-items: center; gap: 6px;
padding: 6px 12px;
background: var(--accent-bg); border: 1px solid var(--accent-light);
border-radius: var(--radius-full);
font-size: var(--font-size-sm); font-weight: 500; color: var(--accent-text);
animation: qtChipIn 0.2s ease;
transition: transform var(--transition-fast), box-shadow var(--transition-fast);
}
.qt-chip:hover { transform: translateY(-1px); box-shadow: var(--shadow-sm); }
@keyframes qtChipIn {
from { opacity: 0; transform: scale(0.8); }
to   { opacity: 1; transform: scale(1); }
}
.qt-chip__name {
max-width: 120px; overflow: hidden;
text-overflow: ellipsis; white-space: nowrap;
}
.qt-chip__remove {
display: flex; align-items: center; justify-content: center;
width: 20px; height: 20px; border-radius: 50%;
border: none; background: rgba(139,92,246,0.15);
color: var(--accent); font-size: 14px; font-weight: 700;
cursor: pointer; line-height: 1; padding: 0;
transition: background var(--transition-fast), color var(--transition-fast);
}
.qt-chip__remove:hover { background: var(--error); color: #fff; }
.qt-chip--eliminated {
background: var(--bg-tertiary); border-color: var(--border);
color: var(--text-tertiary); opacity: 0.5; text-decoration: line-through;
}
.qt-item-count {
margin-top: var(--space-2);
font-size: var(--font-size-xs);
color: var(--text-tertiary); font-weight: 500;
}
.qt-params {
display: grid; gap: var(--space-3);
margin-top: var(--space-4); padding: var(--space-4);
background: var(--bg-secondary);
border-radius: var(--radius-lg);
border: 1px solid var(--border-light);
}
.qt-params--cols-2 { grid-template-columns: repeat(2, 1fr); }
.qt-params--cols-3 { grid-template-columns: repeat(3, 1fr); }
.qt-params label {
font-size: var(--font-size-xs); font-weight: 600;
text-transform: uppercase; letter-spacing: 0.5px;
color: var(--text-tertiary);
margin-bottom: var(--space-1); display: block;
}
.qt-params .select, .qt-params .input {
width: 100%; font-size: var(--font-size-sm);
}
@media (max-width: 640px) {
.qt-params--cols-2, .qt-params--cols-3 {
grid-template-columns: 1fr;
gap: var(--space-2); padding: var(--space-3);
}
}
.qt-main-btn {
margin-top: var(--space-5);
width: 100%; max-width: 360px;
font-size: var(--font-size-lg); padding: 14px 24px;
border-radius: var(--radius-xl); font-weight: 700;
transition: transform var(--transition-fast), box-shadow var(--transition-fast);
}
.qt-main-btn:not(:disabled):hover {
transform: scale(1.03);
box-shadow: var(--shadow-accent);
}
.qt-main-btn:disabled { opacity: 0.4; cursor: not-allowed; }
.tool-result { position: relative; overflow: hidden; }
.tool-result--animate { animation: qtSlideIn 0.5s ease; }
@keyframes qtSlideIn {
from { opacity: 0; transform: translateY(20px); }
to   { opacity: 1; transform: translateY(0); }
}
.qt-result-badge {
text-align: center;
font-size: var(--font-size-xl); font-weight: 800;
color: var(--accent); margin-bottom: var(--space-4);
display: flex; align-items: center; justify-content: center;
gap: var(--space-2);
}
.qt-result-badge::before,
.qt-result-badge::after {
content: '✦'; font-size: 14px; color: #F59E0B;
}
.qt-result-meta {
text-align: center; font-size: var(--font-size-sm);
color: var(--text-tertiary); margin-bottom: var(--space-4);
}
.tool-result__actions {
display: flex; gap: var(--space-2);
justify-content: center; flex-wrap: wrap;
}
.tool-result__actions .btn {
min-height: 44px; padding: 10px 20px;
font-size: var(--font-size-sm); border-radius: var(--radius-lg);
}
.qt-winners { display: flex; flex-direction: column; gap: var(--space-3); margin-bottom: var(--space-4); }
.qt-winner {
display: flex; align-items: center; gap: var(--space-3); padding: var(--space-4);
background: linear-gradient(135deg, var(--accent-bg), transparent);
border: 2px solid var(--accent); border-radius: var(--radius-lg);
animation: qtWinnerPop 0.5s cubic-bezier(0.34, 1.56, 0.64, 1) both;
}
.qt-winner:nth-child(2) { animation-delay: 0.15s; }
.qt-winner:nth-child(3) { animation-delay: 0.3s; }
@keyframes qtWinnerPop {
0%   { opacity: 0; transform: scale(0.5) rotate(-5deg); }
60%  { transform: scale(1.05) rotate(1deg); }
100% { opacity: 1; transform: scale(1) rotate(0); }
}
.qt-winner__rank {
flex-shrink: 0; width: 44px; height: 44px;
display: flex; align-items: center; justify-content: center;
border-radius: 50%; font-size: 18px; font-weight: 800; color: #fff;
background: var(--accent); box-shadow: 0 3px 10px rgba(139,92,246,0.35);
}
.qt-winner:nth-child(1) .qt-winner__rank {
background: linear-gradient(135deg, #F59E0B, #D97706);
box-shadow: 0 3px 10px rgba(245,158,11,0.4);
}
.qt-winner:nth-child(2) .qt-winner__rank {
background: linear-gradient(135deg, #9CA3AF, #6B7280);
}
.qt-winner:nth-child(3) .qt-winner__rank {
background: linear-gradient(135deg, #D97706, #92400E);
}
.qt-winner__name { font-size: var(--font-size-xl); font-weight: 700; color: var(--text-primary); }
.qt-persons { display: flex; flex-wrap: wrap; gap: var(--space-3); min-height: 40px; }
.qt-person {
display: flex; align-items: center; gap: var(--space-2);
background: var(--bg-secondary); padding: var(--space-2) var(--space-3);
border-radius: var(--radius-lg); animation: qtChipIn 0.2s ease;
transition: transform var(--transition-fast);
}
.qt-person:hover { transform: translateY(-1px); }
.qt-person__avatar {
width: 36px; height: 36px; border-radius: 50%;
display: flex; align-items: center; justify-content: center;
color: #fff; font-weight: 700; font-size: 15px; flex-shrink: 0;
}
.qt-person__name { font-weight: 500; font-size: var(--font-size-sm); color: var(--text-primary); }
.qt-person__remove {
background: none; border: none; color: var(--text-tertiary);
cursor: pointer; font-size: 18px; padding: 0 4px; margin-left: var(--space-1);
transition: color var(--transition-fast);
}
.qt-person__remove:hover { color: var(--error); }
.qt-teams {
display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
gap: var(--space-4);
}
.qt-team {
background: var(--bg-primary); border-radius: var(--radius-lg);
padding: var(--space-4); box-shadow: var(--shadow-sm);
border-top: 3px solid var(--accent);
animation: qtSlideIn 0.4s ease both;
}
.qt-team:nth-child(2) { animation-delay: 0.1s; }
.qt-team:nth-child(3) { animation-delay: 0.2s; }
.qt-team:nth-child(4) { animation-delay: 0.3s; }
.qt-team__title { font-size: var(--font-size-lg); font-weight: 600; margin-bottom: var(--space-3); }
.qt-team__members { display: flex; flex-wrap: wrap; gap: var(--space-2); }
.qt-countdown {
display: flex; justify-content: center; gap: var(--space-4); padding: var(--space-6) 0;
}
.qt-countdown__unit { text-align: center; }
.qt-countdown__value {
display: block; font-size: var(--font-size-4xl); font-weight: 800;
color: var(--accent); line-height: 1.1; min-width: 72px;
}
.qt-countdown__label {
display: block; font-size: var(--font-size-xs); color: var(--text-tertiary);
text-transform: uppercase; letter-spacing: 1px; margin-top: var(--space-1);
}
@media (max-width: 480px) {
.qt-countdown { gap: var(--space-2); }
.qt-countdown__value { font-size: var(--font-size-3xl); min-width: 56px; }
}
.qt-spotlight { text-align: center; padding: var(--space-8) 0; }
.qt-spotlight__card {
display: inline-flex; flex-direction: column; align-items: center;
padding: var(--space-6); border: 3px solid var(--accent);
border-radius: var(--radius-xl);
animation: qtSpotlight 0.15s ease;
}
@keyframes qtSpotlight {
from { transform: scale(0.9); opacity: 0.7; }
to { transform: scale(1); opacity: 1; }
}
.qt-spotlight__name {
font-size: var(--font-size-2xl); font-weight: 700;
margin-top: var(--space-2); color: var(--text-primary);
}
.qt-poll-option {
display: flex; gap: var(--space-2); margin-bottom: var(--space-2); align-items: center;
}
.qt-poll-option .input { flex: 1; }
.qt-poll-option__remove {
background: none; border: none; color: var(--error);
font-size: 20px; cursor: pointer; padding: 0 var(--space-2); line-height: 1;
transition: opacity var(--transition-fast);
}
.qt-poll-option__remove:hover { opacity: 0.7; }
.qt-poll-success { text-align: center; padding: var(--space-6) 0; }
.qt-poll-success__icon {
width: 56px; height: 56px; border-radius: 50%;
background: var(--success); color: #fff;
display: inline-flex; align-items: center; justify-content: center;
font-size: 28px; margin-bottom: var(--space-3);
}
.qt-poll-success__title {
font-size: var(--font-size-xl); font-weight: 700; color: var(--text-primary);
margin-bottom: var(--space-2);
}
.qt-poll-success__sub { font-size: var(--font-size-sm); color: var(--text-secondary); }
.qt-wheel-wrap { text-align: center; margin: var(--space-6) 0; position: relative; }
.qt-wheel-pointer {
position: relative; z-index: 2; text-align: center;
font-size: 28px; color: var(--accent); line-height: 1; margin-bottom: -10px;
}
.qt-wheel-canvas {
display: block; margin: 0 auto; max-width: 100%;
border-radius: 50%; box-shadow: var(--shadow-lg);
}
.qt-ai-result {
margin-top: var(--space-5); padding: var(--space-5);
background: var(--bg-secondary); border-radius: var(--radius-lg);
border-left: 4px solid var(--accent);
animation: qtSlideIn 0.4s ease;
}
.qt-ai-result__text {
font-size: var(--font-size-base); line-height: 1.7;
color: var(--text-primary); white-space: pre-wrap; word-break: break-word;
}
.qt-ai-result__actions {
display: flex; gap: var(--space-2); margin-top: var(--space-4);
padding-top: var(--space-3); border-top: 1px solid var(--border-light);
}
.qt-ai-loading {
display: flex; align-items: center; gap: var(--space-3);
padding: var(--space-5); color: var(--text-secondary); font-size: var(--font-size-sm);
}
.qt-ai-loading__dots { display: inline-flex; gap: 4px; }
.qt-ai-loading__dots span {
width: 8px; height: 8px; border-radius: 50%;
background: var(--accent); opacity: 0.3;
animation: qtDotPulse 1.2s ease infinite;
}
.qt-ai-loading__dots span:nth-child(2) { animation-delay: 0.2s; }
.qt-ai-loading__dots span:nth-child(3) { animation-delay: 0.4s; }
@keyframes qtDotPulse {
0%, 80%, 100% { opacity: 0.3; transform: scale(0.8); }
40% { opacity: 1; transform: scale(1.2); }
}
.qt-corrections { margin-top: var(--space-4); }
.qt-correction {
display: flex; align-items: center; gap: var(--space-3);
padding: var(--space-2) var(--space-3); background: var(--bg-tertiary);
border-radius: var(--radius-sm); margin-bottom: var(--space-2);
font-size: var(--font-size-sm);
}
.qt-correction__old { color: var(--error); text-decoration: line-through; }
.qt-correction__arrow { color: var(--text-tertiary); }
.qt-correction__new { color: var(--success); font-weight: 600; }
.qt-correction__type {
margin-left: auto; font-size: var(--font-size-xs); color: var(--text-tertiary);
background: var(--bg-secondary); padding: 2px 8px; border-radius: var(--radius-full);
}
.qt-char-counter {
display: block; text-align: right; font-size: var(--font-size-xs);
color: var(--text-tertiary); margin-top: var(--space-1);
}
.qt-confetti {
position: absolute; width: 8px; height: 8px; border-radius: 2px;
top: 0; opacity: 1; pointer-events: none;
animation: qtConfettiFall 1.2s ease-out forwards;
}
@keyframes qtConfettiFall {
0%   { transform: translateY(-20px) rotate(0deg) scale(1); opacity: 1; }
100% { transform: translateY(200px) rotate(720deg) scale(0.3); opacity: 0; }
}
.btn-select {
display: flex;
flex-wrap: wrap;
gap: 6px;
}
.btn-select-label {
display: block;
font-size: 13px;
font-weight: 500;
color: var(--text-primary);
margin-bottom: 6px;
}
.btn-select-opt {
height: 34px;
min-width: 42px;
padding: 0 14px;
border: 0.5px solid var(--border);
border-radius: 8px;
background: var(--bg-secondary);
color: var(--text-primary);
font-size: 13px;
font-weight: 400;
font-family: inherit;
cursor: pointer;
display: inline-flex;
align-items: center;
justify-content: center;
gap: 5px;
transition: all 0.15s ease;
white-space: nowrap;
user-select: none;
-webkit-tap-highlight-color: transparent;
}
.btn-select-opt:hover {
border-color: var(--accent);
background: var(--bg-primary);
}
.btn-select-opt:active {
transform: scale(0.96);
}
.btn-select-opt.active {
background: var(--accent);
color: #fff;
border-color: var(--accent);
font-weight: 500;
box-shadow: 0 1px 4px rgba(124, 58, 237, 0.2);
}
.btn-select-opt.active:hover {
opacity: 0.9;
}
.btn-select--sm .btn-select-opt {
height: 28px;
min-width: 36px;
padding: 0 10px;
font-size: 12px;
border-radius: 6px;
}
.btn-select--lg .btn-select-opt {
height: 40px;
min-width: 54px;
padding: 0 18px;
font-size: 14px;
border-radius: 10px;
}
.btn-select--grid {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(80px, 1fr));
gap: 8px;
}
.btn-select--grid .btn-select-opt {
width: 100%;
}
.btn-select--pill .btn-select-opt {
border-radius: 9999px;
padding: 0 16px;
}
.btn-select-opt svg {
width: 14px;
height: 14px;
opacity: 0.7;
}
.btn-select-opt.active svg {
opacity: 1;
}
.btn-select-opt[data-color] {
position: relative;
padding-left: 28px;
}
.btn-select-opt[data-color]::before {
content: '';
position: absolute;
left: 10px;
top: 50%;
transform: translateY(-50%);
width: 10px;
height: 10px;
border-radius: 50%;
background: attr(data-color);
border: 1px solid rgba(0,0,0,0.1);
}
@media (max-width: 480px) {
.btn-select-opt {
padding: 0 10px;
font-size: 12px;
min-width: 36px;
height: 32px;
}
.btn-select--lg .btn-select-opt {
height: 36px;
font-size: 13px;
}
.btn-select {
gap: 5px;
}
}
@keyframes btnSelectPop {
0% { transform: scale(0.95); opacity: 0.5; }
100% { transform: scale(1); opacity: 1; }
}
.btn-select-opt {
animation: btnSelectPop 0.2s ease-out;
}
.btn-select-opt:focus-visible {
outline: 2px solid var(--accent);
outline-offset: 2px;
}