@import"https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&family=Fraunces:opsz,wght@9..144,400;9..144,500;9..144,600;9..144,700&display=swap";.btn{display:inline-flex;align-items:center;justify-content:center;gap:4px;border:none;cursor:pointer;font-family:Fraunces,serif;border-radius:20px;transition:all var(--transition-normal);white-space:nowrap;-webkit-tap-highlight-color:transparent}.btn:focus{outline:none}.btn:focus-visible{outline:2px solid var(--color-interaction-primary);outline-offset:2px}.btn--lg{height:42px;padding:12px 20px;font-size:14px;line-height:18px;font-weight:400}.btn--md{height:24px;padding:4px 12px;font-size:12px;line-height:16px;font-weight:400}.btn--sm{height:20px;width:20px;padding:4px}.btn--lg.btn--icon-only{height:40px;width:40px;padding:12px}.btn--sm.btn--icon-only{height:20px;width:20px;padding:4px}.btn--filled.btn--primary{background:var(--burgundy-600--light);color:var(--beige-25--light)}.btn--filled.btn--primary:hover{background:var(--burgundy-700--light)}.btn--filled.btn--primary:active,.btn--filled.btn--primary.btn--pressed{background:var(--burgundy-700--light);box-shadow:inset 0 2px 4px #0003}.btn--filled.btn--secondary{background:var(--beige-400--light);color:var(--beige-25--light)}.btn--filled.btn--secondary:hover{background:var(--beige-500--light)}.btn--filled.btn--secondary:active,.btn--filled.btn--secondary.btn--pressed{background:var(--beige-500--light);box-shadow:inset 0 2px 4px #0003}.btn--filled.btn--success{background:var(--sage-500--light);color:var(--beige-25--light)}.btn--filled.btn--success:hover{background:var(--sage-600--light)}.btn--filled.btn--success:active,.btn--filled.btn--success.btn--pressed{background:var(--sage-600--light);box-shadow:inset 0 2px 4px #0003}.btn--filled.btn--warning{background:var(--sand-500--light);color:var(--beige-25--light)}.btn--filled.btn--warning:hover{background:var(--sand-600--light)}.btn--filled.btn--warning:active,.btn--filled.btn--warning.btn--pressed{background:var(--sand-600--light);box-shadow:inset 0 2px 4px #0003}.btn--filled.btn--danger{background:var(--clay-500--light);color:var(--beige-25--light)}.btn--filled.btn--danger:hover{background:var(--clay-600--light)}.btn--filled.btn--danger:active,.btn--filled.btn--danger.btn--pressed{background:var(--clay-600--light);box-shadow:inset 0 2px 4px #0003}.btn--ghost{background:transparent;color:var(--color-text-primary--light);font-family:Outfit,sans-serif;font-weight:600;padding:0}.btn--ghost.btn--lg{font-size:14px;line-height:18px;text-transform:uppercase;height:auto}.btn--ghost.btn--md{font-size:12px;line-height:16px;height:auto}.btn--ghost:hover,.btn--ghost:active,.btn--ghost.btn--pressed{color:var(--burgundy-700--light)}.btn--ghost.btn--secondary{color:var(--beige-400--light)}.btn--ghost.btn--secondary:hover,.btn--ghost.btn--secondary:active,.btn--ghost.btn--secondary.btn--pressed{color:var(--beige-500--light)}.btn--ghost.btn--success{color:var(--sage-500--light)}.btn--ghost.btn--success:hover,.btn--ghost.btn--success:active,.btn--ghost.btn--success.btn--pressed{color:var(--sage-600--light)}.btn--ghost.btn--warning{color:var(--sand-500--light)}.btn--ghost.btn--warning:hover,.btn--ghost.btn--warning:active,.btn--ghost.btn--warning.btn--pressed{color:var(--sand-600--light)}.btn--ghost.btn--danger{color:var(--clay-500--light)}.btn--ghost.btn--danger:hover,.btn--ghost.btn--danger:active,.btn--ghost.btn--danger.btn--pressed{color:var(--clay-600--light)}.btn--borderless{background:transparent;color:var(--color-text-primary--light)}.btn--borderless:hover,.btn--borderless:active,.btn--borderless.btn--pressed{color:var(--burgundy-700--light)}.btn--borderless.btn--secondary{color:var(--beige-400--light)}.btn--borderless.btn--secondary:hover,.btn--borderless.btn--secondary:active,.btn--borderless.btn--secondary.btn--pressed{color:var(--beige-500--light)}.btn--borderless.btn--success{color:var(--sage-500--light)}.btn--borderless.btn--success:hover,.btn--borderless.btn--success:active,.btn--borderless.btn--success.btn--pressed{color:var(--sage-600--light)}.btn--borderless.btn--warning{color:var(--sand-500--light)}.btn--borderless.btn--warning:hover,.btn--borderless.btn--warning:active,.btn--borderless.btn--warning.btn--pressed{color:var(--sand-600--light)}.btn--borderless.btn--danger{color:var(--clay-500--light)}.btn--borderless.btn--danger:hover,.btn--borderless.btn--danger:active,.btn--borderless.btn--danger.btn--pressed{color:var(--clay-600--light)}.btn--disabled,.btn:disabled{opacity:.6;cursor:not-allowed;pointer-events:none}.btn__icon{display:flex;align-items:center;justify-content:center}.btn__icon svg{width:100%;height:100%}.btn--lg .btn__icon{width:16px;height:16px}.btn--md .btn__icon,.btn--sm .btn__icon{width:12px;height:12px}.btn--icon-only .btn__icon{width:100%;height:100%}.btn--lg.btn--icon-only .btn__icon{width:16px;height:16px}.btn--sm.btn--icon-only .btn__icon{width:12px;height:12px}.btn__label{display:inline-block}.landing{min-height:100vh;background:var(--color-bg);color:var(--color-text);overflow-x:hidden}.landing-nav{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-4) var(--spacing-6);max-width:1200px;margin:0 auto}.landing-logo{display:flex;align-items:center;gap:var(--spacing-2)}.landing-logo-icon{font-size:32px}.landing-logo-text{font-family:Fraunces,serif;font-size:var(--font-size-2xl);font-weight:700;color:var(--color-text)}.landing-nav-links{display:flex;align-items:center;gap:var(--spacing-6)}.landing-nav-links a{font-family:Outfit,sans-serif;font-size:var(--font-size-base);color:var(--color-text-secondary);text-decoration:none;transition:color var(--transition-normal)}.landing-nav-links a:hover{color:var(--color-text)}.landing-btn-primary{display:inline-flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-3) var(--spacing-5);background:var(--color-brand);color:var(--color-text-inverse);font-family:Outfit,sans-serif;font-weight:600;font-size:var(--font-size-base);border-radius:var(--radius-full);text-decoration:none;transition:all var(--transition-normal)}.landing-btn-primary:hover{background:var(--burgundy-700);transform:translateY(-2px)}.landing-btn-secondary{display:inline-flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-3) var(--spacing-5);background:var(--color-surface);color:var(--color-text);font-family:Outfit,sans-serif;font-weight:600;font-size:var(--font-size-base);border:1px solid var(--color-border);border-radius:var(--radius-full);text-decoration:none;transition:all var(--transition-normal)}.landing-btn-secondary:hover{background:var(--color-bg-secondary);transform:translateY(-2px)}.landing-btn-large{padding:var(--spacing-4) var(--spacing-8);font-size:var(--font-size-lg)}.landing-header{background:linear-gradient(180deg,var(--color-surface) 0%,var(--color-bg) 100%)}.landing-hero{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-12);align-items:center;max-width:1200px;margin:0 auto;padding:var(--spacing-12) var(--spacing-6)}.landing-title{font-family:Fraunces,serif;font-size:56px;font-weight:700;line-height:1.1;margin-bottom:var(--spacing-6)}.landing-title-accent{color:var(--color-brand)}.landing-subtitle{font-family:Outfit,sans-serif;font-size:var(--font-size-lg);color:var(--color-text-secondary);line-height:1.6;margin-bottom:var(--spacing-8);max-width:500px}.landing-cta{display:flex;flex-direction:column;gap:var(--spacing-3)}.landing-cta-note{font-size:var(--font-size-sm);color:var(--color-text-tertiary)}.landing-hero-visual{display:flex;justify-content:center}.landing-phone-mockup{width:280px;height:560px;background:var(--beige-900);border-radius:40px;padding:12px;box-shadow:var(--shadow-xl)}.landing-phone-screen{width:100%;height:100%;background:var(--color-bg);border-radius:32px;overflow:hidden}.landing-app-preview{padding:var(--spacing-4)}.preview-header{display:flex;align-items:center;gap:var(--spacing-2);font-family:Fraunces,serif;font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--spacing-4);padding:var(--spacing-3)}.preview-card{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-3);background:var(--color-surface);border-radius:var(--radius-lg);margin-bottom:var(--spacing-3);border:1px solid var(--color-border)}.preview-card.active{border-color:var(--color-brand);background:var(--burgundy-25)}.preview-card-icon{font-size:24px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--color-bg-secondary);border-radius:var(--radius-md)}.preview-card-info{flex:1}.preview-card-title{font-family:Outfit,sans-serif;font-weight:600;font-size:var(--font-size-sm)}.preview-card-meta{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.preview-timer{font-size:16px}.landing-features{padding:var(--spacing-16) var(--spacing-6);max-width:1200px;margin:0 auto}.landing-section-title{font-family:Fraunces,serif;font-size:var(--font-size-3xl);font-weight:700;text-align:center;margin-bottom:var(--spacing-12)}.landing-features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-8)}.landing-feature{text-align:center;padding:var(--spacing-6)}.landing-feature-icon{font-size:48px;margin-bottom:var(--spacing-4)}.landing-feature h3{font-family:Outfit,sans-serif;font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--spacing-3)}.landing-feature p{font-size:var(--font-size-base);color:var(--color-text-secondary);line-height:1.6}.landing-crafts{background:var(--color-surface);padding:var(--spacing-12) var(--spacing-6);text-align:center}.landing-crafts-list{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--spacing-4);max-width:800px;margin:0 auto}.landing-craft{padding:var(--spacing-3) var(--spacing-5);background:var(--color-bg);border-radius:var(--radius-full);font-family:Outfit,sans-serif;font-size:var(--font-size-base);border:1px solid var(--color-border)}.landing-pricing{padding:var(--spacing-16) var(--spacing-6);max-width:1200px;margin:0 auto}.landing-pricing-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-6);align-items:start}.landing-pricing-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--spacing-8);text-align:center}.landing-pricing-card.featured{border-color:var(--color-brand);transform:scale(1.05);box-shadow:var(--shadow-lg)}.landing-pricing-badge{display:inline-block;padding:var(--spacing-1) var(--spacing-3);background:var(--color-bg-secondary);border-radius:var(--radius-full);font-family:Outfit,sans-serif;font-size:var(--font-size-sm);font-weight:600;margin-bottom:var(--spacing-4)}.landing-pricing-card.featured .landing-pricing-badge{background:var(--color-brand);color:var(--color-text-inverse)}.landing-pricing-price{font-family:Fraunces,serif;font-size:48px;font-weight:700}.landing-pricing-period{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-6)}.landing-pricing-features{list-style:none;text-align:left;margin-bottom:var(--spacing-6)}.landing-pricing-features li{padding:var(--spacing-2) 0;font-size:var(--font-size-base);color:var(--color-text-secondary)}.landing-pricing-features li strong{color:var(--color-text)}.landing-social{background:linear-gradient(180deg,var(--color-bg) 0%,var(--burgundy-50) 100%);padding:var(--spacing-16) var(--spacing-6);text-align:center}.landing-social-text{font-size:var(--font-size-lg);color:var(--color-text-secondary);max-width:600px;margin:0 auto var(--spacing-10)}.landing-social-stats{display:flex;justify-content:center;gap:var(--spacing-12)}.landing-stat{text-align:center}.landing-stat-value{font-size:48px;margin-bottom:var(--spacing-2)}.landing-stat-label{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.landing-final-cta{background:var(--color-brand);color:var(--color-text-inverse);padding:var(--spacing-16) var(--spacing-6);text-align:center}.landing-final-cta h2{font-family:Fraunces,serif;font-size:var(--font-size-3xl);font-weight:700;margin-bottom:var(--spacing-4);color:var(--color-text-inverse)}.landing-final-cta p{font-size:var(--font-size-lg);opacity:.9;margin-bottom:var(--spacing-8)}.landing-store-buttons{display:flex;justify-content:center;gap:var(--spacing-4)}.landing-store-btn{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-3) var(--spacing-5);background:#ffffff1a;border:1px solid rgba(255,255,255,.3);border-radius:var(--radius-lg);color:var(--color-text-inverse);text-decoration:none;transition:all var(--transition-normal)}.landing-store-btn:hover{background:#fff3;transform:translateY(-2px)}.store-icon{font-size:28px}.store-text{display:flex;flex-direction:column;text-align:left}.store-small{font-size:var(--font-size-xs);opacity:.8}.store-large{font-family:Outfit,sans-serif;font-weight:600;font-size:var(--font-size-base)}.landing-footer{background:var(--beige-900);color:var(--beige-300);padding:var(--spacing-12) var(--spacing-6)}.landing-footer-content{display:flex;justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto var(--spacing-8)}.landing-footer-brand{display:flex;align-items:center;gap:var(--spacing-2)}.landing-footer-brand .landing-logo-text{color:var(--beige-100)}.landing-footer-brand p{margin-left:var(--spacing-4);font-size:var(--font-size-sm)}.landing-footer-links{display:flex;gap:var(--spacing-6)}.landing-footer-links a{color:var(--beige-400);text-decoration:none;font-size:var(--font-size-sm)}.landing-footer-links a:hover{color:var(--beige-200)}.landing-footer-copyright{text-align:center;font-size:var(--font-size-sm);opacity:.6;max-width:1200px;margin:0 auto;padding-top:var(--spacing-6);border-top:1px solid var(--beige-800)}@media (max-width: 968px){.landing-hero{grid-template-columns:1fr;text-align:center;padding:var(--spacing-8) var(--spacing-4)}.landing-hero-content{order:1}.landing-hero-visual{order:2}.landing-subtitle{margin:0 auto var(--spacing-8)}.landing-title{font-size:40px}.landing-features-grid{grid-template-columns:repeat(2,1fr)}.landing-pricing-cards{grid-template-columns:1fr;max-width:400px;margin:0 auto}.landing-pricing-card.featured{transform:none}.landing-nav-links a:not(.landing-btn-primary):not(.landing-btn-secondary){display:none}.landing-footer-content{flex-direction:column;gap:var(--spacing-6);text-align:center}.landing-store-buttons{flex-direction:column}}@media (max-width: 640px){.landing-features-grid{grid-template-columns:1fr}.landing-social-stats{flex-direction:column;gap:var(--spacing-6)}.landing-phone-mockup{width:240px;height:480px}}.sg{min-height:100vh;background:var(--color-bg)}.sg-header{display:flex;align-items:center;gap:var(--spacing-4);padding:var(--spacing-4) var(--spacing-6);background:var(--color-surface);border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:100}.sg-back{padding:var(--spacing-2) var(--spacing-3);background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text--light);font-family:Outfit,sans-serif;font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-normal)}.sg-back:hover{background:var(--color-bg-secondary);color:var(--color-text--light)}.sg-title{flex:1;font-family:Fraunces,serif;font-size:var(--font-size-xl);font-weight:600;color:var(--color-text--light);margin:0}.sg-version{padding:var(--spacing-1) var(--spacing-3);background:var(--color-bg-secondary);border-radius:var(--radius-full);font-family:Outfit,sans-serif;font-size:var(--font-size-xs);color:var(--color-text--light)}.sg-nav{display:flex;gap:var(--spacing-2);padding:var(--spacing-4) var(--spacing-6);background:var(--color-surface);border-bottom:1px solid var(--color-border);overflow-x:auto}.sg-nav-item{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-4);background:transparent;border:1px solid transparent;border-radius:var(--radius-full);font-family:Outfit,sans-serif;font-size:var(--font-size-sm);color:var(--color-text--light);cursor:pointer;transition:all var(--transition-normal);white-space:nowrap}.sg-nav-item:hover{background:var(--color-bg-secondary);color:var(--color-text--light)}.sg-nav-item--active{background:var(--color-brand);color:var(--color-text-inverse);border-color:var(--color-brand)}.sg-nav-item--active:hover{background:var(--burgundy-700);color:var(--color-text-inverse)}.sg-nav-item__icon{font-size:16px}.sg-content{padding:var(--spacing-6);max-width:1000px;margin:0 auto}.sg-section{margin-bottom:var(--spacing-12)}.sg-section__title{font-family:Fraunces,serif;font-size:var(--font-size-2xl);font-weight:600;color:var(--color-text--light);margin:0 0 var(--spacing-2) 0}.sg-section__desc{font-family:Outfit,sans-serif;font-size:var(--font-size-base);color:var(--color-text--light);margin:0 0 var(--spacing-6) 0;max-width:600px}.sg-subsection__title{font-family:Outfit,sans-serif;font-size:var(--font-size-md);font-weight:600;color:var(--color-text--light);margin:var(--spacing-8) 0 var(--spacing-2) 0}.sg-subsection__desc{font-family:Outfit,sans-serif;font-size:var(--font-size-sm);color:var(--color-text--light);margin:0 0 var(--spacing-4) 0}.sg-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-10);background:var(--color-surface);border:2px dashed var(--color-border);border-radius:var(--radius-lg);text-align:center}.sg-placeholder span{font-size:48px;margin-bottom:var(--spacing-3)}.sg-placeholder p{font-family:Outfit,sans-serif;color:var(--color-text--light);margin:0}.sg-color-semantic-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-3)}.sg-color-semantic-grid--2col{grid-template-columns:repeat(2,1fr);max-width:600px}.sg-status-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-4);margin-bottom:var(--spacing-6)}.sg-status-column{display:flex;flex-direction:column;gap:var(--spacing-2)}.sg-status-column__title{font-family:Outfit,sans-serif;font-size:var(--font-size-sm);font-weight:600;color:var(--color-text--light);margin:0 0 var(--spacing-2) 0}.sg-category__title{font-family:Outfit,sans-serif;font-size:var(--font-size-sm);font-weight:600;color:var(--color-text--light);margin:var(--spacing-4) 0 var(--spacing-2) 0;text-transform:uppercase;letter-spacing:.5px}.sg-palette__title{font-family:Outfit,sans-serif;font-size:var(--font-size-sm);font-weight:600;color:var(--color-text--light);margin:var(--spacing-4) 0 var(--spacing-1) 0}.sg-palette__desc{font-family:Outfit,sans-serif;font-size:var(--font-size-xs);color:var(--color-text--light);display:block;margin-bottom:var(--spacing-2)}.sg-color-semantic{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-3);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg)}.sg-color-semantic__swatch{width:48px;height:48px;border-radius:var(--radius-md);border:1px solid var(--color-border);flex-shrink:0}.sg-color-semantic__info{display:flex;flex-direction:column;gap:2px}.sg-color-semantic__name{font-family:Outfit,sans-serif;font-weight:600;font-size:var(--font-size-sm);color:var(--color-text--light)}.sg-color-semantic__var{font-family:monospace;font-size:var(--font-size-xs);color:var(--color-brand);background:var(--burgundy-50);padding:2px 6px;border-radius:4px;width:fit-content}.sg-color-semantic__usage,.sg-color-semantic__ref{font-family:Outfit,sans-serif;font-size:var(--font-size-xs);color:var(--color-text--light)}.sg-palette{margin-top:var(--spacing-8)}.sg-color-grid{display:flex;flex-wrap:wrap;gap:var(--spacing-2)}.sg-color{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-1)}.sg-color__swatch{width:60px;height:60px;border-radius:var(--radius-md);border:1px solid var(--color-border)}.sg-color__name{font-family:Outfit,sans-serif;font-size:var(--font-size-xs);color:var(--color-text--light)}.sg-color__var{font-family:monospace;font-size:9px;color:var(--color-text--light)}.sg-type-families{display:flex;gap:var(--spacing-6);margin-bottom:var(--spacing-6)}.sg-type-family{display:flex;flex-direction:column;gap:var(--spacing-1)}.sg-type-family__sample{font-size:32px;color:var(--color-text--light)}.sg-type-family__usage{font-family:Outfit,sans-serif;font-size:var(--font-size-sm);color:var(--color-text--light)}.sg-type-styles{display:flex;flex-direction:column;gap:var(--spacing-4)}.sg-type-style{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-4);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg)}.sg-type-style__sample{color:var(--color-text--light)}.sg-type-style code{font-family:monospace;font-size:var(--font-size-xs);color:var(--color-text--light);background:var(--color-bg-secondary);padding:var(--spacing-1) var(--spacing-2);border-radius:4px}.sg-spacing-grid{display:flex;flex-direction:column;gap:var(--spacing-4)}.sg-spacing{display:flex;align-items:center;gap:var(--spacing-4);padding:var(--spacing-3);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg)}.sg-spacing__visual{background:var(--color-brand);border-radius:2px;flex-shrink:0}.sg-spacing__info{display:flex;align-items:center;gap:var(--spacing-4)}.sg-spacing__name{font-family:Outfit,sans-serif;font-weight:600;font-size:var(--font-size-sm);color:var(--color-text--light);min-width:40px}.sg-spacing__value{font-family:Outfit,sans-serif;font-size:var(--font-size-sm);color:var(--color-text--light);min-width:50px}.sg-spacing__var{font-family:monospace;font-size:var(--font-size-xs);color:var(--color-brand);background:var(--burgundy-50);padding:2px 6px;border-radius:4px}.sg-radius-grid{display:flex;flex-wrap:wrap;gap:var(--spacing-4)}.sg-radius{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-2)}.sg-radius__visual{width:80px;height:80px;background:var(--color-surface);border:2px solid var(--color-brand)}.sg-radius__info{display:flex;flex-direction:column;align-items:center;gap:2px}.sg-radius__name{font-family:Outfit,sans-serif;font-weight:600;font-size:var(--font-size-sm);color:var(--color-text--light)}.sg-radius__value{font-family:monospace;font-size:var(--font-size-xs);color:var(--color-text--light)}.sg-playground{display:flex;flex-direction:column;gap:var(--spacing-6);margin-bottom:var(--spacing-8)}.sg-playground__controls{display:flex;flex-direction:column;gap:var(--spacing-4);padding:var(--spacing-5);background:var(--color-surface--light);border:1px solid var(--color-border--light);border-radius:20px}.sg-control{display:flex;flex-direction:column;gap:var(--spacing-2)}.sg-control__label{font-family:Outfit,sans-serif;font-size:var(--font-size-sm);font-weight:600;color:var(--color-text--light);text-transform:uppercase}.sg-control__options{display:flex;flex-wrap:wrap;gap:var(--spacing-2)}.sg-control__btn{padding:var(--spacing-2) var(--spacing-3);background:var(--color-bg-secondary--light);border:1px solid var(--color-border--light);border-radius:20px;font-family:Outfit,sans-serif;font-size:var(--font-size-sm);color:var(--color-text--light);cursor:pointer;transition:all var(--transition-normal)}.sg-control__btn:hover{background:var(--color-surface--light);border-color:var(--color-text--light)}.sg-control__btn--active{background:var(--color-interaction-primary--light);border-color:var(--color-interaction-primary--light);color:var(--color-text-inverse--light)}.sg-control__btn--active:hover{background:var(--color-interaction-primary-contrast--light);border-color:var(--color-interaction-primary-contrast--light)}.sg-playground__preview{display:flex;flex-direction:column;gap:var(--spacing-4)}.sg-playground__preview-area{display:flex;align-items:center;justify-content:center;min-height:120px;padding:var(--spacing-6);background:var(--color-surface--light);border:1px solid var(--color-border--light);border-radius:20px}.sg-playground__code{padding:var(--spacing-4);background:var(--beige-800--light);border-radius:20px;overflow-x:auto}.sg-playground__code code{font-family:SF Mono,Monaco,Menlo,monospace;font-size:var(--font-size-sm);color:var(--beige-100--light);white-space:pre;line-height:1.5}.sg-specs-table{overflow-x:auto;margin-bottom:var(--spacing-6)}.sg-specs-table table{width:100%;border-collapse:collapse;font-family:Outfit,sans-serif;font-size:var(--font-size-sm)}.sg-specs-table th,.sg-specs-table td{padding:var(--spacing-3) var(--spacing-4);text-align:left;border-bottom:1px solid var(--color-border--light)}.sg-specs-table th{font-weight:600;color:var(--color-text--light);background:var(--color-surface--light)}.sg-specs-table td{color:var(--color-text--light)}.sg-specs-table tr:last-child td{border-bottom:none}.sg-variant__desc{font-family:Outfit,sans-serif;font-size:var(--font-size-sm);color:var(--color-text--light);margin:0 0 var(--spacing-4) 0}.sg-component-preview{display:flex;align-items:center;justify-content:center;padding:var(--spacing-6);background:var(--color-bg-app--light);border:1px solid var(--color-border--light);border-radius:20px;margin-bottom:var(--spacing-4)}.sg-code-block{padding:var(--spacing-4);background:var(--beige-800--light);border-radius:20px;overflow-x:auto;margin-bottom:var(--spacing-8)}.sg-code-block code{font-family:SF Mono,Monaco,Menlo,monospace;font-size:var(--font-size-sm);color:var(--beige-100--light);white-space:pre;line-height:1.5}.sg-empty-state{display:flex;flex-direction:column;align-items:center;width:100%;max-width:370px}.sg-empty-state--section-cta{background:var(--color-surface-elevated--light);border:1px dashed var(--color-border--light);border-radius:20px;padding:20px 12px;gap:13px}.sg-empty-state__description{font-family:Outfit,sans-serif;font-size:12px;line-height:16px;color:var(--color-text-secondary--light);text-align:center}.sg-empty-state--minimal{padding:20px 12px;gap:13px}.sg-empty-state__text{font-family:Outfit,sans-serif;font-size:12px;line-height:16px;color:var(--color-text-secondary--light);text-align:center}.sg-empty-state--full{padding:20px 12px;gap:20px}.sg-empty-state__contents{display:flex;flex-direction:column;align-items:center;gap:4px}.sg-empty-state__title{font-family:Fraunces,serif;font-size:24px;font-weight:600;color:var(--color-text--light);margin:0;text-align:center}.sg-empty-state__subtitle{font-family:Outfit,sans-serif;font-size:14px;line-height:18px;color:var(--color-text-secondary--light);margin:0;text-align:center}.sg-empty-state__footer{font-family:Outfit,sans-serif;font-size:12px;line-height:16px;color:var(--color-text-secondary--light);text-align:center}:root{--beige-25--light: #fdfcfa;--beige-50--light: #faf8f5;--beige-100--light: #f5f0e8;--beige-200--light: #e8e0d4;--beige-300--light: #d9cfc0;--beige-400--light: #c4b8a6;--beige-500--light: #a89a86;--beige-600--light: #8a7c68;--beige-700--light: #6b5f4d;--beige-800--light: #4d4437;--beige-900--light: #2e2922;--burgundy-25--light: #fdf5f7;--burgundy-50--light: #fae8ec;--burgundy-100--light: #f5d0d8;--burgundy-200--light: #e8a0b2;--burgundy-300--light: #d87a92;--burgundy-400--light: #c45d77;--burgundy-500--light: #a63d56;--burgundy-600--light: #8b2942;--burgundy-700--light: #6b1d32;--burgundy-800--light: #4d1524;--burgundy-900--light: #3d2229;--sage-25--light: #f5faf7;--sage-50--light: #e8f4ed;--sage-100--light: #d0e6da;--sage-200--light: #a8d1b8;--sage-300--light: #7ab896;--sage-400--light: #4d9e74;--sage-500--light: #2d6a4f;--sage-600--light: #255842;--sage-700--light: #1d4534;--sage-800--light: #153327;--sage-900--light: #0d211a;--sand-25--light: #fdfaf6;--sand-50--light: #f9f1e8;--sand-100--light: #f2e2d1;--sand-200--light: #e6cdb3;--sand-300--light: #d9b896;--sand-400--light: #c4956a;--sand-500--light: #a87d55;--sand-600--light: #8c6644;--sand-700--light: #6f5036;--sand-800--light: #523b28;--sand-900--light: #35261a;--clay-25--light: #fdf5f5;--clay-50--light: #f9e5e5;--clay-100--light: #f0c8c8;--clay-200--light: #e09a9a;--clay-300--light: #c96b6b;--clay-400--light: #b24545;--clay-500--light: #9b2c2c;--clay-600--light: #7f2424;--clay-700--light: #631c1c;--clay-800--light: #481515;--clay-900--light: #2d0e0e;--color-success-soft--light: var(--sage-50--light);--color-success-strong--light: var(--sage-500--light);--color-warning-soft--light: var(--sand-50--light);--color-warning-strong--light: var(--sand-500--light);--color-error-soft--light: var(--clay-50--light);--color-error-strong--light: var(--clay-500--light);--color-brand--light: var(--burgundy-600--light);--color-brand-secondary--light: var(--burgundy-500--light);--color-interaction-primary--light: var(--burgundy-600--light);--color-interaction-primary-contrast--light: var(--burgundy-700--light);--color-interaction-secondary--light: var(--burgundy-500--light);--color-text--light: var(--beige-600--light);--color-text-secondary--light: var(--beige-400--light);--color-text-disabled--light: var(--beige-300--light);--color-text-inverse--light: var(--beige-25--light);--color-text-primary--light: var(--burgundy-600--light);--color-border--light: var(--beige-200--light);--color-bg-app--light: var(--beige-100--light);--color-surface--light: var(--beige-50--light);--color-surface-elevated--light: var(--beige-25--light);--color-bg-secondary--light: var(--beige-200--light);--form-border-focus--light: var(--burgundy-600--light);--form-bg--light: var(--beige-50--light);--form-bg-disabled--light: var(--beige-100--light);--color-brand: var(--color-brand--light);--color-brand-secondary: var(--color-brand-secondary--light);--color-interaction-primary: var(--color-interaction-primary--light);--color-interaction-primary-contrast: var(--color-interaction-primary-contrast--light);--color-interaction-secondary: var(--color-interaction-secondary--light);--color-text: var(--color-text--light);--color-text-secondary: var(--color-text-secondary--light);--color-text-disabled: var(--color-text-disabled--light);--color-text-inverse: var(--color-text-inverse--light);--color-text-primary: var(--color-text-primary--light);--color-border: var(--color-border--light);--color-bg: var(--color-bg-app--light);--color-bg-app: var(--color-bg-app--light);--color-surface: var(--color-surface--light);--color-surface-elevated: var(--color-surface-elevated--light);--color-bg-secondary: var(--color-bg-secondary--light);--form-border-focus: var(--form-border-focus--light);--form-bg: var(--form-bg--light);--form-bg-disabled: var(--form-bg-disabled--light);--color-success-soft: var(--color-success-soft--light);--color-success-strong: var(--color-success-strong--light);--color-warning-soft: var(--color-warning-soft--light);--color-warning-strong: var(--color-warning-strong--light);--color-error-soft: var(--color-error-soft--light);--color-error-strong: var(--color-error-strong--light);--font-family: "Outfit", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-display: "Fraunces", Georgia, serif;--font-size-xs: .65rem;--font-size-sm: .75rem;--font-size-base: .875rem;--font-size-md: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 2rem;--font-size-4xl: 2.5rem;--font-size-5xl: 3rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.2;--line-height-normal: 1.5;--line-height-relaxed: 1.65;--letter-spacing-tight: -.02em;--letter-spacing-normal: 0;--letter-spacing-wide: .03em;--spacing-0: 0;--spacing-1: 2px;--spacing-2: 4px;--spacing-3: 8px;--spacing-4: 12px;--spacing-5: 16px;--spacing-6: 20px;--spacing-7: 24px;--spacing-8: 28px;--spacing-10: 40px;--spacing-12: 48px;--spacing-16: 64px;--spacing-xs: 2px;--spacing-sm: 4px;--spacing-md: 12px;--spacing-lg: 20px;--spacing-xl: 28px;--spacing-2xl: 40px;--radius: 20px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .07);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px rgba(0, 0, 0, .15);--transition-fast: .1s ease;--transition-normal: .15s ease;--transition-slow: .3s ease;--z-base: 0;--z-dropdown: 100;--z-sticky: 200;--z-fixed: 300;--z-modal-backdrop: 400;--z-modal: 500;--z-popover: 600;--z-tooltip: 700;--color-primary: var(--color-brand);--color-secondary: var(--color-brand-secondary);--color-accent: var(--color-brand);--color-success: var(--color-success-strong);--color-warning: var(--color-warning-strong);--color-error: var(--color-error-strong);--color-text-muted: var(--color-text-secondary);--color-text-tertiary: var(--color-text-secondary);--color-card: var(--color-surface);--color-card-bg: var(--color-surface);--color-card-border: var(--color-border);--color-bg-warm: var(--color-bg-secondary);--color-border-strong: var(--beige-300--light);--color-form-border: var(--color-border);--color-form-border-hover: var(--beige-300--light);--color-form-border-focus: var(--form-border-focus);--color-form-border-disabled: var(--color-border);--color-form-bg: var(--form-bg);--color-form-bg-focus: var(--form-bg);--color-form-bg-filled: var(--form-bg);--color-form-bg-disabled: var(--form-bg-disabled);--color-form-text: var(--color-text);--color-form-text-placeholder: var(--color-text-secondary);--color-form-text-disabled: var(--color-text-disabled);--radius-sm: 20px;--radius-md: 20px;--radius-lg: 20px;--radius-xl: 20px;--radius-none: 0}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%}html,body,#root{height:100%;width:100%}body{font-family:var(--font-family);font-size:var(--font-size-base);font-weight:var(--font-weight-normal);line-height:var(--line-height-normal);color:var(--color-text);background:var(--color-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent}input,textarea,[contenteditable]{-webkit-user-select:text;-moz-user-select:text;user-select:text}h1,h2,h3,h4,h5,h6{font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight);letter-spacing:var(--letter-spacing-tight);color:var(--color-text)}p{margin-bottom:var(--spacing-4)}p:last-child{margin-bottom:0}a{color:var(--color-brand);text-decoration:none}a:hover{text-decoration:underline}button{font-family:inherit;font-size:inherit;cursor:pointer;border:none;background:none}input,textarea,select{font-family:inherit;font-size:inherit}img,svg{display:block;max-width:100%}ul,ol{list-style:none}table{border-collapse:collapse;border-spacing:0}::selection{background:#8b29424d;color:var(--color-text)}::-webkit-scrollbar{display:none}*{-ms-overflow-style:none;scrollbar-width:none}#root{position:relative;z-index:var(--z-base)}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 30% 20%,rgba(139,41,66,.03) 0%,transparent 50%),radial-gradient(ellipse at 70% 80%,rgba(196,149,106,.05) 0%,transparent 50%);pointer-events:none;z-index:-1}.layout{display:flex;flex-direction:column;align-items:center;padding:var(--spacing-md);padding-top:calc(env(safe-area-inset-top,0px) + var(--spacing-md))}.layout__container{width:100%;max-width:600px}.auth-screen{display:flex;flex-direction:column;gap:var(--spacing-xl)}.auth-screen__title{font-size:var(--text-4xl);text-align:center;color:var(--color-text);margin-bottom:var(--spacing-xs)}.auth-screen__subtitle{text-align:center;color:var(--color-text-muted);font-size:var(--text-md)}.setup-screen{display:flex;flex-direction:column;gap:var(--spacing-xl)}.setup-screen__title{font-size:var(--text-4xl);text-align:center;color:var(--color-text);margin-bottom:var(--spacing-xs)}.setup-screen__subtitle{text-align:center;color:var(--color-text-muted);font-size:var(--text-md)}.project-list-screen{display:flex;flex-direction:column;gap:var(--spacing-md)}.page-header{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.page-header__actions{display:flex;align-items:center;gap:var(--spacing-sm);justify-content:flex-end}.page-header__title{font-size:var(--text-2xl);color:var(--color-text);margin:0;flex:1;min-width:0;line-height:1.3;word-wrap:break-word}.page-header__actions{display:flex;align-items:center;gap:var(--spacing-sm);flex-shrink:0;margin-left:auto}.page-header__actions .button{height:28px;padding:0 12px;font-size:var(--text-sm)}.page-header__account{display:flex;align-items:center;gap:4px;height:28px;padding:0 10px;background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--color-text);cursor:pointer;transition:background .15s ease}.page-header__account:hover{background:#8b451314}.page-header__handle{font-weight:var(--font-medium);max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.name-prompt{background:var(--color-surface);border:1px solid rgba(139,69,19,.2);border-radius:var(--radius-md);padding:1rem;margin-bottom:1rem}.name-prompt__text{margin:0 0 .75rem;font-size:var(--text-base);color:var(--color-text)}.name-prompt__row{display:flex;gap:.5rem}.name-prompt__input{flex:1;padding:.5rem .75rem;border:1px solid rgba(139,69,19,.2);border-radius:var(--radius-sm);background:var(--color-surface);font-size:var(--text-base);color:var(--color-text);outline:none}.name-prompt__input:focus{border-color:var(--color-primary)}.empty-state__hint{font-size:var(--text-base);color:var(--color-text-muted);margin:0}.empty-state{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-lg);padding:var(--spacing-2xl) var(--spacing-lg)}.empty-state__text{color:var(--color-text-muted);font-size:var(--text-lg)}.new-project-subtle{width:100%;padding:.75rem 1rem;background:var(--color-primary);border:none;border-radius:var(--radius-lg);color:#fff;font-size:var(--text-base);font-weight:var(--font-semibold);cursor:pointer;transition:all .2s ease;margin-bottom:var(--spacing-sm)}.new-project-subtle:hover{opacity:.9;transform:translateY(-1px)}.project-list-compact{display:flex;flex-direction:column;gap:.5rem}.project-row{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.875rem 1rem;background:var(--color-card);border:1px solid var(--color-card-border);border-radius:var(--radius-lg);cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.project-row:hover{border-color:var(--color-primary)}.project-row--active{background:#fbbf2426;border-color:var(--color-warning)}.project-row--finished{opacity:.6;background:#1e293bb3}.project-row--finished:hover{opacity:.8}.project-row__main{flex:1;min-width:0;display:flex;flex-direction:column;gap:.125rem}.project-row__name{font-weight:var(--font-semibold);font-size:var(--text-base);color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-row__yarn{font-size:var(--text-sm);color:var(--color-text-muted)}.project-row__notes{font-size:var(--text-sm);color:var(--color-text-light);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.project-row__meta{font-size:var(--text-sm);color:var(--color-text-muted)}.project-row__right{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.project-row__time{font-size:var(--text-sm);font-variant-numeric:tabular-nums;color:var(--color-text-muted);padding:.25rem .5rem;background:var(--color-surface);border-radius:var(--radius-sm)}.project-row__time--running{background:#fbbf2433;color:var(--color-warning);font-weight:var(--font-semibold)}.project-row__finish{padding:.25rem .5rem;background:var(--color-border);border:none;color:var(--color-text-muted);cursor:pointer;font-size:var(--text-base);border-radius:var(--radius-sm);transition:all .15s ease}.project-row__finish:hover{background:#10b9814d;color:#34d399}.project-row__finish--done{color:var(--color-success)}.project-row__finish--done:hover{background:#fbbf2433;color:var(--color-warning)}.project-row__delete{padding:.25rem .5rem;background:var(--color-border);border:none;color:var(--color-text-muted);cursor:pointer;font-size:var(--text-base);border-radius:var(--radius-sm);transition:all .15s ease}.project-row__delete:hover{background:#ef444433;color:#f87171}.project-list-divider{display:flex;align-items:center;gap:.75rem;margin:1rem 0 .5rem;color:var(--color-text-muted);font-size:var(--text-sm);text-transform:uppercase;letter-spacing:.05em}.project-list-divider:before,.project-list-divider:after{content:"";flex:1;height:1px;background:var(--color-border)}.project-list-divider span{padding:0 .5rem}.project-card-simple{display:flex;align-items:stretch;background:var(--color-surface);border:1px solid rgba(139,69,19,.15);border-radius:var(--radius-md);transition:all .15s ease}.project-card-simple:hover{border-color:#8b45134d}.project-card-simple--selected{background:var(--color-surface);border-color:var(--color-primary)}.project-card-simple__checkbox{display:flex;align-items:center;justify-content:center;background:none;border:none;font-size:var(--text-lg);color:#8b451340;cursor:pointer;padding:0 0 0 12px;min-height:100%;transition:color .15s ease}.project-card-simple__checkbox:hover{color:#8b451380}.project-card-simple--selected .project-card-simple__checkbox{color:var(--color-primary)}.project-card-simple__content{flex:1;display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem .875rem .5rem;cursor:pointer;min-width:0}.project-card-simple__icon{font-size:var(--text-xl);flex-shrink:0}.project-card-simple__info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.project-card-simple__name{font-weight:var(--font-semibold);font-size:var(--text-base);color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-card-simple__meta{font-size:var(--text-sm);color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-card-simple__header{display:flex;align-items:center;gap:8px}.project-card-simple__start{padding:2px 8px;font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--color-primary);background:var(--color-surface);border:none;border-radius:4px;cursor:pointer;transition:background .15s ease;flex-shrink:0}.project-card-simple__start:hover,.project-card-simple__start:active{background:var(--color-border-strong)}.project-card-simple__right{display:flex;flex-direction:column;align-items:flex-end;gap:2px;flex-shrink:0}.project-card-simple__time{font-size:var(--text-sm);color:var(--color-text-secondary)}.project-card-simple__deadline{font-size:var(--text-xs);color:var(--color-text-secondary)}.project-card-simple__deadline--urgent{color:var(--color-primary);font-weight:var(--font-medium)}.project-card{display:flex;flex-direction:row;align-items:center;background:var(--color-surface);border:1px solid rgba(139,69,19,.15);border-radius:8px;padding:8px 10px}.project-card:hover{border-color:#8b45134d}.project-card--selected{background:var(--color-surface);border-color:var(--color-primary)}.project-card__checkbox{background:none;border:none;color:#8b451340;cursor:pointer;padding:0;margin-right:8px;flex-shrink:0}.project-card__checkbox:hover{color:#8b451380}.project-card--selected .project-card__checkbox{color:var(--color-primary)}.project-card__content{flex:1;display:flex;align-items:center;gap:8px;cursor:pointer;min-width:0}.project-card__icon{font-size:var(--text-xl);flex-shrink:0}.project-card__info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.project-card__header{display:flex;align-items:center;gap:8px}.project-card__name{font-weight:var(--font-semibold);font-size:var(--text-base);color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-card__start{padding:2px 8px;font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--color-primary);background:var(--color-surface);border:none;border-radius:4px;cursor:pointer;transition:background .15s ease;flex-shrink:0}.project-card__start:hover{background:var(--color-border-strong)}.project-card__meta{font-size:var(--text-sm);color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-card__label{color:var(--color-text-tertiary)}.project-card__value{color:var(--color-text);font-weight:var(--font-medium)}.project-card__right{display:flex;flex-direction:column;align-items:flex-end;gap:2px;flex-shrink:0}.project-card__time{font-size:var(--text-sm);color:var(--color-text-secondary)}.project-card__deadline{font-size:var(--text-xs);color:var(--color-text-secondary)}.project-card__deadline--urgent{color:var(--color-primary);font-weight:var(--font-medium)}.project-card__arrow{color:var(--color-text-tertiary);flex-shrink:0;margin-right:.5rem}.project-list-select-all{margin-bottom:.5rem}.select-all-btn{background:none;border:none;font-size:var(--text-sm);color:var(--color-text-muted);cursor:pointer;padding:.25rem 0;transition:color .15s ease}.select-all-btn:hover{color:var(--color-text)}.bulk-action-bar{display:flex;align-items:center;gap:.5rem;padding:.625rem .75rem;background:#8b451326;border:1px solid rgba(139,69,19,.3);border-radius:var(--radius-md);margin-bottom:.75rem}.bulk-action-bar__cancel{background:none;border:none;color:var(--color-text);font-size:var(--text-md);cursor:pointer;padding:.25rem}.bulk-action-bar__count{flex:1;font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text)}.bulk-action-bar__actions{display:flex;gap:.375rem}.bulk-action-btn{background:var(--color-border);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:.375rem .625rem;font-size:var(--text-sm);color:var(--color-text);cursor:pointer;transition:all .15s ease}.bulk-action-btn:hover{background:var(--color-border)}.bulk-action-btn--danger{color:#f87171}.bulk-action-btn--danger:hover{background:#ef444433}.bulk-actions-toolbar{display:flex;align-items:center;gap:.4rem;padding:.3rem .5rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm)}.bulk-actions-toolbar__count{font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--color-text);white-space:nowrap;padding-right:.4rem;border-right:1px solid var(--color-border)}.bulk-actions-toolbar__link{background:none;border:none;padding:.2rem .3rem;font-size:var(--text-xs);color:var(--color-primary);cursor:pointer;white-space:nowrap}.bulk-actions-toolbar__divider{width:1px;height:.75rem;background:var(--color-border);flex-shrink:0}.bulk-action-btn{display:flex;align-items:center;gap:.2rem;padding:.2rem .4rem;background:none;border:none;border-radius:var(--radius-sm);font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--color-text-secondary);cursor:pointer;white-space:nowrap}.bulk-action-btn:hover{color:var(--color-primary)}.bulk-action-btn--danger{color:var(--color-error)}.project-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.project-list__loading,.project-list__empty{text-align:center;color:var(--color-text-muted);padding:var(--spacing-md)}.project-list__create{width:100%}.counter-screen{display:flex;flex-direction:column;gap:var(--spacing-xl)}.counter-screen__header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-md);flex-wrap:wrap}.counter-screen__title{font-size:var(--text-2xl);color:var(--color-text);margin-bottom:var(--spacing-xs)}.counter-screen__subtitle{font-size:var(--text-base);color:var(--color-text-muted)}.counter-screen__back{white-space:nowrap}.create-project-screen{display:flex;flex-direction:column;gap:var(--spacing-lg)}.create-project-screen__header{display:flex;align-items:center;gap:var(--spacing-sm)}.create-project-screen__title{flex-grow:1}.create-project-screen__submit{flex-shrink:0;margin-left:auto}.create-project-screen__back{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:transparent;color:var(--color-text);cursor:pointer;border-radius:var(--radius-md);transition:background .15s;flex-shrink:0}.create-project-screen__back:hover{background:#0000000d}.create-project-screen__title{font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--color-text);margin:0}.project-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.project-detail-screen{display:flex;flex-direction:column;gap:var(--spacing-md)}.project-detail-screen__header{display:flex;align-items:flex-start;gap:var(--spacing-sm)}.project-detail-screen__back{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:transparent;color:var(--color-text);cursor:pointer;border-radius:var(--radius-md);transition:background .15s;flex-shrink:0;margin-top:2px}.project-detail-screen__back:hover{background:#0000000d}.project-detail-screen__actions{position:relative;flex-shrink:0}.project-detail-screen__menu-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:transparent;color:var(--color-text);cursor:pointer;border-radius:var(--radius-md);transition:background .15s}.project-detail-screen__menu-btn:hover{background:#0000000d}.project-actions-dropdown{position:absolute;top:100%;right:0;margin-top:4px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:0 4px 20px #0000001f;min-width:180px;z-index:1000;padding:.25rem}.project-actions-dropdown button{display:flex;align-items:center;gap:10px;width:100%;padding:.6rem .75rem;border:none;background:none;border-radius:var(--radius-sm);font-size:var(--text-sm);color:var(--color-text);cursor:pointer;text-align:left;transition:background .15s}.project-actions-dropdown button:hover{background:var(--color-surface)}.project-actions-dropdown button svg{flex-shrink:0;color:var(--color-text-secondary)}.project-detail-screen__shared-badge{display:inline-flex;align-items:center;padding:2px 8px;background:#2d6a4f1a;color:var(--color-success);font-size:var(--text-sm);font-weight:var(--font-medium);border-radius:99px;white-space:nowrap}.project-detail-screen__header-info{flex:1;min-width:0;overflow:hidden}.project-detail-screen__title-row{display:flex;align-items:center;gap:8px}.project-detail-screen__title{font-size:var(--text-2xl);color:var(--color-text);margin:0;display:flex;align-items:center;flex-wrap:wrap}.project-detail-screen__recipient{font-weight:var(--font-normal);color:var(--color-text-secondary);margin-left:.35em}.project-detail-screen__meta{font-size:var(--text-sm);color:var(--color-text-muted);margin:.25rem 0 0}.project-detail-screen__meta .meta-label{color:var(--color-text-tertiary)}.project-detail-screen__meta .meta-value{color:var(--color-text);font-weight:var(--font-medium)}.project-detail-screen__meta .meta-value--deadline{color:var(--color-primary)}.project-detail-screen__yarn{font-size:var(--text-sm);color:var(--color-text-muted)}.project-notes-compact{display:flex;flex-direction:column;gap:.25rem}.project-links-compact{display:flex;flex-direction:column;gap:.5rem}.project-info__link{color:var(--color-accent);text-decoration:none;transition:color .15s ease}.project-info__link:hover{color:var(--color-accent-light);text-decoration:underline}.counters-section-compact{display:flex;flex-direction:column;gap:var(--spacing-sm)}.counters-list-compact{display:flex;flex-direction:column;gap:.5rem}.counter-row{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;background:var(--color-card);border:1px solid var(--color-card-border);border-radius:var(--radius-lg);transition:all .2s cubic-bezier(.4,0,.2,1);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.counter-row:hover:not(.counter-row--completed){border-color:var(--color-primary)}.counter-row--active{border-color:var(--color-primary)}.counter-row--completed{opacity:.5}.counter-row__icon{font-size:var(--text-xl);width:1.5rem;text-align:center}.counter-row__info{flex:1;font-size:var(--text-base);color:var(--color-text)}.counter-row__badge{color:var(--color-success);font-weight:var(--font-semibold)}.counter-row__action{color:var(--color-primary);font-size:var(--text-base)}.counter-row__delete{padding:.375rem .625rem;background:var(--color-border);border:none;color:var(--color-text-muted);cursor:pointer;font-size:var(--text-base);border-radius:var(--radius-sm);transition:all .15s ease;flex-shrink:0}.counter-row__delete:hover{background:#ef44444d;color:#f87171}.project-info{display:flex;flex-direction:column;gap:var(--spacing-md)}.project-info__section{display:flex;flex-direction:column;gap:var(--spacing-xs)}.project-info__label{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text);text-transform:uppercase;letter-spacing:.05em}.project-info__text{color:var(--color-text-muted);line-height:1.6}.counters-section{display:flex;flex-direction:column;gap:var(--spacing-md)}.counters-section__title{font-size:var(--text-md);font-weight:var(--font-semibold);color:var(--color-text)}.counters-section__empty{text-align:center;color:var(--color-text-muted);padding:var(--spacing-md)}.counters-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.counters-section__add{width:100%}.create-counter-screen{display:flex;flex-direction:column;gap:var(--spacing-xl)}.create-counter-screen__title{font-size:var(--text-2xl);color:var(--color-text);margin:0}.create-counter-screen__subtitle{text-align:center;color:var(--color-text-muted);font-size:var(--text-md)}.counter-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.counter-screen-new{display:flex;flex-direction:column;gap:var(--spacing-md);height:100%}.counter-screen-new__header{display:flex;align-items:center;gap:var(--spacing-sm)}.counter-screen-new__title{font-size:var(--text-2xl);color:var(--color-text);margin:0}.counter-screen-new__subtitle{font-size:var(--text-base);color:var(--color-text-muted)}.counter-screen-new__back{white-space:nowrap}.counter-card-main{display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-md)}.counter-info__sublabel{font-size:var(--text-sm);color:var(--color-text-muted);text-align:center;margin-top:2px}.counter-card{display:flex;flex-direction:column;gap:var(--spacing-md)}.counter-info{text-align:center;padding:var(--spacing-xs) 0}.counter-info__label{font-size:var(--text-sm);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);margin-bottom:2px}.counter-info__value{font-size:var(--text-2xl);font-weight:var(--font-semibold);color:var(--color-primary);line-height:1}.counter-info__value--large{font-size:var(--text-6xl);background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.counter-row-info{display:flex;justify-content:center;gap:var(--spacing-xl);padding:var(--spacing-sm) 0}.counter-row-info .counter-info{padding:0}.counter-alert-container{min-height:52px;display:flex;align-items:center;justify-content:center}.counter-alert{margin:0;width:100%}.counter-action{width:100%;font-size:var(--text-xl);padding:var(--spacing-lg) var(--spacing-xl)}.counter-footer{text-align:center;margin-top:auto;padding-top:var(--spacing-sm)}.counter-footer__text{color:var(--color-text-muted);font-size:var(--text-sm)}.counter-phase-info{text-align:center;font-size:var(--text-sm);color:var(--color-text-muted);padding-top:var(--spacing-sm);border-top:1px solid var(--color-border);margin-top:var(--spacing-sm)}.auth-form,.setup-form{display:flex;flex-direction:column;gap:var(--spacing-xl)}.form-field{display:flex;flex-direction:column;gap:var(--spacing-xs)}.form-group{display:flex;flex-direction:column;gap:var(--spacing-sm)}.form-group__header{display:flex;justify-content:space-between;align-items:center}.form-label{font-weight:var(--font-medium);color:var(--color-text);font-size:var(--text-base)}.form-label__optional{color:var(--color-text-secondary);font-weight:var(--font-normal)}.form-hint{font-size:var(--text-sm);color:var(--color-text-secondary);margin-top:.25rem}.radio-group{display:flex;gap:var(--spacing-lg);flex-wrap:wrap}.radio-label{display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer;font-size:var(--text-md);color:var(--color-text)}.radio-label input[type=radio]{width:1.25rem;height:1.25rem;cursor:pointer;accent-color:var(--color-primary)}.form-error{color:var(--color-error);font-size:var(--text-base);margin-top:-.25rem}.auth-form__error{text-align:center;margin-bottom:-var(--spacing-md)}.auth-form__submit{margin-top:var(--spacing-md)}.recent-accounts{margin-bottom:.5rem}.recent-accounts__label{font-size:var(--text-sm);color:var(--color-text-muted);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.5px}.recent-account{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;margin-bottom:.5rem;text-align:left;transition:background-color .15s,border-color .15s}.recent-account:hover{background:var(--color-background);border-color:var(--color-primary)}.recent-account:disabled{opacity:.6;cursor:not-allowed}.recent-account__icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--color-background);border-radius:50%;flex-shrink:0;color:var(--color-text-muted)}.recent-account__info{flex:1;min-width:0}.recent-account__name{display:block;font-size:var(--text-base);font-weight:var(--font-medium);color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.recent-account__email{display:block;font-size:var(--text-sm);color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.recent-account__remove{background:none;border:none;color:var(--color-text-muted);font-size:var(--text-sm);cursor:pointer;padding:.25rem;opacity:.5;transition:opacity .15s}.recent-account__remove:hover{opacity:1;color:var(--color-danger, #e74c3c)}.google-signin-btn{display:flex;align-items:center;justify-content:center;gap:.75rem;width:100%;padding:.75rem 1rem;background:#fff;border:1px solid #dadce0;border-radius:var(--radius-md);font-size:var(--text-base);font-weight:var(--font-medium);color:#3c4043;cursor:pointer;transition:background-color .2s,box-shadow .2s}.google-signin-btn:hover{background:#f8f9fa;box-shadow:0 1px 3px #0000001a}.google-signin-btn:disabled{opacity:.6;cursor:not-allowed}.auth-divider{display:flex;align-items:center;margin:1.25rem 0;color:var(--color-text-muted);font-size:var(--text-sm)}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--color-border)}.auth-divider span{padding:0 .75rem}.auth-form__toggle{background:none;border:none;color:var(--color-accent);cursor:pointer;font-size:var(--text-base);padding:var(--spacing-sm);text-align:center;transition:color .15s ease}.auth-form__toggle:hover{color:var(--color-accent-light);text-decoration:underline}.auth-form__toggle:disabled{opacity:.5;cursor:not-allowed}.setup-form__actions{display:flex;gap:var(--spacing-md);margin-top:var(--spacing-md)}.setup-form__actions .button{flex:1}.setup-form__submit{margin-top:0}@media (max-width: 480px){.layout{padding:var(--spacing-md);padding-top:calc(env(safe-area-inset-top,0px) + var(--spacing-md))}.setup-screen__title,.auth-screen__title{font-size:var(--text-3xl)}.counter-screen__title{font-size:var(--text-xl)}.counter-info__value--large{font-size:var(--text-5xl)}.counter-action{font-size:var(--text-lg);padding:var(--spacing-md) var(--spacing-lg)}}.type-selector{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem}@media (max-width: 400px){.type-selector{grid-template-columns:repeat(3,1fr)}}.type-option{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;padding:.75rem .5rem;background:var(--color-surface);border:2px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;min-height:70px}.type-option:hover{border-color:var(--color-primary);background:#ffffff1f}.type-option--selected{border-color:var(--color-primary);background:#f9731633}.type-option__icon{font-size:var(--text-2xl)}.type-option__label{font-size:var(--text-sm);color:var(--color-text);font-weight:var(--font-medium)}.type-selector--compact{justify-content:flex-start}.type-option--small{min-width:auto;padding:.5rem .75rem;flex-direction:row}.type-option--small .type-option__icon{font-size:var(--text-xl)}.project-type-badge{margin-right:.5rem;vertical-align:middle;flex-shrink:0}.project-type-icon{color:var(--color-text)}.project-sections{display:flex;flex-direction:column;gap:1.25rem}.project-section{display:flex;flex-direction:column;gap:.375rem}.section-header{display:flex;justify-content:space-between;align-items:center;gap:.5rem}.section-badge{font-size:var(--text-xs);font-weight:var(--font-semibold);padding:2px 8px;border-radius:10px;text-transform:uppercase;letter-spacing:.02em}.section-badge--owner{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.section-title{font-size:var(--text-base);font-weight:var(--font-medium);color:var(--color-text);margin:0}.section-add-btn{height:24px;padding:0 8px;font-size:var(--text-sm);font-weight:var(--font-medium);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);cursor:pointer;transition:all .15s ease;white-space:nowrap;flex-shrink:0}.section-add-btn:hover{background:var(--color-border);border-color:var(--color-border-strong);color:var(--color-primary)}.section-add-btn:disabled{opacity:.5;cursor:not-allowed}.section-content{display:flex;flex-direction:column;gap:.375rem}.section-empty{text-align:center;color:var(--color-text-muted);font-size:var(--text-base);padding:.75rem;margin:0}.section-card{padding:.625rem .875rem;background:var(--color-surface);border:1px solid var(--color-surface);border-radius:var(--radius-md);font-size:var(--text-base);color:var(--color-text)}.section-card-list{display:flex;flex-direction:column;gap:.375rem}.section-card--row{display:flex;align-items:center;gap:.75rem}.section-card--row .checkbox,.section-card--row .checkbox__label{flex:1}.section-card--completed .checkbox__label{text-decoration:line-through;color:var(--color-text-muted)}.section-card--readonly{cursor:default}.section-card--empty{color:var(--color-text-muted);font-style:italic}.section-card--link{display:block;text-decoration:none;color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.section-card--link:hover{border-color:#f973164d}.section-card--pattern{display:flex;align-items:center;gap:8px;background:var(--color-surface);border-color:var(--color-border-strong);color:var(--color-primary);font-weight:var(--font-medium)}.section-card--pattern:hover{background:var(--color-border);border-color:var(--color-border-strong)}.section-card--active{border-color:var(--color-primary);border-width:2px;background:#8a5e5b14}.section-card--completed{opacity:.7;background:#00000005}.section-card--completed .counter-row__info{text-decoration:line-through;color:var(--color-text-muted)}.section-card--input{display:flex;gap:.5rem;padding:.375rem .5rem .375rem .875rem}.section-textarea{min-height:auto;resize:vertical;font-family:inherit;border:1px solid var(--color-surface);background:var(--color-surface);border-radius:var(--radius-md);padding:.625rem .875rem;font-size:var(--text-base);color:var(--color-text);outline:none;transition:border-color .15s ease}.section-textarea:focus{border-color:var(--color-secondary)}.section-textarea::placeholder{color:var(--color-text-muted);font-size:var(--text-sm)}.section-input{flex:1;border:none;background:transparent;font-size:var(--text-base)}.checklist-input-inline{flex:1;border:none;background:transparent;font-size:var(--text-base);color:var(--color-text);outline:none}.checklist-input-inline::placeholder{color:var(--color-text-muted)}.checklist-add-form{display:flex;gap:.5rem;align-items:center;flex:1;margin-left:1rem}.checklist-add-input{flex:1;border:none;background:transparent;font-size:var(--text-sm);color:var(--color-text);outline:none;text-align:right;padding:.25rem 0}.checklist-add-input::placeholder{color:var(--color-text-muted)}.section-input-full{width:100%;border:1px solid var(--color-surface);background:var(--color-surface);border-radius:var(--radius-md);padding:.625rem .875rem;font-size:var(--text-base);color:var(--color-text);font-family:inherit;outline:none;transition:border-color .15s ease}.section-input-full:focus{border-color:var(--color-secondary)}.section-input-full::placeholder{color:var(--color-text-muted)}.section-status{font-size:var(--text-sm);color:var(--color-text-muted)}.craft-fields{display:flex;flex-direction:column;gap:12px}.craft-field{display:flex;flex-direction:column;gap:4px}.craft-field__label{font-size:var(--text-sm);font-weight:var(--font-normal);color:var(--color-text-secondary)}.craft-field__input{width:100%;border:1px solid var(--color-surface);background:var(--color-surface);border-radius:var(--radius-md);padding:.5rem .75rem;font-size:var(--text-base);color:var(--color-text);font-family:inherit;outline:none;transition:border-color .15s}.craft-field__input:focus{border-color:var(--color-secondary)}.craft-field__input::placeholder{color:var(--color-text-muted);font-size:var(--text-sm)}.custom-field__remove{background:none;border:none;color:var(--color-text-muted);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center}.add-field-btn{align-self:flex-start;height:24px;padding:0 8px;font-size:var(--text-sm);font-weight:var(--font-medium);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);cursor:pointer;transition:all .15s ease;margin-top:.5rem}.add-field-btn:hover{background:var(--color-border);border-color:var(--color-border-strong);color:var(--color-primary)}.add-field-input{display:flex;gap:.5rem;align-items:center;margin-top:.5rem}.add-field-input__input{flex:1;border:1px solid var(--color-border-strong);background:var(--color-surface);border-radius:var(--radius-md);padding:.5rem .75rem;font-size:var(--text-base);color:var(--color-text);font-family:inherit}.add-field-input__input:focus{border-color:var(--color-secondary);outline:none}.add-field-input__confirm{background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);padding:.5rem 1rem;font-size:var(--text-base);cursor:pointer;font-weight:var(--font-medium)}.add-field-input__cancel{background:none;border:none;color:var(--color-text-muted);cursor:pointer;padding:.25rem;font-size:var(--text-md)}.add-field-input__cancel:hover{color:var(--color-error)}.craft-field--custom{position:relative}.craft-field__header{display:flex;justify-content:space-between;align-items:center}.craft-field__remove{background:none;border:none;color:var(--color-text-muted);cursor:pointer;padding:2px;display:flex;align-items:center;justify-content:center;opacity:.6;transition:all .15s}.craft-field__remove:hover{color:var(--color-error);opacity:1}.dropdown{position:relative}.dropdown--disabled{opacity:.5;pointer-events:none}.dropdown__trigger{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.5rem .75rem;background:var(--color-surface);border:1px solid var(--color-surface);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--color-text);cursor:pointer;transition:border-color .15s ease}.dropdown__trigger:hover{border-color:var(--color-border-strong)}.dropdown__trigger--open{border-color:var(--color-primary)}.dropdown__value--placeholder{color:var(--color-text-tertiary)}.dropdown__arrow{color:var(--color-text-secondary);transition:transform .15s ease}.dropdown__arrow--open{transform:rotate(180deg)}.dropdown__menu{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:0 4px 20px #0000001f;z-index:1000;padding:.25rem}.dropdown__option{display:flex;align-items:center;gap:.5rem;width:100%;padding:.5rem .75rem;background:none;border:none;border-radius:var(--radius-sm);font-size:var(--text-sm);color:var(--color-text);cursor:pointer;text-align:left}.dropdown__option:hover{background:var(--color-surface)}.dropdown__option--selected{color:var(--color-primary);font-weight:var(--font-medium);background:var(--color-surface)}.toggle-selector{display:flex;gap:.5rem}.toggle-selector__option{flex:1;display:flex;align-items:center;justify-content:center;gap:.35rem;padding:.5rem .75rem;background:#fff6;border:1px solid var(--color-surface);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-secondary);cursor:pointer;transition:all .15s ease}.toggle-selector__option:hover{border-color:var(--color-border-strong);color:var(--color-text)}.toggle-selector__option--selected{background:var(--color-surface);border-color:var(--color-primary);color:var(--color-primary)}.toggle-selector__icon{font-size:1rem}.form-toggle-section{margin-bottom:.75rem}.order-fields{display:flex;flex-direction:column;gap:.75rem;padding:.75rem;background:#8b294208;border:1px solid var(--color-surface);border-radius:var(--radius-md)}.order-fields__row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.order-field{display:flex;flex-direction:column;gap:.25rem}.order-field__label{font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--color-text-secondary)}.price-input-group{display:flex;gap:.5rem}.price-input-group .currency-dropdown{width:auto;min-width:70px;flex-shrink:0}.price-input-group .price-input{flex:1}.form-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238b2942' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;padding-right:2rem}.order-details{display:flex;flex-direction:column;gap:.75rem;padding:.75rem;background:#8b294208;border:1px solid var(--color-surface);border-radius:var(--radius-md)}.order-details__info{display:flex;justify-content:space-between;align-items:center;padding-bottom:.5rem;border-bottom:1px solid var(--color-surface)}.order-details__info:last-of-type{border-bottom:none;padding-bottom:0}.order-details__label{font-size:var(--text-sm);color:var(--color-text-secondary)}.order-details__value{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-primary)}.order-details__statuses{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-top:.25rem}@media (max-width: 480px){.order-details__statuses{grid-template-columns:1fr 1fr}}.order-details__status{display:flex;flex-direction:column;gap:.25rem}.links-display{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.link-chip{display:inline-flex;align-items:center;gap:.25rem;padding:.35rem .5rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--text-xs);max-width:200px}.link-chip__text{color:var(--color-primary);text-decoration:none;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.link-chip__text:hover{text-decoration:underline}.link-chip__remove{background:none;border:none;color:var(--color-text-tertiary);cursor:pointer;font-size:1rem;line-height:1;padding:0;margin-left:.25rem}.link-chip__remove:hover{color:var(--color-error)}.add-link-modal{margin-top:.75rem;padding:.75rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md)}.add-link-modal__content{display:flex;flex-direction:column;gap:.5rem}.add-link-modal__field{display:flex;flex-direction:column;gap:.25rem}.add-link-modal__label{font-size:var(--text-xs);color:var(--color-text-secondary)}.add-link-modal__actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:.5rem}.add-link-modal__cancel{padding:.4rem .75rem;background:none;border:none;font-size:var(--text-sm);color:var(--color-text-secondary);cursor:pointer}.add-link-modal__cancel:hover{color:var(--color-text)}.add-link-modal__save{padding:.4rem .75rem;background:var(--color-primary);border:none;border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:var(--font-medium);color:#fff;cursor:pointer}.add-link-modal__save:hover{background:var(--color-brand-dark)}.add-link-modal__save:disabled{opacity:.5;cursor:not-allowed}.links-list{display:flex;flex-direction:column;gap:.5rem}.link-item{display:flex;align-items:center;gap:.5rem}.link-item__fields{flex:1;display:grid;grid-template-columns:100px 1fr;gap:.5rem}.link-item__label,.link-item__url{font-size:var(--text-sm)}.link-item__remove{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:none;border:none;flex-shrink:0;color:var(--color-text-tertiary);cursor:pointer;border-radius:var(--radius-sm);transition:all .15s ease}.link-item__remove:hover{color:var(--color-error)}.add-link-btn{align-self:flex-start;height:24px;padding:0 8px;font-size:var(--text-sm);font-weight:var(--font-medium);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);cursor:pointer;transition:all .15s ease}.add-link-btn:hover{background:var(--color-border);border-color:var(--color-border-strong);color:var(--color-primary)}.pattern-owner-toggle{display:flex;align-items:center;gap:.5rem;font-size:var(--text-base);color:var(--color-text-muted);cursor:pointer;margin-top:.5rem}.pattern-owner-toggle input[type=checkbox]{width:16px;height:16px;accent-color:var(--color-primary)}.section-textarea{min-height:70px;width:100%;font-family:inherit;font-size:var(--text-base);resize:vertical}.section-input{font-size:var(--text-base)}.section-info-items{display:flex;flex-direction:column;gap:.375rem}.info-item{display:flex;align-items:center;gap:.625rem;padding:.625rem .875rem;background:var(--color-card);border:1px solid var(--color-card-border);border-radius:var(--radius-md);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.info-item--link{text-decoration:none;color:var(--color-text);transition:all .15s ease}.info-item--link:hover{background:#f973161a;border-color:#f973164d}.info-item__icon{font-size:var(--text-md)}.info-item__text{font-size:var(--text-base)}.section-edit-row{display:flex;gap:.5rem;align-items:center}.section-edit-row .section-input{flex:1}.project-section--archive{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--color-border)}.action-button{width:100%;height:32px;padding:0 16px;font-size:var(--text-base);font-weight:var(--font-semibold);border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease}.action-button--start{background:var(--color-primary);border:none;color:#fff}.action-button--start:hover{opacity:.9}.action-button--finish{background:#2d6a4f1a;border:1px solid rgba(45,106,79,.25);color:var(--color-success)}.action-button--finish:hover{background:#2d6a4f26;border-color:#2d6a4f59}.action-button--reactivate{background:var(--color-surface);border:1px solid var(--color-border-strong);color:var(--color-primary)}.action-button--reactivate:hover{background:var(--color-border);border-color:#8b294259}.action-button--share{background:#3b82f61a;border:1px solid rgba(59,130,246,.25);color:#3b82f6}.action-button--share:hover{background:#3b82f626;border-color:#3b82f659}.date-inputs{display:flex;gap:var(--spacing-md)}.date-input-group{flex:1;display:flex;flex-direction:column;gap:.25rem}.date-input-label{font-size:var(--text-sm);color:var(--color-text-muted);font-weight:var(--font-medium)}.add-inline-btn{width:100%;padding:.625rem .875rem;background:transparent;border:1px dashed var(--color-border-strong);border-radius:var(--radius-md);color:var(--color-text-muted);font-size:var(--text-base);cursor:pointer;transition:all .15s ease;text-align:left}.add-inline-btn:hover{border-color:#f9731666;color:var(--color-primary)}.info-row{display:flex;align-items:center;gap:.75rem;padding:.625rem .875rem;background:var(--color-card);border:1px solid var(--color-card-border);border-radius:var(--radius-md);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);cursor:pointer;transition:all .15s ease}.info-row:hover{border-color:#f973164d}.info-row--link{text-decoration:none;color:inherit}.info-row__label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;flex-shrink:0}.info-row__value{font-size:var(--text-base);color:var(--color-text);flex:1}.info-row__value--truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.inline-edit-row{display:flex;gap:.5rem;align-items:center}.inline-edit-row .section-input{flex:1}.project-section--compact{gap:.25rem}.checklists-section{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-top:var(--spacing-sm)}.checklist-items{display:flex;flex-direction:column;gap:.375rem}.checklist-item{display:flex;align-items:center;gap:.75rem;padding:.625rem .875rem;background:var(--color-card);border:1px solid var(--color-card-border);border-radius:var(--radius-md);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.checklist-item--checked{opacity:.6}.checklist-item--checked .checklist-item__text{text-decoration:line-through;color:var(--color-text-muted)}.checklist-item__checkbox{background:none;border:none;font-size:var(--text-xl);cursor:pointer;padding:0;color:var(--color-text);transition:color .15s ease}.checklist-item__checkbox:hover{color:var(--color-primary)}.checklist-item__text{flex:1;font-size:var(--text-base);color:var(--color-text)}.checklist-item__delete{padding:.375rem .5rem;background:var(--color-border);border:none;color:var(--color-text-muted);cursor:pointer;font-size:var(--text-sm);border-radius:var(--radius-sm);transition:all .15s ease;flex-shrink:0}.checklist-item__delete:hover{background:var(--color-error-soft);color:var(--color-error-strong)}.checklist-item{flex-direction:row;align-items:center;padding:.75rem;cursor:grab;transition:all .2s ease}.checklist-item:active{cursor:grabbing}.checklist-item--dragging,.checklist-item.dragging{opacity:.5;background:var(--color-primary-soft);border-color:var(--color-primary);transform:scale(1.02);box-shadow:0 4px 12px #00000026}.checklist-item--drop-target{border-color:var(--color-primary);background:var(--color-primary-soft)}.checklist-item__drag-handle{display:flex;align-items:center;justify-content:center;padding:.5rem;margin:-.25rem .25rem -.25rem -.25rem;color:var(--color-text-muted);opacity:.6;cursor:grab;flex-shrink:0;touch-action:none;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.checklist-item:hover .checklist-item__drag-handle,.checklist-item__drag-handle:active{opacity:1}.checklist-item__drag-handle:active{cursor:grabbing}.checklist-item__content{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:center;gap:.25rem}.checklist-item__main{display:flex;align-items:center;gap:.5rem}.checklist-item__description{margin:0;padding-left:1.75rem;font-size:var(--font-size-sm);color:var(--color-text-muted);line-height:1.4}.section-card--completed .checklist-item__description{text-decoration:line-through;opacity:.6}.checklist-item__edit{display:flex;flex-direction:column;gap:.5rem;width:100%}.checklist-item__edit-fields{display:flex;flex-direction:column;gap:.5rem;flex:1}.checklist-item__edit-input{height:36px;padding:.5rem .75rem;font-size:var(--font-size-sm)}.checklist-item__edit-textarea{padding:.5rem .75rem;font-size:var(--font-size-sm);resize:vertical;min-height:60px}.checklist-item__edit-actions{display:flex;gap:.5rem;justify-content:flex-end}.checklist-list{display:flex;flex-direction:column;gap:.5rem}.checklist-item__actions{display:flex;align-items:center;gap:.25rem;margin-left:auto}.checklist-item__edit-btn{padding:.375rem .5rem;background:var(--color-border);border:none;color:var(--color-text-muted);cursor:pointer;border-radius:var(--radius-sm);transition:all .15s ease;display:flex;align-items:center;justify-content:center}.checklist-item__edit-btn:hover{background:var(--color-primary-soft);color:var(--color-primary)}.checklist-item__edit-save,.checklist-item__edit-cancel{padding:.375rem .5rem;border:none;cursor:pointer;border-radius:var(--radius-sm);transition:all .15s ease;display:flex;align-items:center;justify-content:center}.checklist-item__edit-save{background:var(--color-success-soft);color:var(--color-success-strong)}.checklist-item__edit-save:hover{background:var(--color-success-strong);color:#fff}.checklist-item__edit-cancel{background:var(--color-border);color:var(--color-text-muted)}.checklist-item__edit-cancel:hover{background:var(--color-error-soft);color:var(--color-error-strong)}.checklist-add-form{display:flex;gap:.5rem;margin-top:.25rem}.checklist-input{flex:1;font-size:var(--text-base)!important;padding:.5rem .75rem!important}.photos-section{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-top:var(--spacing-sm)}.photos-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}.photo-item{position:relative;aspect-ratio:1;border-radius:var(--radius-md);overflow:hidden;background:var(--color-card);cursor:pointer;transition:transform .15s ease}.photo-item:hover{transform:scale(1.02)}.photo-item__img{width:100%;height:100%;object-fit:cover}.photo-item__delete{position:absolute;top:.25rem;right:.25rem;width:1.5rem;height:1.5rem;padding:0;background:#0009;border:none;border-radius:50%;color:#fff;font-size:var(--text-sm);cursor:pointer;opacity:0;transition:opacity .15s ease;display:flex;align-items:center;justify-content:center}.photo-item:hover .photo-item__delete{opacity:1}.add-photo-button{width:100%;padding:.75rem 1rem;background:var(--color-surface);border:1px dashed var(--color-border);border-radius:var(--radius-md);color:var(--color-text-muted);font-size:var(--text-base);font-weight:var(--font-medium);cursor:pointer;transition:all .2s ease}.add-photo-button:hover{border-color:var(--color-primary);color:var(--color-primary);background:#f973161a}.add-photo-button:disabled{opacity:.5;cursor:not-allowed}.lightbox-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000f2;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;z-index:100000;padding:1rem;padding-top:calc(env(safe-area-inset-top,0px) + 3rem);padding-bottom:calc(80px + env(safe-area-inset-bottom,0px));overflow-y:auto;-webkit-overflow-scrolling:touch;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.lightbox-content{position:relative;width:100%;max-width:400px;display:flex;flex-direction:column;align-items:center;gap:1rem}.lightbox-image{width:100%;max-height:40vh;object-fit:contain;border-radius:var(--radius-md)}.lightbox-actions{display:flex;gap:1rem;align-items:center}.lightbox-close{position:fixed;top:calc(env(safe-area-inset-top,0px) + .5rem);right:1rem;width:2.5rem;height:2.5rem;padding:0;background:var(--color-border);border:none;border-radius:50%;color:#fff;font-size:var(--text-xl);cursor:pointer;transition:background .15s ease;display:flex;align-items:center;z-index:100001;justify-content:center}.lightbox-close:hover{background:var(--color-border-strong)}.lightbox-delete{padding:.5rem 1rem;background:#ef444433;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-md);color:#f87171;font-size:var(--text-base);cursor:pointer;transition:all .15s ease;display:flex;align-items:center;gap:.5rem}.lightbox-delete:hover{background:#ef44444d;border-color:#ef444480}.lightbox-share{padding:.5rem 1rem;background:var(--color-border);border:1px solid var(--color-border-strong);border-radius:var(--radius-md);color:#fff;font-size:var(--text-base);cursor:pointer;transition:all .15s ease;display:flex;align-items:center;gap:.5rem}.lightbox-share:hover{background:var(--color-border-strong)}.lightbox-share--active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.lightbox-share:disabled{opacity:.5;cursor:not-allowed}.lightbox-cover{padding:.5rem 1rem;background:var(--color-border);border:1px solid var(--color-border-strong);border-radius:var(--radius-md);color:#fff;font-size:var(--text-base);cursor:pointer;transition:all .15s ease;display:flex;align-items:center;gap:.5rem}.lightbox-cover:hover{background:var(--color-primary);border-color:var(--color-primary)}.lightbox-cover-badge{padding:.5rem 1rem;background:var(--color-success-soft);border:1px solid var(--color-success-strong);border-radius:var(--radius-md);color:var(--color-success-strong);font-size:var(--text-base);display:flex;align-items:center;gap:.5rem;font-weight:var(--font-medium)}.lightbox-share-form{background:#1e1e1efa;padding:1rem;border-radius:var(--radius-md);display:flex;flex-direction:column;gap:.75rem;width:100%}.lightbox-share-form__header{display:flex;justify-content:space-between;align-items:center;color:#fff;font-weight:var(--font-semibold);font-size:var(--text-base)}.lightbox-share-form__header button{background:none;border:none;color:var(--color-surface);cursor:pointer;font-size:var(--text-md)}.lightbox-share-form__tags{display:flex;flex-wrap:wrap;gap:.375rem}.lightbox-tag{display:flex;align-items:center;gap:.25rem;background:var(--color-border);padding:.25rem .5rem;border-radius:1rem;font-size:var(--text-sm);color:#fff}.lightbox-tag--auto{background:var(--color-primary)}.lightbox-tag button{background:none;border:none;color:var(--color-surface);cursor:pointer;font-size:var(--text-sm);padding:0;margin-left:.125rem}.lightbox-share-form__input{display:flex;gap:.5rem}.lightbox-share-form__input input{flex:1;padding:.5rem .75rem;border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);background:var(--color-border);color:#fff;font-size:var(--text-sm)}.lightbox-share-form__input input::placeholder{color:#fff6}.lightbox-share-form__input button{padding:.5rem .75rem;background:var(--color-border-strong);border:none;border-radius:var(--radius-sm);color:#fff;cursor:pointer;font-size:var(--text-base)}.lightbox-share-form__submit{padding:.625rem 1rem;background:var(--color-primary);border:none;border-radius:var(--radius-md);color:#fff;font-weight:var(--font-semibold);font-size:var(--text-base);cursor:pointer}.lightbox-share-form__submit:disabled{opacity:.5;cursor:not-allowed}.app-container{display:flex;flex-direction:column;height:100vh;height:100dvh;overflow:hidden}.app-content{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding-bottom:calc(70px + env(safe-area-inset-bottom,0px))}.header-timer{display:flex;align-items:center;gap:4px;height:28px;padding:0 10px;background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-md)}.header-timer--running{background:var(--color-surface);border-color:var(--color-primary)}.header-timer__info{display:flex;align-items:center;gap:.35rem;background:none;border:none;color:var(--color-text);cursor:pointer;padding:.15rem .25rem}.header-timer__pulse{width:6px;height:6px;background:#ef4444;border-radius:50%;animation:timerPulse 1.5s ease-in-out infinite;flex-shrink:0}.header-timer__paused-dot{width:6px;height:6px;background:var(--color-text-tertiary);border-radius:50%;flex-shrink:0}@keyframes timerPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.2)}}.header-timer__project{font-size:var(--text-xs);font-weight:var(--font-medium);max-width:100px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-timer__time{font-size:var(--text-xs);font-weight:var(--font-semibold);font-variant-numeric:tabular-nums;color:var(--color-text-secondary)}.header-timer--running .header-timer__time{color:var(--color-primary)}.header-timer__toggle{display:flex;align-items:center;justify-content:center;width:20px;height:20px;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--color-text-secondary);cursor:pointer;transition:all .15s ease}.header-timer__toggle:hover{background:#0000000d;color:var(--color-text)}.header-timer--running .header-timer__toggle{color:var(--color-primary)}.header-timer__switch-wrapper{position:relative;display:flex;align-items:center}.header-timer__switch{display:flex;align-items:center;justify-content:center;width:16px;height:16px;background:none;border:none;border-radius:var(--radius-sm);color:var(--color-text-secondary);cursor:pointer;transition:all .15s ease;margin-right:2px}.header-timer__switch:hover{color:var(--color-text)}.header-timer__picker-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:999}.header-timer__picker{position:absolute;top:calc(100% + 12px);left:-10px;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);min-width:180px;max-width:220px;z-index:1000;overflow:hidden}.header-timer__picker-item{display:flex;align-items:center;justify-content:space-between;gap:.5rem;width:100%;padding:.6rem .75rem;background:none;border:none;font-size:var(--text-sm);color:var(--color-text);cursor:pointer;text-align:left;transition:background .15s ease}.header-timer__picker-item:hover{background:#0000000a}.header-timer__picker-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-timer__picker-time{font-size:var(--text-xs);color:var(--color-text-secondary);font-variant-numeric:tabular-nums}.tab-bar{position:fixed;bottom:0;left:0;right:0;height:calc(70px + env(safe-area-inset-bottom,0px));padding-bottom:env(safe-area-inset-bottom,0px);background:var(--color-bg);border-top:1px solid var(--color-border);display:flex;justify-content:space-around;align-items:stretch;z-index:99999}.tab-bar__item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:8px 0;background:none;border:none;color:var(--color-text-muted);cursor:pointer;transition:color .15s ease}.tab-bar__item svg{width:24px;height:24px}.tab-bar__item span{font-size:var(--text-sm);font-weight:var(--font-medium)}.tab-bar__item--active{color:var(--color-primary)}.tab-bar__add{width:56px;height:56px;border-radius:50%;background:var(--color-primary);border:none;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;margin-top:-20px;box-shadow:0 4px 12px var(--color-border-strong);transition:transform .15s ease,box-shadow .15s ease}.tab-bar__add:hover{transform:scale(1.05);box-shadow:0 6px 16px #8b294266}.tab-bar__add:active{transform:scale(.95)}.tab-bar__add svg{width:24px;height:24px}.feed-screen{display:flex;flex-direction:column;gap:var(--spacing-md)}.feed-screen__header{display:flex;justify-content:space-between;align-items:center}.feed-screen__title{font-size:var(--text-2xl);color:var(--color-text);margin:0}.feed-loading,.feed-empty{text-align:center;padding:var(--spacing-xl)}.feed-empty__text{font-size:var(--text-lg);color:var(--color-text);margin-bottom:var(--spacing-sm)}.feed-empty__hint{color:var(--color-text-muted);font-size:var(--text-base)}.feed-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-sm)}@media (min-width: 500px){.feed-grid{grid-template-columns:repeat(3,1fr)}}.feed-item{position:relative;aspect-ratio:1;border-radius:var(--radius-md);overflow:hidden;cursor:pointer}.feed-item__img{width:100%;height:100%;object-fit:cover}.feed-item__overlay{position:absolute;bottom:0;left:0;right:0;padding:var(--spacing-sm);background:linear-gradient(transparent,#000000b3);display:flex;justify-content:space-between;align-items:center}.feed-item__type{font-size:var(--text-md)}.feed-item__author{font-size:var(--text-sm);color:#fff;opacity:.9;background:none;border:none;cursor:pointer;padding:0}.feed-item__author:hover{opacity:1;text-decoration:underline}.feed-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.feed-post{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.feed-post__header{display:flex;justify-content:space-between;align-items:center;padding:.625rem .75rem;gap:8px}.feed-post__header-right{display:flex;align-items:center;gap:8px}.feed-post__author{display:flex;align-items:center;gap:.5rem;background:none;border:none;cursor:pointer;padding:0}.feed-post__avatar{font-size:var(--text-xl)}.feed-post__handle{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text)}.feed-post__author:hover .feed-post__handle{text-decoration:underline}.feed-post__edit{background:none;border:none;color:var(--color-text-muted);font-size:var(--text-sm);cursor:pointer;padding:.25rem .5rem}.feed-post__edit:hover{color:var(--color-primary)}.feed-post__actions{display:flex;align-items:center;gap:.5rem}.feed-post__delete{background:none;border:none;color:var(--color-text-muted);cursor:pointer;padding:.25rem;display:flex;align-items:center;opacity:.6}.feed-post__delete:hover{color:var(--color-danger, #e74c3c);opacity:1}.feed-post__image{width:100%;aspect-ratio:1;background:var(--color-surface)}.feed-post__image img{width:100%;height:100%;object-fit:cover}.feed-post__info{padding:.75rem}.feed-post__separator{color:var(--color-text-muted);font-size:var(--text-base)}.feed-post__meta{display:flex;align-items:center;gap:.5rem;font-size:var(--text-sm);color:var(--color-text-muted);flex-shrink:0}.feed-post__project-row{display:flex;align-items:baseline;gap:.25rem;margin-bottom:.25rem}.feed-post__project-label{font-size:var(--text-sm);color:var(--color-text-muted);font-weight:var(--font-normal)}.feed-post__project-name{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text)}.feed-post__details{display:flex;flex-wrap:wrap;align-items:baseline;gap:.375rem;font-size:var(--text-sm);line-height:1.4;margin-bottom:8px}.feed-post__description{color:var(--color-text);margin:0}.feed-post__hashtag{background:none;border:none;color:var(--color-primary);font-size:var(--text-sm);cursor:pointer;padding:0}.feed-post__location{display:flex;align-items:center;gap:.25rem}.feed-post__location svg{opacity:.7}.feed-post__date{opacity:.7}.feed-post__hashtag:hover{text-decoration:underline}.feed-post__shared-details{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.25rem}.feed-post__info .project-badges{margin-top:4px}.feed-post__detail{font-size:var(--text-sm);color:var(--color-text-muted);background:var(--color-surface);padding:2px 8px;border-radius:12px}.feed-post__detail--pattern{display:inline-flex;align-items:center;gap:4px}.feed-post__owner-badge{font-size:var(--text-xs);font-weight:var(--font-semibold);padding:1px 5px;border-radius:8px;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;text-transform:uppercase;letter-spacing:.02em}.feed-post__link{font-size:var(--text-sm);color:var(--color-primary);background:var(--color-border);padding:4px 10px;border-radius:12px;text-decoration:none;font-weight:var(--font-medium);display:inline-flex;align-items:center;gap:4px;transition:background .15s}.feed-post__link:hover{background:var(--color-border-strong)}.edit-photo-page{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--color-bg);z-index:9000;display:flex;flex-direction:column}.edit-photo-page__header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;padding-top:calc(env(safe-area-inset-top,0px) + .75rem);border-bottom:1px solid var(--color-border);flex-shrink:0;background:var(--color-background)}.edit-photo-page__back{background:none;border:none;color:var(--color-text);cursor:pointer;padding:.25rem;display:flex;align-items:center}.edit-photo-page__title{font-size:var(--text-md);font-weight:var(--font-semibold);color:var(--color-text);margin:0}.edit-photo-page__save{background:var(--color-primary);border:none;color:#fff;font-weight:var(--font-semibold);font-size:var(--text-base);padding:.5rem 1rem;border-radius:var(--radius-sm);cursor:pointer}.edit-photo-page__save:disabled{opacity:.5}.edit-photo-page__content{flex:1;display:flex;flex-direction:column;overflow-y:auto;-webkit-overflow-scrolling:touch}.edit-photo-page__image{width:100%;height:40vh;max-height:300px;flex-shrink:0;background:#000;display:flex;align-items:center;justify-content:center}.edit-photo-page__image img{max-width:100%;max-height:100%;object-fit:contain}.edit-photo-page__form{padding:1rem;padding-bottom:calc(80px + env(safe-area-inset-bottom,0px))}.edit-photo-page__field{margin-bottom:1rem}.edit-photo-page__field label{display:block;font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-primary);margin-bottom:.375rem}.edit-photo-page__field textarea{width:100%;padding:.75rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text);font-size:var(--text-base);resize:none;font-family:inherit;min-height:60px}.edit-photo-page__field textarea:focus{outline:none;border-color:var(--color-primary)}.edit-photo-page__tags{display:flex;flex-wrap:wrap;gap:.375rem;margin-bottom:.5rem}.edit-photo-page__tag{display:inline-flex;align-items:center;gap:.25rem;background:var(--color-primary);color:#fff;padding:.375rem .625rem;border-radius:1rem;font-size:var(--text-sm)}.edit-photo-page__tag button{background:none;border:none;color:#ffffffb3;cursor:pointer;font-size:var(--text-sm);padding:0;margin-left:.125rem}.edit-photo-page__location-input{width:100%;padding:.625rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text);font-size:var(--text-base)}.edit-photo-page__location-input:focus{outline:none;border-color:var(--color-primary)}.edit-photo-page__tag-input{display:flex;gap:.5rem}.edit-photo-page__tag-input input{flex:1;padding:.625rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text);font-size:var(--text-base)}.edit-photo-page__tag-input input:focus{outline:none;border-color:var(--color-primary)}.edit-photo-page__tag-input button{padding:.625rem .875rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);cursor:pointer;font-size:var(--text-md)}.edit-photo-page__project{font-size:var(--text-base);color:var(--color-text);margin-top:.5rem}.edit-photo-page__project-label{color:var(--color-text-muted)}.edit-photo-page__project-link{display:inline-flex;align-items:center;gap:6px;font-size:var(--text-base);color:var(--color-primary);background:none;border:none;padding:8px 0;cursor:pointer;margin-top:.5rem}.edit-photo-page__project-link:hover{text-decoration:underline}.edit-photo-page__delete{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.75rem;margin-top:1.5rem;background:none;border:1px solid var(--color-danger, #e74c3c);border-radius:var(--radius-md);color:var(--color-danger, #e74c3c);font-size:var(--text-base);cursor:pointer}.edit-photo-page__delete:hover{background:#e74c3c1a}.add-to-feed-page{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--color-bg);z-index:100000;display:flex;flex-direction:column}.add-to-feed-page__header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;padding-top:calc(env(safe-area-inset-top,0px) + .75rem);border-bottom:1px solid var(--color-border);flex-shrink:0;background:var(--color-bg)}.add-to-feed-page__back{background:none;border:none;color:var(--color-text);cursor:pointer;padding:.25rem;display:flex;align-items:center}.add-to-feed-page__title{font-size:var(--text-md);font-weight:var(--font-semibold);color:var(--color-text);margin:0}.add-to-feed-page__submit{background:var(--color-primary);border:none;color:#fff;font-weight:var(--font-semibold);font-size:var(--text-base);padding:.5rem 1rem;border-radius:var(--radius-sm);cursor:pointer}.add-to-feed-page__submit:disabled{opacity:.5}.add-to-feed-page__content{flex:1;display:flex;flex-direction:column;overflow-y:auto;-webkit-overflow-scrolling:touch}.add-to-feed-page__image{width:100%;max-height:50vh;flex-shrink:0;background:#000;display:flex;align-items:center;justify-content:center}.add-to-feed-page__image img{max-width:100%;max-height:100%;object-fit:contain}.add-to-feed-page__form{padding:1rem;padding-bottom:calc(80px + env(safe-area-inset-bottom,0px))}.add-to-feed-page__field{margin-bottom:1rem}.add-to-feed-page__field label{display:block;font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-primary);margin-bottom:.375rem}.add-to-feed-page__field textarea{width:100%;padding:.75rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text);font-size:var(--text-base);font-family:inherit;resize:vertical;min-height:80px}.add-to-feed-page__field textarea:focus{outline:none;border-color:var(--color-primary)}.add-to-feed-page__location-input{width:100%;padding:.75rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text);font-size:var(--text-base);font-family:inherit}.add-to-feed-page__location-input:focus{outline:none;border-color:var(--color-primary)}.add-to-feed-page__tags{display:flex;flex-wrap:wrap;gap:.375rem;margin-bottom:.5rem}.add-to-feed-page__tag{display:inline-flex;align-items:center;gap:.25rem;background:var(--color-primary);color:#fff;padding:.375rem .625rem;border-radius:1rem;font-size:var(--text-sm)}.add-to-feed-page__tag--auto{background:var(--color-primary);opacity:.8}.add-to-feed-page__tag button{background:none;border:none;color:#ffffffb3;cursor:pointer;font-size:var(--text-sm);padding:0;margin-left:.125rem}.add-to-feed-page__tag-input{display:flex;gap:.5rem}.add-to-feed-page__tag-input input{flex:1;padding:.625rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text);font-size:var(--text-base)}.add-to-feed-page__tag-input input:focus{outline:none;border-color:var(--color-primary)}.add-to-feed-page__tag-input button{padding:.625rem .875rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);cursor:pointer;font-size:var(--text-md)}.add-to-feed-page__project{font-size:var(--text-base);color:var(--color-text-muted);margin-top:.5rem}.user-profile-page{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--color-bg);z-index:9000;display:flex;flex-direction:column}.user-profile-page__header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;padding-top:calc(env(safe-area-inset-top,0px) + .75rem);border-bottom:1px solid var(--color-border);flex-shrink:0;background:var(--color-bg)}.user-profile-page__title{font-size:var(--text-md);font-weight:var(--font-semibold);color:var(--color-text);margin:0}.user-profile-page__content{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:var(--spacing-md);padding-bottom:calc(80px + env(safe-area-inset-bottom,0px));display:flex;flex-direction:column;gap:var(--spacing-md)}.user-profile-page__loading{text-align:center;color:var(--color-text-muted);padding:2rem}.user-profile-page__follow{width:100%;padding:.75rem;background:var(--color-primary);border:none;border-radius:var(--radius-md);color:#fff;font-weight:var(--font-semibold);font-size:var(--text-base);cursor:pointer;margin:var(--spacing-md) 0}.user-profile-page__follow--following{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border)}.user-profile-page__follow:disabled{opacity:.5}.feed-user-result{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;margin-bottom:var(--spacing-md)}.feed-user-result:active{background:var(--color-card)}.feed-user-result__avatar{width:48px;height:48px;border-radius:50%;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:var(--text-xl);font-weight:var(--font-semibold);overflow:hidden;flex-shrink:0}.feed-user-result__avatar img{width:100%;height:100%;object-fit:cover}.feed-user-result__info{flex:1;min-width:0}.feed-user-result__handle{display:block;font-weight:var(--font-semibold);color:var(--color-text);font-size:var(--text-base)}.feed-user-result__bio{display:block;font-size:var(--text-sm);color:var(--color-text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.feed-user-result__arrow{color:var(--color-text-muted);flex-shrink:0}.feed-lightbox{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:200;padding:var(--spacing-lg)}.feed-lightbox__content{position:relative;max-width:100%;max-height:100%;display:flex;flex-direction:column;align-items:center;gap:1rem}.feed-lightbox__img{max-width:100%;max-height:calc(100vh - 8rem);object-fit:contain;border-radius:var(--radius-md)}.feed-lightbox__info{display:flex;flex-direction:column;align-items:center;gap:.25rem;color:#fff}.feed-lightbox__project{font-weight:var(--font-semibold)}.feed-lightbox__author{font-size:var(--text-base);opacity:.7}.feed-lightbox__close{position:absolute;top:-2.5rem;right:0;width:2.5rem;height:2.5rem;padding:0;background:var(--color-border);border:none;border-radius:50%;color:#fff;cursor:pointer;transition:background .15s ease;display:flex;align-items:center;justify-content:center}.feed-lightbox__close:hover{background:var(--color-border-strong)}.feed-lightbox__hashtags{display:flex;flex-wrap:wrap;gap:.375rem;margin-top:.5rem}.feed-lightbox__hashtag{background:var(--color-border);border:none;border-radius:1rem;padding:.25rem .625rem;font-size:var(--text-sm);color:#fff;cursor:pointer;transition:background .15s ease}.feed-lightbox__hashtag:hover{background:#ffffff40}.feed-lightbox__author-btn{background:none;border:none;color:var(--color-surface-elevated);font-size:var(--text-base);cursor:pointer;padding:0;text-decoration:underline}.feed-lightbox__author-btn:hover{color:#fff}.user-profile-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.user-profile-modal__content{background:var(--color-background);border-radius:var(--radius-lg);width:100%;max-width:400px;max-height:80vh;overflow-y:auto;position:relative;padding:1.25rem}.user-profile-modal__close{position:absolute;top:.75rem;right:.75rem;background:none;border:none;color:var(--color-text-muted);cursor:pointer;padding:.25rem}.user-profile-modal__header{display:flex;gap:1rem;align-items:center;margin-bottom:.75rem}.user-profile-modal__avatar{width:60px;height:60px;border-radius:50%;background:var(--color-surface);border:2px solid var(--color-border);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}.user-profile-modal__avatar img{width:100%;height:100%;object-fit:cover}.user-profile-modal__avatar span{font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--color-primary)}.user-profile-modal__info{flex:1}.user-profile-modal__handle{font-size:var(--text-md);font-weight:var(--font-semibold);color:var(--color-text);margin:0 0 .25rem}.user-profile-modal__stats{display:flex;gap:.75rem;font-size:var(--text-sm);color:var(--color-text-muted)}.user-profile-modal__stats strong{color:var(--color-text)}.user-profile-modal__bio{font-size:var(--text-sm);color:var(--color-text-muted);margin:0 0 .75rem;line-height:1.4}.user-profile-modal__follow{width:100%;padding:.5rem;background:var(--color-primary);border:none;border-radius:var(--radius-md);color:#fff;font-weight:var(--font-semibold);font-size:var(--text-base);cursor:pointer;margin-bottom:.75rem}.user-profile-modal__follow--following{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border)}.user-profile-modal__follow:disabled{opacity:.5}.user-profile-modal__photos{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;margin-top:.5rem}.user-profile-modal__photo{aspect-ratio:1;overflow:hidden}.user-profile-modal__photo img{width:100%;height:100%;object-fit:cover}.feed-search{display:flex;align-items:center;position:relative}.feed-search__input{width:100%;height:44px;padding:0 .75rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background:transparent;color:var(--color-text);font-size:var(--text-base)}.feed-search__input::placeholder{color:var(--color-text-muted)}.feed-search__input:focus{outline:none;border-color:var(--color-secondary)}.feed-search__clear{position:absolute;right:.5rem;background:none;border:none;color:var(--color-text-muted);cursor:pointer;padding:.25rem;font-size:var(--text-sm)}.feed-active-filter{display:flex;align-items:center;gap:var(--spacing-sm)}.feed-active-filter__tag{background:var(--color-primary);color:#fff;padding:.25rem .625rem;border-radius:1rem;font-size:var(--text-sm);font-weight:var(--font-medium)}.feed-active-filter__profile{background:var(--color-primary);border:none;color:#fff;font-size:var(--text-sm);font-weight:var(--font-semibold);padding:.25rem .5rem;border-radius:var(--radius-sm);cursor:pointer}.feed-active-filter__clear{background:none;border:none;color:var(--color-text-muted);font-size:var(--text-sm);cursor:pointer;text-decoration:underline}.profile-screen{display:flex;flex-direction:column;gap:var(--spacing-xs)}.profile-screen__header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-xs)}.profile-screen__title{font-size:var(--text-xl);color:var(--color-text);margin:0;flex-grow:1}.profile-edit__save-btn{flex-shrink:0;margin-left:auto;flex:1}.profile-screen__actions{display:flex;gap:.5rem}.account-switcher-btn{display:flex;align-items:center;gap:.375rem;padding:.375rem .625rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;font-size:var(--text-sm);color:var(--color-text)}.account-switcher-btn:hover{border-color:var(--color-primary)}.account-switcher-btn__handle{max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.account-switcher-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:9999;display:flex;align-items:flex-start;justify-content:center;padding-top:10vh}.account-switcher{background:var(--color-bg);border-radius:var(--radius-lg);width:90%;max-width:320px;box-shadow:0 4px 20px #00000026;overflow:hidden}.account-switcher__header{display:flex;justify-content:space-between;align-items:center;padding:.875rem 1rem;border-bottom:1px solid var(--color-border)}.account-switcher__header h3{margin:0;font-size:var(--text-md);font-weight:var(--font-semibold);color:var(--color-text)}.account-switcher__close{background:none;border:none;color:var(--color-text-muted);cursor:pointer;font-size:var(--text-md);padding:.25rem}.account-switcher__list{padding:.5rem}.account-switcher__item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem;background:none;border:none;border-radius:var(--radius-md);cursor:pointer;text-align:left}.account-switcher__item:hover{background:var(--color-surface)}.account-switcher__item--current{background:var(--color-surface);cursor:default}.account-switcher__item-wrapper{display:flex;align-items:center;position:relative}.account-switcher__item-wrapper .account-switcher__item{flex:1}.account-switcher__remove{position:absolute;right:.5rem;background:none;border:none;color:var(--color-text-muted);font-size:var(--text-sm);cursor:pointer;padding:.5rem;opacity:.4;transition:opacity .15s}.account-switcher__remove:hover{opacity:1;color:var(--color-danger, #c0392b)}.account-switcher__icon{width:36px;height:36px;border-radius:50%;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:var(--font-semibold);font-size:var(--text-base);flex-shrink:0;overflow:hidden}.account-switcher__icon img{width:100%;height:100%;object-fit:cover}.account-switcher__info{flex:1;min-width:0}.account-switcher__name{display:block;font-size:var(--text-base);font-weight:var(--font-medium);color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.account-switcher__email{display:block;font-size:var(--text-sm);color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.account-switcher__check{color:var(--color-primary);font-weight:700}.account-switcher__footer{border-top:1px solid var(--color-border);padding:.5rem}.account-switcher__edit-profile,.account-switcher__add,.account-switcher__theme,.account-switcher__admin,.account-switcher__signout{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem;background:none;border:none;border-radius:var(--radius-md);cursor:pointer;text-align:left;font-size:var(--text-base);color:var(--color-text)}.account-switcher__edit-profile:hover,.account-switcher__add:hover,.account-switcher__theme:hover,.account-switcher__admin:hover,.account-switcher__signout:hover{background:var(--color-surface)}.account-switcher__theme{color:var(--color-text)}.account-switcher__admin{color:var(--color-primary)}.account-switcher__signout{color:var(--color-danger, #c0392b)}.account-switcher__password-form{padding:1rem}.account-switcher__password-label{font-size:var(--text-base);color:var(--color-text);margin-bottom:.75rem}.account-switcher__password-label strong{color:var(--color-primary)}.account-switcher__error{font-size:var(--text-sm);color:var(--color-danger, #c0392b);margin-bottom:.5rem}.account-switcher__password-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:.75rem}.account-switcher__cancel{background:none;border:none;color:var(--color-text-muted);cursor:pointer;font-size:var(--text-base);padding:.5rem .75rem}.account-switcher__cancel:hover{color:var(--color-text)}.account-switcher__google-option{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.625rem;margin-top:1rem;background:#fff;border:1px solid #dadce0;border-radius:var(--radius-md);font-size:var(--text-base);color:#3c4043;cursor:pointer}.account-switcher__google-option:hover{background:#f8f9fa}.account-switcher__google-option:disabled{opacity:.6;cursor:not-allowed}.profile-avatar{width:60px;height:60px;border-radius:50%;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:var(--text-2xl);font-weight:var(--font-semibold);overflow:hidden;cursor:pointer;position:relative;flex-shrink:0}.profile-avatar img{width:100%;height:100%;object-fit:cover}.profile-avatar--large{width:100px;height:100px;font-size:var(--text-4xl)}.profile-avatar__overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;font-size:var(--text-2xl);opacity:0;transition:opacity .15s ease}.profile-avatar:hover .profile-avatar__overlay{opacity:1}.profile-header-new{display:flex;flex-direction:column;gap:var(--spacing-md)}.profile-header-top{display:flex;align-items:flex-start;gap:var(--spacing-md)}.profile-avatar-compact{width:72px;height:72px;border-radius:50%;background:var(--color-surface);border:2px solid var(--color-border);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0;cursor:pointer}.profile-avatar-compact img{width:100%;height:100%;object-fit:cover}.profile-avatar-compact span{font-size:var(--text-2xl);font-weight:var(--font-semibold);color:var(--color-primary)}.profile-info{flex:1;display:flex;flex-direction:column;gap:4px}.profile-handle-row{display:flex;align-items:center;gap:var(--spacing-sm)}.profile-handle{font-size:var(--text-md);font-weight:var(--font-semibold);color:var(--color-text)}.profile-bio{font-size:var(--text-sm);color:var(--color-text-muted);margin:0;line-height:1.4}.profile-crafts{display:flex;gap:4px;margin-top:2px}.profile-craft-badge{font-size:var(--text-md)}.profile-time-stat{display:flex;flex-direction:column;align-items:flex-end;gap:2px;margin-left:auto;padding-left:var(--spacing-md)}.profile-time-stat__value{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--color-text)}.profile-time-stat__label{font-size:var(--text-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px}.profile-stats-row{display:flex;justify-content:space-between}.profile-edit-btn{height:16px;padding:0 6px;font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--color-text-muted);background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer}.profile-edit-btn:hover{background:var(--color-surface)}.profile-stat{display:flex;flex-direction:column;align-items:center;gap:0;flex:1;padding:4px 2px;border-radius:var(--radius-md)}.profile-stat--static{cursor:default}.profile-stat__value{font-size:var(--text-base);font-weight:var(--font-bold);color:var(--color-text)}.profile-stat__label{font-size:var(--text-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.02em}.tabs{display:flex;border-bottom:1px solid var(--color-border);margin-bottom:.5rem}.tabs.tabs--no-border{border-bottom:none;margin-bottom:0}.tab{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;background:none;border:none;padding:12px 0;font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-muted);cursor:pointer;border-bottom:2px solid var(--color-border);margin-bottom:-1px;transition:all .15s;font-family:inherit}.tab:hover{color:var(--color-text)}.tab--active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.tab svg{opacity:.7;flex-shrink:0}.tab--active svg{opacity:1}.tab__label{white-space:nowrap}.badge-count{font-size:var(--text-xs);font-weight:var(--font-semibold);background:var(--color-border);color:var(--color-primary);padding:2px 6px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;min-width:18px}.tab--active .badge-count{background:var(--color-border-strong)}.badge-count--locked{background:transparent;font-size:var(--text-sm);padding:0;min-width:auto}.project-badges{display:flex;flex-wrap:wrap;gap:6px}.project-badge{display:inline-flex;align-items:center;gap:3px;padding:3px 8px;font-size:var(--text-xs);font-weight:var(--font-medium);background:#8b451314;color:var(--color-text-muted);border-radius:var(--radius-sm);border:none;font-family:inherit;text-decoration:none;cursor:default;white-space:nowrap}.project-badge__icon{font-size:.85em}.project-badge__sub{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-primary);margin-left:4px;text-transform:uppercase}a.project-badge,button.project-badge{cursor:pointer;transition:all .15s ease}a.project-badge:hover,button.project-badge:hover{background:#8b451326;color:var(--color-text)}.project-badge--success{background:#2d6a4f1f;color:var(--color-success)}.project-badge--highlight{background:var(--color-surface);color:var(--color-primary)}.project-badge--urgent{background:var(--color-border);color:var(--color-primary);font-weight:var(--font-medium)}.project-badge--warning{background:var(--color-warning-bg);color:#8b6914}.profile-badges-section{padding:var(--spacing-sm) 0}.profile-badges-title{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text);margin-bottom:var(--spacing-sm)}button.profile-stat{background:none;border:none;font-family:inherit;cursor:pointer;transition:background .15s}button.profile-stat:hover:not(.profile-stat--static){background:var(--color-surface)}button.profile-stat:active:not(.profile-stat--static){background:var(--color-border)}.follow-list-page{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--color-bg);z-index:100;display:flex;flex-direction:column}.follow-list-page__header{display:flex;align-items:center;gap:12px;padding:16px;background:var(--color-bg)}.back-button{width:32px;height:32px;border-radius:50%;background:#fff;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--color-text);flex-shrink:0;transition:background .15s}.back-button:hover{background:var(--color-surface)}.back-button:active{background:var(--color-border)}.follow-list-page__title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--color-text)}.follow-list-page__content{flex:1;overflow-y:auto;padding:0 16px 16px}.follow-list-page__loading,.follow-list-page__empty{text-align:center;color:var(--color-text-muted);font-size:var(--text-base);padding:32px}.follow-list{display:flex;flex-direction:column;gap:8px}.follow-list__item{display:flex;align-items:center;gap:12px;padding:12px;background:#fff;border-radius:var(--radius-md);width:100%;border:none;text-align:left;font-family:inherit;cursor:pointer;transition:background .15s}.follow-list__item:hover{background:var(--color-surface)}.follow-list__arrow{margin-left:auto;color:var(--color-text-muted);flex-shrink:0}.follow-list__avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),#d4a5b3);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}.follow-list__avatar img{width:100%;height:100%;object-fit:cover}.follow-list__avatar span{color:#fff;font-weight:var(--font-semibold);font-size:var(--text-lg)}.follow-list__info{flex:1;min-width:0}.follow-list__handle{display:block;font-weight:var(--font-semibold);font-size:var(--text-base);color:var(--color-text);margin-bottom:2px}.follow-list__stats{display:flex;gap:6px;font-size:var(--text-sm);color:var(--color-text-muted)}.profile-photos-section{margin-top:var(--spacing-sm)}.profile-photos-empty{color:var(--color-text-muted);font-size:var(--text-sm);text-align:center;padding:var(--spacing-md)}.profile-feed-view{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--color-bg);z-index:9000;display:flex;flex-direction:column;align-items:center}.profile-feed-view__header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;padding-top:calc(env(safe-area-inset-top,0px) + .75rem);border-bottom:1px solid var(--color-border);flex-shrink:0;background:var(--color-background);width:100%;max-width:600px}.profile-feed-view__back{background:none;border:none;color:var(--color-text);cursor:pointer;padding:.25rem;display:flex;align-items:center}.profile-feed-view__title{font-size:var(--text-md);font-weight:var(--font-semibold);color:var(--color-text);margin:0}.profile-feed-view__content{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:var(--spacing-md);padding-bottom:calc(80px + env(safe-area-inset-bottom,0px));width:100%;max-width:600px}.profile-edit{display:flex;flex-direction:column;gap:var(--spacing-lg)}.profile-edit__avatar-section{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs)}.profile-edit__hint{font-size:var(--text-sm);color:var(--color-text-muted);margin:0}.profile-edit__field{display:flex;flex-direction:column;gap:.25rem}.profile-edit__label{font-size:var(--text-base);font-weight:var(--font-medium);color:var(--color-text)}.profile-edit__handle-input{display:flex;align-items:center}.profile-edit__handle-prefix{padding:.625rem .5rem .625rem .875rem;background:var(--color-surface);border:1px solid var(--color-border);border-right:none;border-radius:var(--radius-md) 0 0 var(--radius-md);color:var(--color-text-muted);font-weight:var(--font-medium)}.profile-edit__handle-input .form-input{border-radius:0 var(--radius-md) var(--radius-md) 0;padding-left:.5rem}.profile-edit__error{font-size:var(--text-sm);color:#ef4444;margin:0}.profile-edit__char-count{font-size:var(--text-sm);color:var(--color-text-muted);margin:0;text-align:right}.profile-edit__crafts{display:flex;flex-wrap:wrap;gap:.5rem}.profile-craft-tag{display:flex;align-items:center;gap:.25rem;padding:.375rem .625rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:2rem;font-size:var(--text-sm);color:var(--color-text);cursor:pointer;transition:all .15s ease}.profile-craft-tag:hover{border-color:var(--color-primary)}.profile-craft-tag--selected{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.profile-section{margin-top:var(--spacing-lg)}.profile-section__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm)}.profile-section__title{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--color-text);margin:0}.profile-section__count{font-size:var(--text-base);color:var(--color-text-muted)}.profile-section__empty{color:var(--color-text-muted);font-size:var(--text-base);text-align:center;padding:var(--spacing-lg);background:var(--color-surface);border-radius:var(--radius-md);border:1px dashed var(--color-border)}.profile-loading,.profile-empty{text-align:center;padding:var(--spacing-lg);color:var(--color-text-muted);font-size:var(--text-base)}.profile-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-xs)}.profile-photo{aspect-ratio:1;border-radius:var(--radius-sm);overflow:hidden;cursor:pointer}.profile-photo__img{width:100%;height:100%;object-fit:cover}.profile-photos-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px}.profile-photo-square{position:relative;aspect-ratio:1;overflow:hidden;cursor:pointer;background:var(--color-surface)}.profile-photo-square img{width:100%;height:100%;object-fit:cover}.profile-photo-square:active{opacity:.7}.photo-source-picker-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:200;padding:var(--spacing-md)}.photo-source-picker{width:100%;max-width:320px;background:var(--color-bg);border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column;box-shadow:0 8px 32px #0003}.photo-source-option{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);background:none;border:none;border-bottom:1px solid var(--color-border);color:var(--color-text);font-size:var(--text-md);cursor:pointer;transition:background .15s ease}.photo-source-option:hover{background:#0000000d}.photo-source-option svg{color:var(--color-primary)}.photo-source-cancel{padding:var(--spacing-md) var(--spacing-lg);background:none;border:none;color:var(--color-text-muted);font-size:var(--text-md);font-weight:var(--font-medium);cursor:pointer;transition:background .15s ease}.photo-source-cancel:hover{background:#0000000d}.dashboard-screen{display:block}.dashboard-loading{text-align:center;padding:3rem;color:var(--color-text-muted)}.dashboard-time-card{display:flex;align-items:center;gap:16px;padding:16px 20px;background:linear-gradient(135deg,var(--color-border),var(--color-surface));border:1px solid var(--color-border-strong);border-radius:var(--radius-md);margin-bottom:16px}.dashboard-time-card__icon{font-size:var(--text-2xl)}.dashboard-time-card__stats{display:flex;align-items:center;gap:24px;flex:1}.dashboard-time-card__stat{display:flex;flex-direction:column;gap:0}.dashboard-time-card__value{font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--color-text);line-height:1.2}.dashboard-time-card__exact{font-size:var(--text-xs);color:var(--color-text-muted);opacity:.7}.dashboard-time-card__label{font-size:var(--text-sm);color:var(--color-text-muted);margin-top:2px}.dashboard-time-card__divider{width:1px;height:36px;background:var(--color-border-strong)}.dashboard-section{background:var(--color-surface);border-radius:var(--radius-md);padding:16px;margin-bottom:16px}.dashboard-section__title{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.03em;margin-bottom:12px}.weekly-chart{width:100%}.weekly-chart__bars{display:flex;align-items:flex-end;justify-content:space-between;height:100px;gap:4px}.weekly-chart__bar-container{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%}.weekly-chart__bar{width:100%;background:linear-gradient(to top,var(--color-primary),rgba(139,41,66,.7));border-radius:4px 4px 0 0;min-height:2px;display:flex;align-items:flex-start;justify-content:center;position:relative;transition:height .3s ease}.weekly-chart__bar-value{font-size:var(--text-xs);font-weight:var(--font-semibold);color:#fff;padding:2px;white-space:nowrap;position:absolute;top:2px}.weekly-chart__label{font-size:var(--text-xs);color:var(--color-text-muted);margin-top:6px}.activity-calendar{width:100%}.activity-calendar__title-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-sm)}.activity-calendar__title-row .dashboard-section__title{margin-bottom:0}.activity-calendar__crafted-stat{font-size:var(--text-sm);color:var(--color-text-secondary);font-weight:var(--font-medium)}.activity-calendar__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.activity-calendar__nav{background:none;border:none;color:var(--color-text-muted);cursor:pointer;padding:4px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;transition:all .15s}.activity-calendar__nav:hover:not(:disabled){color:var(--color-primary);background:var(--color-surface)}.activity-calendar__nav:disabled{opacity:.3;cursor:not-allowed}.activity-calendar__month{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--color-text)}.activity-calendar__weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:4px}.activity-calendar__weekday{text-align:center;font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--color-text-muted);text-transform:uppercase}.activity-calendar__grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.activity-calendar__day{aspect-ratio:1;border-radius:4px;display:flex;align-items:center;justify-content:center;position:relative}.activity-calendar__day--empty{background:transparent}.activity-calendar__day-num{font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--color-text)}.activity-calendar__day .activity-calendar__deadline-dot{position:absolute;bottom:6px;left:50%;transform:translate(-50%);width:5px;height:5px;background:var(--color-primary);border-radius:50%}.activity-calendar__day--has-deadline{cursor:pointer}.activity-calendar__tooltip{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:var(--color-text);color:#fff;padding:8px 12px;border-radius:var(--radius-md);font-size:var(--text-xs);white-space:nowrap;z-index:100;box-shadow:0 4px 12px #00000026}.activity-calendar__tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:var(--color-text)}.activity-calendar__tooltip-title{font-weight:var(--font-semibold);margin-bottom:4px;color:#ffffffb3}.activity-calendar__tooltip-item{padding:2px 0}.activity-calendar__day--0{background:var(--color-surface)}.activity-calendar__day--1{background:var(--color-border-strong)}.activity-calendar__day--1 .activity-calendar__day-num{color:var(--color-text)}.activity-calendar__day--2{background:#8b294273}.activity-calendar__day--2 .activity-calendar__day-num{color:#fff}.activity-calendar__day--3{background:#8b2942b3}.activity-calendar__day--3 .activity-calendar__day-num{color:#fff}.activity-calendar__day--4{background:var(--color-primary)}.activity-calendar__day--4 .activity-calendar__day-num{color:#fff}.activity-calendar__day--today{outline:2px solid var(--color-primary);outline-offset:1px}.activity-calendar__footer{display:flex;justify-content:space-between;align-items:center;margin-top:12px}.activity-calendar__legends{display:flex;align-items:center;gap:16px}.activity-calendar__legend{display:flex;flex-direction:row;align-items:center;gap:4px;font-size:var(--text-xs);color:var(--color-text-secondary)}.activity-calendar__month-stats{display:flex;gap:12px;align-items:center}.activity-calendar__legend-labels{display:none}.activity-calendar__legend-boxes{display:flex;gap:2px}.activity-calendar__legend-label{font-size:var(--text-xs);color:var(--color-text-secondary)}.activity-calendar__legend-box{width:12px;height:12px;border-radius:2px}.activity-calendar__legend--deadline{flex-direction:row;align-items:center;gap:4px}.activity-calendar__deadline-dot{width:6px;height:6px;background:var(--color-primary);border-radius:50%;flex-shrink:0}.activity-calendar__month-total,.activity-calendar__month-deadlines{font-size:var(--text-sm);color:var(--color-text-secondary);font-weight:var(--font-medium)}.activity-calendar__month-deadlines{color:var(--color-primary)}.craft-chart{display:flex;flex-direction:column;align-items:center;gap:12px}.craft-chart__empty{text-align:center;color:var(--color-text-muted);font-size:var(--text-base);padding:20px}.craft-chart__donut{position:relative;width:100px;height:100px;flex-shrink:0}.craft-chart__donut svg{width:100%;height:100%}.craft-chart__center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;display:flex;flex-direction:column}.craft-chart__center-value{font-size:var(--text-base);font-weight:var(--font-bold);color:var(--color-text);line-height:1.1}.craft-chart__center-label{font-size:var(--text-xs);color:var(--color-text-muted)}.craft-chart__legend{display:flex;flex-wrap:wrap;justify-content:center;gap:8px 16px}.craft-chart__legend-item{display:flex;align-items:center;gap:4px;font-size:var(--text-sm)}.craft-chart__legend-color{width:10px;height:10px;border-radius:2px;flex-shrink:0}.craft-chart__legend-icon{font-size:var(--text-base)}.craft-chart__legend-label{flex:1;color:var(--color-text)}.craft-chart__legend-value{font-weight:var(--font-semibold);color:var(--color-text)}.craft-chart__legend-percent{display:none}.completion-chart{width:100%}.completion-chart__empty{text-align:center;color:var(--color-text-muted);font-size:var(--text-base);padding:20px}.completion-chart--minimal{display:flex;align-items:center;justify-content:center;padding:24px}.completion-chart__stat{text-align:center}.completion-chart__stat-value{font-size:var(--text-4xl);font-weight:var(--font-bold);color:var(--color-primary);line-height:1;display:block}.completion-chart__stat-label{font-size:var(--text-sm);color:var(--color-text-muted);margin-top:4px}.completion-chart__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.completion-chart__title{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.03em;margin:0}.completion-chart__toggle{display:flex;gap:4px}.completion-chart__toggle-btn{padding:4px 10px;font-size:var(--text-sm);border:none;background:var(--color-surface);color:var(--color-text-muted);border-radius:12px;cursor:pointer;transition:all .15s ease}.completion-chart__toggle-btn--active{background:var(--color-primary);color:#fff}.completion-chart__graph{position:relative;height:80px;margin-bottom:6px}.completion-chart__graph svg{width:100%;height:100%}.completion-chart__markers{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none}.completion-chart__marker{position:absolute;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center}.completion-chart__marker-dot{width:6px;height:6px;background:var(--color-primary);border-radius:50%}.completion-chart__marker-value{position:absolute;bottom:100%;margin-bottom:4px;font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--color-primary);white-space:nowrap}.completion-chart__marker-value:empty,.completion-chart__marker-value--zero{display:none}.completion-chart__labels{display:flex;justify-content:space-between}.completion-chart__label{font-size:var(--text-xs);color:var(--color-text-muted);text-align:center}.completion-chart__label:first-child{text-align:left}.completion-chart__label:last-child{text-align:right}.project-overview{width:100%}.project-overview__metrics{display:flex;justify-content:space-between;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--color-border)}.project-overview__metric{display:flex;flex-direction:column;align-items:center;flex:1}.project-overview__metric-value{font-size:var(--text-2xl);font-weight:var(--font-semibold);color:var(--color-text)}.project-overview__metric-label{font-size:var(--text-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px}.status-overview{width:100%}.status-overview__empty{text-align:center;color:var(--color-text-muted);font-size:var(--text-base);padding:20px}.status-overview__bar{display:flex;height:12px;border-radius:6px;overflow:hidden;margin-bottom:16px}.status-overview__total{display:flex;align-items:baseline;justify-content:center;gap:6px;margin-bottom:12px}.status-overview__total-value{font-size:var(--text-3xl);font-weight:var(--font-bold);color:var(--color-text)}.status-overview__total-label{font-size:var(--text-base);color:var(--color-text-muted)}.status-overview__segment{transition:width .3s ease}.status-overview__segment:first-child{border-radius:6px 0 0 6px}.status-overview__segment:last-child{border-radius:0 6px 6px 0}.status-overview__segment:only-child{border-radius:6px}.status-overview__legend{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.status-overview__item{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--color-surface);border-radius:var(--radius-md)}.status-overview__color{width:10px;height:10px;border-radius:3px;flex-shrink:0}.status-overview__count{font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--color-text)}.status-overview__label{font-size:var(--text-sm);color:var(--color-text-muted)}.badges-display{width:100%}.badges-filters{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:16px}.badges-filter{display:flex;align-items:center;gap:3px;background:var(--color-surface);border:1px solid var(--color-surface);border-radius:16px;padding:4px 8px;font-size:var(--text-sm);color:var(--color-text-muted);cursor:pointer;transition:all .15s}.badges-filter:hover{border-color:var(--color-primary)}.badges-filter--active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.badges-filter__count{font-size:var(--text-xs);opacity:.8}.badges-grid{display:flex;flex-direction:column;gap:16px}.badges-category-section{margin-bottom:4px}.badges-section-title{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.03em;margin-bottom:8px}.badges-list{display:grid;grid-template-columns:1fr 1fr;gap:6px}.badge-card{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--radius-md);border:none;cursor:pointer;text-align:left;width:100%;transition:transform .15s,background .15s}.badge-card:active{transform:scale(.98)}.badge-card--earned{background:linear-gradient(135deg,var(--color-border),var(--color-surface))}.badge-card--locked{background:#00000008}.badge-card__icon{font-size:var(--text-lg);flex-shrink:0;width:24px;text-align:center}.badge-card__name{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text);flex:1;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.badge-card--locked .badge-card__name{color:var(--color-text-muted)}.badge-detail{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.badge-detail__card{background:#fff;border-radius:var(--radius-md);padding:24px;text-align:center;max-width:280px;width:100%;position:relative}.badge-detail__icon{font-size:var(--text-5xl);display:block;margin-bottom:12px}.badge-detail__name{font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--color-text);margin-bottom:4px}.badge-detail__description{font-size:var(--text-base);color:var(--color-text-muted);margin-bottom:12px}.badge-detail__date{font-size:var(--text-sm);color:var(--color-primary);font-weight:var(--font-medium)}.badge-detail__locked{font-size:var(--text-sm);color:var(--color-text-muted);font-style:italic}.badge-detail__close{position:absolute;top:8px;right:8px;background:none;border:none;font-size:var(--text-md);color:var(--color-text-muted);cursor:pointer}.badges-compact{display:flex;flex-direction:column;align-items:center;gap:8px}.badges-compact__row{display:flex;gap:4px;align-items:center}.badges-compact__badge{font-size:var(--text-xl)}.badges-compact__more{font-size:var(--text-sm);color:var(--color-text-muted);background:var(--color-surface);padding:2px 6px;border-radius:10px}.badges-compact__view-all{background:none;border:none;font-size:var(--text-sm);color:var(--color-primary);cursor:pointer;text-decoration:underline}.badge-notification{position:fixed;top:20px;left:50%;transform:translate(-50%);z-index:1001;animation:badgeSlideIn .4s ease-out}@keyframes badgeSlideIn{0%{opacity:0;transform:translate(-50%) translateY(-20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.badge-notification__content{display:flex;align-items:center;gap:12px;background:linear-gradient(135deg,#8b2942,#6b1f32);color:#fff;padding:12px 16px;border-radius:var(--radius-md);box-shadow:0 4px 20px #8b294266}.badge-notification__icon{font-size:var(--text-3xl)}.badge-notification__text{display:flex;flex-direction:column}.badge-notification__label{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em;opacity:.9}.badge-notification__name{font-size:var(--text-md);font-weight:var(--font-bold)}.badge-notification__close{background:none;border:none;color:#fff;opacity:.7;cursor:pointer;font-size:var(--text-md);padding:4px}.badge-notification__close:hover{opacity:1}.progress-reminder{position:fixed;bottom:80px;left:16px;right:16px;background:#fffffff2;border:1px solid var(--color-border-strong);border-radius:var(--radius-md);padding:12px 16px;display:flex;align-items:center;box-shadow:0 4px 12px #0000001a;justify-content:space-between;gap:12px;box-shadow:0 4px 20px #00000026;z-index:1000;animation:slideUp .3s ease-out}.progress-reminder--exiting{animation:slideDown .3s ease-out forwards}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(20px)}}.progress-reminder__content{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.progress-reminder__icon{font-size:var(--text-2xl);flex-shrink:0}.progress-reminder__text{display:flex;flex-direction:column;gap:2px;min-width:0}.progress-reminder__title{font-weight:var(--font-semibold);font-size:var(--text-base);color:var(--color-text)}.progress-reminder__subtitle{font-size:var(--text-sm);color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.progress-reminder__actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.progress-reminder__btn{display:flex;align-items:center;justify-content:center;gap:6px;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease}.progress-reminder__btn--photo{background:var(--color-primary);color:#fff;padding:8px 14px;font-size:var(--text-base);font-weight:var(--font-medium)}.progress-reminder__btn--photo:hover{background:var(--color-primary-dark)}.progress-reminder__btn--dismiss{background:transparent;color:var(--color-text-muted);padding:6px;width:28px;height:28px}.progress-reminder__btn--dismiss:hover{background:#0000000d;color:var(--color-text)}.admin-screen{padding-bottom:100px}.admin-screen__header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.admin-screen__header h1{margin:0;font-size:var(--text-2xl)}.admin-section{padding:0}.admin-section h3{margin:0 0 var(--spacing-sm) 0;font-size:var(--text-base);font-weight:var(--font-semibold)}.admin-screen__search{margin-bottom:var(--spacing-md)}.admin-screen__stats{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.admin-stat{flex:1;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md);text-align:center}.admin-stat__value{display:block;font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--color-text)}.admin-stat__label{font-size:var(--text-sm);color:var(--color-text-muted)}.admin-screen__loading,.admin-screen__error{text-align:center;padding:var(--spacing-xl);color:var(--color-text-muted)}.admin-screen__error p:first-child{font-size:var(--text-3xl);margin-bottom:var(--spacing-sm)}.admin-user-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.admin-user-card{display:flex;align-items:flex-start;gap:var(--spacing-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md)}.admin-user-card__avatar{width:40px;height:40px;border-radius:50%;background:var(--color-border);display:flex;align-items:center;justify-content:center;font-weight:var(--font-semibold);color:var(--color-text-muted);overflow:hidden;flex-shrink:0}.admin-user-card__avatar img{width:100%;height:100%;object-fit:cover}.admin-user-card__info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.admin-user-card__handle{font-weight:var(--font-semibold);color:var(--color-text);font-size:var(--text-base)}.admin-user-card__name{font-size:var(--text-sm);color:var(--color-text-muted)}.admin-user-card__id{font-size:var(--text-xs);color:var(--color-text-muted);opacity:.7;font-family:monospace;word-break:break-all}.admin-user-card__header{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.admin-user-card__actions{display:flex;flex-direction:column;gap:6px;flex-shrink:0}.admin-badge{display:inline-block;padding:4px 8px;border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--font-medium)}.admin-badge--premium{background:linear-gradient(135deg,var(--color-border),var(--color-surface));color:var(--color-primary)}.admin-badge--free{background:var(--color-border);color:var(--color-text-muted)}.admin-edit-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.admin-edit-form__user{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md)}.admin-edit-form__id{font-size:var(--text-sm);color:var(--color-text-muted);font-family:monospace;word-break:break-all}.admin-edit-form__actions{display:flex;gap:var(--spacing-sm);justify-content:flex-end;margin-top:var(--spacing-md)}.admin-tab-content{display:flex;flex-direction:column;gap:var(--spacing-lg);padding-top:var(--spacing-md)}.admin-stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-sm)}.admin-stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-lg) var(--spacing-md);text-align:center}.admin-stat-card--highlight{background:#22c55e26;border-color:#22c55e66}.admin-stat-card--active{background:#3b82f626;border-color:#3b82f666}.admin-stat-card--time{background:var(--color-border);border-color:#8b294266}.admin-stat-card__value{display:block;font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--color-text);margin-bottom:4px;background:none}.admin-stat-card__label{font-size:var(--text-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;background:none}.admin-craft-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.admin-craft-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm)}.admin-craft-item__icon{font-size:var(--text-lg);width:28px;text-align:center}.admin-craft-item__name{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text);min-width:80px}.admin-craft-item__bar{flex:1;height:8px;background:var(--color-border);border-radius:4px;overflow:hidden}.admin-craft-item__fill{height:100%;background:linear-gradient(90deg,var(--color-primary),var(--color-secondary));border-radius:4px;transition:width .3s ease}.admin-craft-item__count{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text);min-width:30px;text-align:right}.admin-craft-item__percent{font-size:var(--text-xs);color:var(--color-text-muted);min-width:35px;text-align:right}.admin-type-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-sm)}.admin-type-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md);text-align:center;display:flex;flex-direction:column;align-items:center;gap:4px}.admin-type-card__icon{font-size:var(--text-xl)}.admin-type-card__value{font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--color-text)}.admin-type-card__label{font-size:var(--text-xs);color:var(--color-text-muted)}.admin-leaderboard{display:flex;flex-direction:column;gap:var(--spacing-xs)}.admin-leaderboard__item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm)}.admin-leaderboard__rank{font-size:var(--text-lg);width:28px;text-align:center}.admin-leaderboard__avatar{width:32px;height:32px;border-radius:50%;background:var(--color-border);display:flex;align-items:center;justify-content:center;overflow:hidden;font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text-muted)}.admin-leaderboard__avatar img{width:100%;height:100%;object-fit:cover}.admin-leaderboard__name{flex:1;font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text)}.admin-leaderboard__value{font-size:var(--text-sm);color:var(--color-text-muted);font-weight:var(--font-medium)}.admin-activity-list{display:flex;flex-direction:column;gap:var(--spacing-xs)}.admin-activity-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm)}.admin-activity-item__avatar{width:32px;height:32px;border-radius:50%;background:var(--color-border);display:flex;align-items:center;justify-content:center;overflow:hidden;font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text-muted)}.admin-activity-item__avatar img{width:100%;height:100%;object-fit:cover}.admin-activity-item__info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.admin-activity-item__name{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-activity-item__detail{font-size:var(--text-xs);color:var(--color-text-muted)}.admin-activity-item__time{font-size:var(--text-xs);color:var(--color-text-muted);white-space:nowrap}.admin-tools-grid{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.admin-tool-btn{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease}.admin-tool-btn:hover:not(:disabled){background:var(--color-bg);border-color:var(--color-primary)}.admin-tool-btn:disabled{opacity:.5;cursor:not-allowed}.admin-tool-btn--danger{border-color:#ef44444d}.admin-tool-btn--danger:hover:not(:disabled){background:#ef44441a;border-color:#ef444480}.admin-tool-btn__icon{font-size:var(--text-xl)}.admin-tool-btn__text{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text)}.admin-flags-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.admin-flag-item{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md)}.admin-flag-item--danger{border-color:#ef44444d;background:#ef44440d}.admin-flag-item__info{flex:1;display:flex;flex-direction:column;gap:2px}.admin-flag-item__name{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text)}.admin-flag-item__desc{font-size:var(--text-xs);color:var(--color-text-muted)}.admin-flag-toggle{position:relative;width:44px;height:24px;background:none;border:none;padding:0;cursor:pointer}.admin-flag-toggle__track{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--color-border);border-radius:12px;transition:background .2s ease}.admin-flag-toggle--on .admin-flag-toggle__track{background:var(--color-primary)}.admin-flag-toggle--danger .admin-flag-toggle__track{background:#ef4444}.admin-flag-toggle__thumb{position:absolute;top:2px;left:2px;width:20px;height:20px;background:#fff;border-radius:50%;transition:transform .2s ease;box-shadow:0 1px 3px #0003}.admin-flag-toggle--on .admin-flag-toggle__thumb{transform:translate(20px)}.admin-summary{display:flex;flex-direction:column;gap:var(--spacing-xs)}.admin-summary__row{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) var(--spacing-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--text-sm)}.admin-summary__row span{color:var(--color-text-muted)}.admin-summary__row strong{color:var(--color-text);font-weight:var(--font-semibold)}.admin-section--danger{background:#ef44440d;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-md);padding:var(--spacing-md)}.admin-section__desc{font-size:var(--text-sm);color:var(--color-text-muted);margin:0 0 var(--spacing-sm) 0}.admin-empty{text-align:center;padding:var(--spacing-lg);color:var(--color-text-muted);font-size:var(--text-sm)}.admin-shared-list{display:flex;flex-direction:column;gap:var(--spacing-xs)}.admin-shared-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md)}.admin-shared-item__preview{width:48px;height:48px;border-radius:var(--radius-sm);overflow:hidden;background:var(--color-bg);display:flex;align-items:center;justify-content:center;flex-shrink:0}.admin-shared-item__preview img{width:100%;height:100%;object-fit:cover}.admin-shared-item__preview span{font-size:1.5rem}.admin-shared-item__info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.admin-shared-item__project{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-shared-item__user{font-size:var(--text-xs);color:var(--color-primary)}.admin-shared-item__date{font-size:var(--text-xs);color:var(--color-text-muted)}.admin-shared-item__delete{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#ef44441a;border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-sm);cursor:pointer;font-size:1rem;transition:all .15s ease;flex-shrink:0}.admin-shared-item__delete:hover{background:#ef444433;border-color:#ef444466}.admin-shared-item__delete:disabled{opacity:.5;cursor:not-allowed}.admin-loading-spinner{width:24px;height:24px;border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:admin-spin .8s linear infinite;margin:0 auto var(--spacing-sm)}@keyframes admin-spin{to{transform:rotate(360deg)}}.profile-admin-link{margin-top:var(--spacing-xl);padding-top:var(--spacing-lg);border-top:1px solid var(--color-border);text-align:center}.profile-admin-link button{background:none;border:none;color:var(--color-text-muted);font-size:var(--text-base);cursor:pointer;padding:var(--spacing-sm) var(--spacing-md);opacity:.7;transition:opacity .15s ease}.profile-admin-link button:hover{opacity:1}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000;padding:var(--spacing-md)}.upgrade-prompt{display:flex;align-items:center;justify-content:center;min-height:60vh;padding:var(--spacing-md)}.upgrade-prompt__card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-xl);max-width:360px;text-align:center}.upgrade-prompt__icon{font-size:var(--text-5xl);margin-bottom:var(--spacing-md)}.upgrade-prompt__title{font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--color-text);margin:0 0 var(--spacing-sm) 0}.upgrade-prompt__description{font-size:var(--text-base);color:var(--color-text-muted);margin:0 0 var(--spacing-lg) 0;line-height:1.5}.upgrade-prompt__features{text-align:left;margin-bottom:var(--spacing-lg)}.upgrade-prompt__feature{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs) 0;font-size:var(--text-base);color:var(--color-text)}.upgrade-prompt__check{color:var(--color-primary);font-weight:var(--font-semibold)}.upgrade-prompt__actions{display:flex;flex-direction:column;gap:var(--spacing-sm)}.upgrade-prompt__later{background:none;border:none;color:var(--color-text-muted);font-size:var(--text-base);cursor:pointer;padding:var(--spacing-sm)}.upgrade-prompt__later:hover{color:var(--color-text)}.upgrade-prompt-inline{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:linear-gradient(135deg,var(--color-surface),rgba(139,41,66,.04));border:1px solid var(--color-border);border-radius:var(--radius-md);margin-bottom:var(--spacing-md)}.upgrade-prompt-inline__icon{font-size:var(--text-2xl)}.upgrade-prompt-inline__content{flex:1;display:flex;flex-direction:column;gap:2px}.upgrade-prompt-inline__title{font-weight:var(--font-semibold);font-size:var(--text-base);color:var(--color-text)}.upgrade-prompt-inline__text{font-size:var(--text-sm);color:var(--color-text-muted)}.project-limit-banner{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:#ffc1071a;border:1px solid rgba(255,193,7,.3);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);font-size:var(--text-base)}.project-limit-banner--full{background:var(--color-surface);border-color:var(--color-border-strong)}.project-limit-banner__icon{flex-shrink:0}.project-limit-banner__text{flex:1;color:var(--color-text)}.project-limit-banner__upgrade{background:none;border:none;color:var(--color-primary);font-weight:var(--font-semibold);font-size:var(--text-base);cursor:pointer;padding:4px 8px}.project-limit-banner__upgrade:hover{text-decoration:underline}.dashboard-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:24px}.stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:16px;display:flex;align-items:center;gap:12px}.stat-card__icon{font-size:var(--text-2xl)}.stat-card__content{display:flex;flex-direction:column;gap:2px}.stat-card__value{font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--color-text)}.stat-card__label{font-size:var(--text-sm);color:var(--color-text-muted)}.dashboard-section{margin-bottom:24px}.dashboard-section:last-child{margin-bottom:0}.dashboard-section__subtitle{font-size:var(--text-sm);color:var(--color-text-secondary);margin:-4px 0 8px}.dashboard-projects{display:flex;flex-direction:column;gap:8px}.dashboard-project-card{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease;text-align:left;width:100%}.dashboard-project-card:hover{background:var(--color-surface-elevated);border-color:var(--color-border-strong)}.dashboard-project-card--stalled{opacity:.7}.dashboard-project-card__icon{font-size:var(--text-xl)}.dashboard-project-card__info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.dashboard-project-card__name{font-size:var(--text-base);font-weight:var(--font-medium);color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dashboard-project-card__meta{display:flex;align-items:center;gap:8px;font-size:var(--text-sm);color:var(--color-text-secondary)}.dashboard-project-card__time,.dashboard-project-card__deadline{color:var(--color-text-secondary)}.dashboard-project-card__deadline--urgent{color:var(--color-primary);font-weight:var(--font-medium)}.dashboard-project-card__arrow{color:var(--color-text-secondary);flex-shrink:0}.dashboard-crafts-row{display:flex;gap:16px;align-items:flex-start}.dashboard-crafts-chart{flex:1;min-width:0}.dashboard-crafts{display:flex;flex-direction:column;gap:8px;flex:1}.dashboard-craft{display:flex;align-items:center;gap:6px;padding:8px 12px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md)}.dashboard-craft__icon{font-size:var(--text-md)}.dashboard-craft__label{font-size:var(--text-base);font-weight:var(--font-medium);color:var(--color-text)}.dashboard-craft__count{font-size:var(--text-sm);color:var(--color-text-muted)}.dashboard-empty{text-align:center;padding:3rem;color:var(--color-text-muted)}.dashboard-empty p{margin-bottom:1rem}.share-project-screen{padding-bottom:var(--spacing-lg)}.share-project-header{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) 0}.share-project-header__title{flex:1;font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--color-text);margin:0}.share-project-loading{text-align:center;padding:3rem;color:var(--color-text-muted)}.share-project-content{display:flex;flex-direction:column;gap:var(--spacing-lg)}.share-project-section{display:flex;flex-direction:column;gap:var(--spacing-sm)}.share-project-section__title{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--color-text);margin:0}.share-project-info{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md)}.share-project-info__icon{font-size:var(--text-2xl)}.share-project-info__name{font-size:var(--text-md);font-weight:var(--font-semibold);color:var(--color-text)}.share-project-hint{font-size:var(--text-sm);color:var(--color-text-muted);margin:0}.share-project-empty{font-size:var(--text-base);color:var(--color-text-muted);padding:1rem;text-align:center;background:#ffffff4d;border-radius:var(--radius-md)}.share-project-photos{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.share-project-photo{position:relative;aspect-ratio:1;border-radius:var(--radius-md);overflow:hidden;cursor:pointer;opacity:.5;border:2px solid transparent;transition:all .15s ease}.share-project-photo img{width:100%;height:100%;object-fit:cover}.share-project-photo--selected{opacity:1;border-color:var(--color-primary)}.share-project-photo--thumbnail{border-color:var(--color-secondary)}.share-project-photo__check{position:absolute;top:4px;right:4px;width:20px;height:20px;background:var(--color-primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:var(--text-sm);font-weight:700}.share-project-photo__badge{position:absolute;bottom:4px;left:4px;padding:2px 6px;background:var(--color-secondary);color:#fff;border-radius:4px;font-size:var(--text-xs);font-weight:var(--font-semibold);text-transform:uppercase}.share-project-details{display:flex;flex-direction:column;gap:var(--spacing-sm);padding:.75rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md)}.share-project-textarea{min-height:80px;resize:vertical}.share-project-actions{padding-top:var(--spacing-md)}.photo-carousel{position:relative;width:100%;aspect-ratio:1;background:var(--color-surface)}.photo-carousel__image{width:100%;height:100%;cursor:pointer}.photo-carousel__image img{width:100%;height:100%;object-fit:cover}.photo-carousel__nav{position:absolute;top:50%;transform:translateY(-50%);width:36px;height:36px;border-radius:50%;background:#00000080;border:none;color:#fff;cursor:pointer;opacity:1;display:flex;align-items:center;justify-content:center;z-index:2}.photo-carousel__nav--prev{left:8px}.photo-carousel__nav--next{right:8px}.photo-carousel__nav:hover{background:#0009}.photo-carousel__dots{position:absolute;bottom:12px;left:50%;transform:translate(-50%);display:flex;gap:6px}.photo-carousel__dot{width:6px;height:6px;border-radius:50%;background:var(--color-surface);border:none;padding:0;cursor:pointer;transition:all .15s ease}.photo-carousel__dot--active{background:#fff;transform:scale(1.2)}.photo-carousel__counter{position:absolute;top:12px;right:12px;padding:4px 8px;background:#00000080;color:#fff;font-size:var(--text-sm);border-radius:10px}.profile-project__indicator{position:absolute;top:8px;right:8px;display:flex;align-items:center;gap:2px;padding:4px 6px;background:#0009;color:#fff;font-size:var(--text-xs);font-weight:var(--font-semibold);border-radius:4px}.profile-project__indicator svg{width:12px;height:12px}[data-theme=dark] .tab-bar{background:var(--color-bg-secondary);border-top-color:var(--color-border)}[data-theme=dark] .form-input,[data-theme=dark] .section-textarea{background:var(--color-surface);border-color:var(--color-border);color:var(--color-text)}[data-theme=dark] .form-input::placeholder,[data-theme=dark] .section-textarea::placeholder{color:var(--color-text-tertiary)}[data-theme=dark] .section-card,[data-theme=dark] .project-card,[data-theme=dark] .card,[data-theme=dark] .dashboard-card,[data-theme=dark] .dashboard-section{background:var(--color-surface);border-color:var(--color-border)}[data-theme=dark] .stat-card,[data-theme=dark] .status-card{background:var(--color-surface-elevated)}[data-theme=dark] .dropdown__menu{background:var(--color-surface-elevated);border-color:var(--color-border)}[data-theme=dark] .dropdown__option:hover{background:#d87a921a}[data-theme=dark] .project-badge,[data-theme=dark] .badge-pill{background:var(--color-surface-elevated);color:var(--color-text-secondary)}[data-theme=dark] .project-badge--success{background:var(--color-status-success-bg);color:var(--color-status-success-text)}[data-theme=dark] .project-badge--warning{background:var(--color-status-warning-bg);color:var(--color-status-warning-text)}[data-theme=dark] .project-badge--urgent{background:var(--color-status-error-bg);color:var(--color-status-error-text)}[data-theme=dark] .feed-post,[data-theme=dark] .feed-post__header{background:var(--color-surface)}[data-theme=dark] .feed-search{background:var(--color-surface-elevated);border-color:var(--color-border)}[data-theme=dark] .feed-search__input{background:transparent}[data-theme=dark] .time-summary{background:var(--color-surface-elevated)}[data-theme=dark] .dashboard-section__card{background:var(--color-surface)}[data-theme=dark] .progress-bar__track{background:var(--color-surface-elevated)}[data-theme=dark] .tab{color:var(--color-text-secondary)}[data-theme=dark] .tab--active{color:var(--color-text)}[data-theme=dark] .profile-stat,[data-theme=dark] .profile-craft-badge{background:transparent}[data-theme=dark] .timer{background:var(--color-surface);border-color:var(--color-border)}[data-theme=dark] .timer--running{background:#d87a921a;border-color:var(--color-primary)}[data-theme=dark] .header-timer{background:var(--color-surface);border-color:var(--color-border)}[data-theme=dark] .header-timer__picker{background:var(--color-surface-elevated);border-color:var(--color-border)}[data-theme=dark] .header-timer__picker-item:hover{background:#d87a921a}[data-theme=dark] .account-switcher{background:var(--color-surface-elevated)}[data-theme=dark] .page-header__account{background:var(--color-surface);border-color:var(--color-border)}[data-theme=dark] .page-header__account:hover{background:var(--color-surface-elevated)}[data-theme=dark] .date-picker__trigger{background:var(--color-surface);border-color:var(--color-border);color:var(--color-text)}[data-theme=dark] .progress-reminder{background:var(--color-surface-elevated);color:var(--color-text);box-shadow:var(--shadow-lg)}[data-theme=dark] .admin-stat-card{background:var(--color-surface)}[data-theme=dark] .admin-stat-card--highlight{background:#4ade8026;border-color:#4ade804d}[data-theme=dark] .admin-stat-card--active{background:#3b82f626;border-color:#3b82f64d}[data-theme=dark] .admin-stat-card--time{background:#d87a9226;border-color:#d87a924d}[data-theme=dark] .admin-craft-item,[data-theme=dark] .admin-type-card,[data-theme=dark] .admin-leaderboard__item,[data-theme=dark] .admin-activity-item,[data-theme=dark] .admin-flag-item,[data-theme=dark] .admin-summary__row,[data-theme=dark] .admin-tool-btn{background:var(--color-surface);border-color:var(--color-border)}[data-theme=dark] .admin-section--danger{background:#f8717114}[data-theme=dark] .follow-list-page,[data-theme=dark] .follow-list-page__header{background:var(--color-bg)}[data-theme=dark] .share-project-info,[data-theme=dark] .share-project-details{background:var(--color-surface);border-color:var(--color-border)}[data-theme=dark] .dashboard-craft{background:var(--color-surface-elevated)}.button{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-xs);border:none;border-radius:var(--radius-md);font-weight:var(--font-semibold);font-family:inherit;cursor:pointer;transition:all .15s ease;-webkit-user-select:none;user-select:none;letter-spacing:.01em}.button:disabled,.button--disabled{opacity:.5;cursor:not-allowed}.button--sm{height:28px;padding:0 var(--spacing-sm);font-size:var(--font-size-sm)}.button--md{height:36px;padding:0 var(--spacing-md);font-size:var(--font-size-base)}.button--lg{height:44px;padding:0 var(--spacing-lg);font-size:var(--font-size-md)}.button--primary{background:var(--color-brand);color:var(--color-text-inverse)}.button--primary:hover:not(:disabled){background:var(--color-brand-secondary)}.button--primary:active:not(:disabled){opacity:.9}.button--primary.button--success{background:var(--color-success-strong)}.button--primary.button--warning{background:var(--color-warning-strong)}.button--primary.button--error{background:var(--color-error-strong)}.button--secondary{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border)}.button--secondary:hover:not(:disabled){background:var(--color-surface-elevated);border-color:var(--color-border-strong)}.button--secondary:active:not(:disabled){opacity:.9}.button--secondary.button--success{color:var(--color-success-strong);border-color:var(--color-success-strong)}.button--secondary.button--success:hover:not(:disabled){background:var(--color-success-soft)}.button--secondary.button--warning{color:var(--color-warning-strong);border-color:var(--color-warning-strong)}.button--secondary.button--warning:hover:not(:disabled){background:var(--color-warning-soft)}.button--secondary.button--error{color:var(--color-error-strong);border-color:var(--color-error-strong)}.button--secondary.button--error:hover:not(:disabled){background:var(--color-error-soft)}.button--ghost{background:transparent;color:var(--color-brand);padding:0;height:auto;border-radius:0}.button--ghost:hover:not(:disabled){text-decoration:underline}.button--ghost.button--success{color:var(--color-success-strong)}.button--ghost.button--warning{color:var(--color-warning-strong)}.button--ghost.button--error{color:var(--color-error-strong)}.button--xs{height:24px;padding:0 6px;font-size:var(--font-size-xs)}.button--small{height:28px;padding:0 8px;font-size:var(--font-size-sm)}.button--medium{height:36px;padding:0 12px;font-size:var(--font-size-base)}.button--large{height:44px;padding:0 16px;font-size:var(--font-size-md)}.card{background:var(--color-surface);border-radius:var(--radius-xl);padding:var(--spacing-lg);border:1px solid var(--color-border);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.message{padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);font-weight:var(--font-medium);font-size:var(--text-base);text-align:center;border:1px solid transparent}.message--info{background:var(--color-surface);color:var(--color-text);border-color:var(--color-border)}.message--warning{background:var(--color-warning-soft);color:var(--color-warning-strong);border-color:var(--color-warning-strong);animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.85}}.form-input{width:100%;height:44px;padding:.625rem .875rem;border:1px solid var(--color-form-border);border-radius:var(--radius-md);font-size:var(--text-base);font-family:inherit;transition:border-color .15s ease,background-color .15s ease;background:var(--color-form-bg);color:var(--color-form-text);box-sizing:border-box;outline:none}.form-input:hover:not(:focus):not(:disabled){border-color:var(--color-form-border-hover)}.form-input:focus{border-color:var(--color-form-border-focus);background:var(--color-form-bg-focus)}.form-input--filled,.form-input:not(:placeholder-shown){background:var(--color-form-bg-filled)}.form-input::placeholder{color:var(--color-form-text-placeholder)}.form-input:disabled{background:var(--color-form-bg-disabled);border-color:var(--color-form-border-disabled);color:var(--color-form-text-disabled);cursor:not-allowed}.form-input--success,.form-input[data-state=success]{border-color:var(--color-success-strong)}.form-input--warning,.form-input[data-state=warning]{border-color:var(--color-warning-strong)}.form-input--error,.form-input[data-state=error]{border-color:var(--color-error-strong)}textarea.form-input{height:auto;min-height:100px;padding:.625rem .875rem;resize:vertical}.checkbox{display:inline-flex;align-items:center;gap:8px;cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox input{display:none}.checkbox__box{width:20px;height:20px;border:1.5px solid var(--color-border-strong);border-radius:4px;background:var(--color-surface);display:flex;align-items:center;justify-content:center;transition:all .15s ease;flex-shrink:0}.checkbox__box svg{width:12px;height:12px;color:var(--color-text-inverse)}.checkbox input:checked+.checkbox__box{background:var(--color-brand);border-color:var(--color-brand)}.checkbox:hover .checkbox__box{border-color:var(--color-brand)}.checkbox__label{font-size:var(--text-base);color:var(--color-text)}.checkbox--disabled{opacity:.5;cursor:not-allowed}.checkbox--small .checkbox__box{width:14px;height:14px}.checkbox--small .checkbox__box svg{width:10px;height:10px}.checkbox--small .checkbox__label{font-size:var(--text-sm)}.checkbox--large .checkbox__box{width:22px;height:22px}.checkbox--large .checkbox__box svg{width:14px;height:14px}.date-picker{position:relative;width:100%}.date-picker__trigger{display:flex;align-items:center;justify-content:space-between;width:100%;height:44px;padding:.625rem .875rem;border:1px solid var(--color-form-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text);font-size:var(--text-base);font-family:inherit;cursor:pointer;transition:border-color .15s ease;text-align:left}.date-picker__trigger:hover,.date-picker__trigger:focus{outline:none;border-color:var(--color-form-border-hover)}.date-picker__value--placeholder{color:var(--color-form-text-placeholder)}.date-picker__icon{color:var(--color-text-tertiary);flex-shrink:0}.date-picker__dropdown{position:absolute;z-index:1000;width:260px;background:var(--color-bg);border:1px solid var(--color-border-strong);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:var(--spacing-sm)}.date-picker__dropdown--down{top:calc(100% + 4px)}.date-picker__dropdown--up{bottom:calc(100% + 4px)}.date-picker__dropdown--left{left:0;right:auto}.date-picker__dropdown--right{right:0;left:auto}.date-picker__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-xs)}.date-picker__month-year{font-weight:var(--font-semibold);font-size:var(--text-base);color:var(--color-text)}.date-picker__nav{display:flex;gap:4px}.date-picker__nav button{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;border-radius:var(--radius-md);background:transparent;color:var(--color-text-tertiary);cursor:pointer;transition:all .15s ease}.date-picker__nav button:hover{background:var(--color-brand-secondary);color:var(--color-text-inverse)}.date-picker__weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:var(--spacing-xs)}.date-picker__weekdays span{text-align:center;font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text-tertiary);padding:4px}.date-picker__days{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.date-picker__day{display:flex;align-items:center;justify-content:center;width:100%;height:32px;border:none;border-radius:var(--radius-md);background:transparent;color:var(--color-text);font-size:var(--text-sm);cursor:pointer;transition:all .15s ease}.date-picker__day:hover{background:var(--color-surface-elevated)}.date-picker__day--other{color:var(--color-text-tertiary);opacity:.5}.date-picker__day--today{font-weight:var(--font-bold);color:var(--color-brand)}.date-picker__day--selected{background:var(--color-brand)!important;color:var(--color-text-inverse)!important;font-weight:var(--font-semibold)}.date-picker__footer{display:flex;justify-content:space-between;margin-top:var(--spacing-xs);padding-top:var(--spacing-xs);border-top:1px solid var(--color-border)}.date-picker__clear,.date-picker__today{background:none;border:none;color:var(--color-brand);font-size:var(--text-base);font-weight:var(--font-medium);cursor:pointer;padding:4px 8px}.date-picker__clear:hover,.date-picker__today:hover{text-decoration:underline}.form-checkbox{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:var(--text-base);color:var(--color-text);margin-top:4px}.form-checkbox input[type=checkbox]{width:18px;height:18px;accent-color:var(--color-brand);cursor:pointer}.form-checkbox span{-webkit-user-select:none;user-select:none}.form-row{display:flex;align-items:center;gap:var(--spacing-md)}.form-row .form-input{flex:1;min-width:0}.form-row .checkbox{flex-shrink:0}.form-hint{font-size:var(--text-sm);color:var(--color-text-tertiary);margin:0 0 8px}.pattern-creator-fields{margin-top:12px}.form-input-with-prefix{display:flex;align-items:center;height:44px;background:var(--color-surface);border:1px solid var(--color-form-border);border-radius:var(--radius-md);overflow:hidden}.form-input__prefix{padding:0 0 0 .875rem;color:var(--color-text-tertiary);font-weight:var(--font-medium);background:transparent;flex-shrink:0}.form-input-with-prefix .form-input{border:none;border-radius:0;padding-left:.25rem;background:transparent;height:100%}.form-input-with-prefix .form-input:focus{box-shadow:none}.form-input-with-prefix:focus-within{border-color:var(--color-form-border-hover)}.form-input--error{border-color:var(--color-error-strong)}.form-textarea{resize:vertical;min-height:80px}.form-input-file{padding:var(--spacing-sm);border:2px dashed var(--color-border);border-radius:var(--radius-md);cursor:pointer;background:var(--color-surface)}.form-input-file:hover{border-color:var(--color-brand);background:var(--color-surface-elevated)}.file-preview{margin-top:var(--spacing-sm);padding:var(--spacing-sm);background:var(--color-surface-elevated);border-radius:var(--radius-sm);font-size:var(--text-base)}.form-actions{display:flex;gap:var(--spacing-md);margin-top:var(--spacing-lg)}.form-actions .button{flex:1}.project-card{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-lg);padding:var(--spacing-lg);flex-wrap:wrap}.project-card__content{flex:1;min-width:200px}.project-card__name{font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--color-text);margin-bottom:var(--spacing-xs)}.project-card__details{display:flex;gap:var(--spacing-md);flex-wrap:wrap;font-size:var(--text-base);color:var(--color-text-secondary)}.project-card__mode{padding:.25rem .5rem;border-radius:var(--radius-sm);font-weight:var(--font-semibold)}.project-card__mode--increase{background:var(--color-success-soft);color:var(--color-success-strong)}.project-card__mode--decrease{background:var(--color-error-soft);color:var(--color-error-strong)}.project-card__actions{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}@media (max-width: 480px){.project-card{flex-direction:column;align-items:stretch}.project-card__actions{width:100%}.project-card__actions .button{flex:1}}.counter-card{padding:var(--spacing-lg);transition:all .2s ease}.counter-card--active{border-color:var(--color-brand)}.counter-card--completed{opacity:.6}.counter-card__header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-md)}.counter-card__name{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--color-text);margin-bottom:var(--spacing-xs)}.counter-card__mode{font-size:var(--text-base);color:var(--color-text-secondary)}.counter-card__badge{padding:.25rem .5rem;background:var(--color-success-soft);color:var(--color-success-strong);border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:var(--font-semibold)}.counter-card__details{display:flex;gap:var(--spacing-lg);font-size:var(--text-base);color:var(--color-text-secondary);margin-bottom:var(--spacing-md)}.counter-card__button{width:100%}.counter-progress{width:100%;height:6px;background:var(--color-border);border-radius:var(--radius-sm);overflow:hidden;margin:var(--spacing-sm) 0}.counter-progress__bar{height:100%;background:linear-gradient(90deg,var(--color-brand) 0%,var(--color-brand-secondary) 100%);transition:width .3s ease}.counter-calc{padding:var(--spacing-md);background:var(--color-surface);border-radius:var(--radius-md);text-align:center;color:var(--color-brand);font-size:var(--text-base);border:1px solid var(--color-border)}.counter-calc strong{font-size:var(--text-lg)}.timer{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:10px 12px;background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border)}.timer--running{background:var(--color-warning-soft);border-color:var(--color-warning-strong)}.timer__display{flex:1}.timer__time{font-size:var(--text-base);font-weight:var(--font-medium);font-variant-numeric:tabular-nums;color:var(--color-text)}.timer--running .timer__time{color:var(--color-warning-strong)}.timer__button{height:24px;padding:0 10px;font-size:var(--text-sm);display:inline-flex;align-items:center;justify-content:center;gap:4px;border:1px solid var(--color-border);border-radius:var(--radius-md);font-weight:var(--font-medium);cursor:pointer;transition:all .15s ease;background:var(--color-surface);color:var(--color-text)}.timer__button:hover{background:var(--color-surface-elevated);border-color:var(--color-border-strong);color:var(--color-brand)}.timer__button--start{background:var(--color-brand);border-color:var(--color-brand);color:var(--color-text-inverse)}.timer__button--start:hover{background:var(--color-brand-secondary);border-color:var(--color-brand-secondary)}.timer__button--stop{background:var(--color-warning-strong);border-color:var(--color-warning-strong);color:var(--color-text-inverse)}.timer__button--stop:hover{opacity:.9}.timer-compact-wrapper{display:inline-flex;align-items:center;gap:.25rem}.timer-compact{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--text-base);font-weight:var(--font-semibold);cursor:pointer;transition:all .15s ease;color:var(--color-text)}.timer-compact:hover{border-color:var(--color-brand)}.timer-compact--running{background:var(--color-warning-soft);border-color:var(--color-warning-strong)}.timer-compact__icon{font-size:var(--text-sm)}.timer-compact__time{font-variant-numeric:tabular-nums}.timer-compact-reset{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;padding:0;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--text-base);cursor:pointer;color:var(--color-text-tertiary);transition:all .15s ease}.timer-compact-reset:hover{background:var(--color-error-soft);border-color:var(--color-error-strong);color:var(--color-error-strong)}.timer__button--reset{background:transparent;color:var(--color-text-tertiary)}.timer__button--reset:hover{background:var(--color-error-soft);border-color:var(--color-error-strong);color:var(--color-error-strong)}.style-guide{min-height:100vh;background:var(--color-bg);padding-bottom:var(--spacing-16)}.style-guide__header{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-4);background:var(--color-surface);border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:10}.style-guide__title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text);margin:0}.style-guide__content{padding:var(--spacing-4);display:flex;flex-direction:column;gap:var(--spacing-8)}.style-guide__section{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--spacing-5);border:1px solid var(--color-border)}.style-guide__section-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text);margin:0 0 var(--spacing-4) 0;padding-bottom:var(--spacing-3);border-bottom:1px solid var(--color-border)}.style-guide__subsection-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);margin:var(--spacing-4) 0 var(--spacing-3) 0;text-transform:uppercase;letter-spacing:.05em}.style-guide__subsection-title:first-of-type{margin-top:0}.style-guide__palette{display:flex;gap:2px;border-radius:var(--radius-md);overflow:hidden}.style-guide__swatch{flex:1;aspect-ratio:1;min-width:28px;display:flex;align-items:flex-end;justify-content:center;padding:var(--spacing-1)}.style-guide__swatch-label{font-size:8px;font-weight:var(--font-weight-medium);color:inherit;mix-blend-mode:difference;opacity:.7}.style-guide__type-scale{display:flex;flex-direction:column;gap:var(--spacing-2)}.style-guide__type-scale p{margin:0;color:var(--color-text)}.style-guide__weights{display:flex;flex-direction:column;gap:var(--spacing-2);margin-top:var(--spacing-4);padding-top:var(--spacing-4);border-top:1px solid var(--color-border)}.style-guide__weights p{margin:0;color:var(--color-text)}.style-guide__row{display:flex;flex-wrap:wrap;gap:var(--spacing-3);align-items:center}.style-guide__form-row{display:flex;flex-direction:column;gap:var(--spacing-3)}.style-guide__status-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-3)}.style-guide__status-item{display:flex;flex-direction:column}.style-guide__status-box{padding:var(--spacing-4);border-radius:var(--radius-md);text-align:center;font-weight:var(--font-weight-medium)}.style-guide__spacing{display:flex;flex-wrap:wrap;gap:var(--spacing-4);align-items:flex-end}.style-guide__spacing-item{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-2)}.style-guide__spacing-box{background:var(--color-brand);border-radius:2px}.style-guide__spacing-item span{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.style-guide__radius-box{width:60px;height:60px;background:var(--color-brand);display:flex;align-items:center;justify-content:center;color:var(--color-text-inverse);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.style-guide__icons{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:var(--spacing-3)}.style-guide__icon-item{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-2);padding:var(--spacing-3);background:var(--color-bg);border-radius:var(--radius-md);color:var(--color-text)}.style-guide__icon-item span{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.style-guide__description{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0 0 var(--spacing-4) 0}.style-guide__demo{padding:var(--spacing-4);background:var(--color-bg);border-radius:var(--radius-md);border:1px dashed var(--color-border)}.style-guide__demo-stack{display:flex;flex-direction:column;gap:var(--spacing-4);padding:var(--spacing-4);background:var(--color-bg);border-radius:var(--radius-md);border:1px dashed var(--color-border)}.style-guide__code{margin-top:var(--spacing-3);padding:var(--spacing-3);background:var(--color-bg-secondary);border-radius:var(--radius-sm);overflow-x:auto}.style-guide__code code{font-family:SF Mono,Monaco,Consolas,monospace;font-size:var(--font-size-xs);color:var(--color-text-secondary)}.style-guide__status-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--spacing-3)}.style-guide__status-box{padding:var(--spacing-4);border-radius:var(--radius-md);text-align:center;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.style-guide__token-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:var(--spacing-3)}.style-guide__token-item{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-1);padding:var(--spacing-3);background:var(--color-bg);border-radius:var(--radius-md)}.style-guide__token-swatch{width:48px;height:48px;border-radius:var(--radius-md);background:var(--color-surface)}.style-guide__token-swatch--text{display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);background:var(--color-form-bg);border:1px solid var(--color-border)}.style-guide__token-item>span:first-of-type{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-text);text-align:center}.style-guide__token-desc{font-size:10px;color:var(--color-text-tertiary)}.style-guide__note{font-size:var(--font-size-sm);color:var(--color-text-tertiary);margin-top:var(--spacing-3);font-style:italic}.style-guide__note code{font-family:SF Mono,Monaco,Consolas,monospace;font-size:var(--font-size-xs);background:var(--color-bg-secondary);padding:2px 6px;border-radius:var(--radius-sm);font-style:normal}.style-guide__form-states{display:flex;flex-direction:column;gap:var(--spacing-4)}.style-guide__form-states>div{display:flex;flex-direction:column;gap:var(--spacing-2)}
