.google-sign-in-btn{display:flex;align-items:center;justify-content:center;gap:.75rem;background:var(--color-surface-2);color:var(--color-text);border:1px solid var(--color-border-mid);border-radius:var(--radius-md);padding:.75rem 1.5rem;font-family:var(--font-body);font-size:.9375rem;font-weight:400;cursor:pointer;transition:all .2s ease;width:100%;max-width:320px;letter-spacing:.01em}.google-sign-in-btn:hover{background:var(--color-surface-3);border-color:#fff3;box-shadow:var(--shadow-sm)}.google-sign-in-btn:active{transform:scale(.98)}.google-icon{flex-shrink:0}.google-sign-in-btn.nav-version{padding:.5rem 1rem;max-width:none;width:auto;font-size:.875rem}.telegram-sign-in-container{display:flex;justify-content:center;align-items:center;width:100%}.telegram-sign-in-btn{display:flex;align-items:center;justify-content:center;gap:.625rem;padding:.75rem 1.5rem;background:#0088cc26;color:#5aabee;border:1px solid rgba(90,171,238,.25);border-radius:var(--radius-md);font-family:var(--font-body);font-size:.9375rem;font-weight:500;cursor:pointer;transition:all .2s ease;width:100%;max-width:320px;letter-spacing:.01em}.telegram-sign-in-btn:hover:not(:disabled){background:#0088cc38;border-color:#5aabee66;box-shadow:0 4px 16px #5aabee26}.telegram-sign-in-btn:disabled{opacity:.45;cursor:not-allowed}.tonconnect-signin{display:flex;flex-direction:column;gap:.75rem;width:100%}.tonconnect-button{width:100%;padding:.75rem 1.5rem;background:#0088cc1a;color:#5aabee;border:1px solid rgba(90,171,238,.2);border-radius:var(--radius-md);font-family:var(--font-body);font-size:.9375rem;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.625rem;letter-spacing:.01em}.tonconnect-button:hover:not(:disabled){background:#0088cc2e;border-color:#5aabee59;box-shadow:0 4px 16px #5aabee1f}.tonconnect-button:disabled{opacity:.45;cursor:not-allowed}.tonconnect-error{padding:.75rem 1rem;background:var(--color-coral-dim);color:var(--color-coral);border:1px solid rgba(224,123,110,.25);border-radius:var(--radius-sm);font-size:.875rem;text-align:center}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:var(--color-bg);padding:2rem;position:relative;overflow:hidden}.login-page:before{content:"";position:absolute;top:-20%;left:-15%;width:55%;height:60%;background:radial-gradient(ellipse at center,rgba(240,180,41,.06) 0%,transparent 70%);pointer-events:none;animation:blobDrift 12s ease-in-out infinite alternate}.login-page:after{content:"";position:absolute;bottom:-15%;right:-10%;width:50%;height:55%;background:radial-gradient(ellipse at center,rgba(78,202,139,.05) 0%,transparent 70%);pointer-events:none;animation:blobDrift 16s ease-in-out infinite alternate-reverse}@keyframes blobDrift{0%{transform:translate(0) scale(1)}to{transform:translate(3%,4%) scale(1.06)}}.login-container{background:var(--color-surface);border:1px solid var(--color-border-mid);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg),0 0 60px #00000080;padding:3rem;max-width:420px;width:100%;position:relative;z-index:1;animation:slideUp .5s cubic-bezier(.22,1,.36,1) both}@keyframes slideUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.login-container:before{content:"";position:absolute;top:0;left:2.5rem;right:2.5rem;height:1px;background:linear-gradient(90deg,transparent,var(--color-accent),transparent);border-radius:0 0 1px 1px}.login-header{text-align:center;margin-bottom:2.5rem}.login-logo-mark{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;background:var(--color-accent-dim);border:1px solid rgba(240,180,41,.25);border-radius:14px;font-size:1.75rem;margin-bottom:1.25rem}.login-title{font-family:var(--font-display);font-size:2.25rem;font-weight:700;font-style:italic;color:var(--color-text);margin:0 0 .5rem;letter-spacing:-.01em}.login-subtitle{font-size:.9375rem;color:var(--color-text-soft);margin:0;font-weight:300;letter-spacing:.01em}.login-options{display:flex;flex-direction:column;gap:.875rem}.login-option{width:100%;animation:optionIn .4s cubic-bezier(.22,1,.36,1) both}.login-option:nth-child(1){animation-delay:.1s}.login-option:nth-child(2){animation-delay:.18s}.login-option:nth-child(3){animation-delay:.26s}@keyframes optionIn{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}.login-error{padding:1rem;background:#e07b6e1a;border:1px solid rgba(224,123,110,.3);border-radius:var(--radius-md);color:var(--color-coral);text-align:center;margin-bottom:1rem}.login-error p{margin:0;font-size:.875rem}.login-processing{padding:1.25rem;text-align:center;background:var(--color-mint-dim);border:1px solid rgba(78,202,139,.25);border-radius:var(--radius-md);color:var(--color-mint);margin-bottom:1rem}.login-processing p{margin:0;font-size:.9375rem;font-weight:500}.login-retry-button{margin-top:.75rem;padding:.5rem 1.25rem;background:var(--color-sky);color:#0d0f14;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:.875rem;font-weight:600;transition:opacity .2s;font-family:var(--font-body)}.login-retry-button:hover{opacity:.85}.login-divider{display:flex;align-items:center;gap:1rem;margin:.25rem 0;color:var(--color-text-muted);font-size:.75rem;letter-spacing:.08em;text-transform:uppercase}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--color-border)}@media (max-width: 640px){.login-container{padding:2rem 1.5rem}.login-title{font-size:1.75rem}}.wallet-selection-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:1rem}.wallet-selection-modal{background:#fff;border-radius:1rem;box-shadow:0 10px 25px #0003;max-width:500px;width:100%;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column}.wallet-selection-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e5e7eb}.wallet-selection-header h2{margin:0;font-size:1.5rem;font-weight:700;color:#1a1a1a}.wallet-selection-close{background:transparent;border:none;font-size:2rem;color:#6b7280;cursor:pointer;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:.25rem;transition:all .2s}.wallet-selection-close:hover{background:#f3f4f6;color:#1a1a1a}.wallet-selection-content{padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem}.wallet-selection-description{margin:0;color:#6b7280;font-size:.9375rem}.wallet-options{display:flex;flex-direction:column;gap:1rem}.wallet-option{display:flex;align-items:center;gap:1rem;padding:1rem;border:2px solid #e5e7eb;border-radius:.75rem;background:#fff;cursor:pointer;transition:all .3s ease;text-align:left;width:100%}.wallet-option:hover:not(:disabled){border-color:#08c;background:#f0f9ff;transform:translateY(-2px);box-shadow:0 4px 12px #0088cc26}.wallet-option:disabled{opacity:.6;cursor:not-allowed}.wallet-option.connecting{border-color:#08c;background:#f0f9ff}.wallet-option-icon{font-size:2.5rem;width:3rem;height:3rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.wallet-option-info{flex:1;min-width:0}.wallet-option-name{font-size:1.125rem;font-weight:600;color:#1a1a1a;margin-bottom:.25rem;display:flex;align-items:center;gap:.5rem}.wallet-installed-badge{font-size:.75rem;font-weight:500;color:#10b981;background:#d1fae5;padding:.125rem .5rem;border-radius:.25rem}.wallet-option-description{font-size:.875rem;color:#6b7280}.wallet-option-loader{font-size:1.5rem;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 768px){.wallet-selection-modal{max-width:95vw}.wallet-selection-header,.wallet-selection-content{padding:1rem}.wallet-option{padding:.75rem}.wallet-option-icon{font-size:2rem;width:2.5rem;height:2.5rem}}.connect-wallet-container{display:flex;flex-direction:column;gap:.75rem;width:100%}.connect-wallet-button{width:100%;padding:.75rem 1.5rem;background:linear-gradient(135deg,#08c,#06a);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:.5rem}.connect-wallet-button:hover:not(:disabled){background:linear-gradient(135deg,#06a,#048);transform:translateY(-1px);box-shadow:0 4px 12px #0088cc4d}.connect-wallet-button:disabled{opacity:.6;cursor:not-allowed}.connect-wallet-error{padding:.75rem;background:#fee2e2;color:#dc2626;border-radius:4px;font-size:.875rem;text-align:center}.drawer-toggle-button{position:fixed;top:.875rem;left:1rem;z-index:1000;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:.625rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.drawer-toggle-button:hover{background:var(--color-surface-2);border-color:var(--color-border-mid)}.hamburger-icon{display:flex;flex-direction:column;gap:4px;width:22px;height:16px;position:relative}.hamburger-icon span{display:block;height:2px;width:100%;background:var(--color-text-soft);border-radius:2px;transition:all .3s cubic-bezier(.22,1,.36,1)}.hamburger-icon.active span:nth-child(1){transform:rotate(45deg) translate(6px,6px);background:var(--color-accent)}.hamburger-icon.active span:nth-child(2){opacity:0}.hamburger-icon.active span:nth-child(3){transform:rotate(-45deg) translate(6px,-6px);background:var(--color-accent)}.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;z-index:1098;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);animation:overlayFadeIn .25s ease}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}.navigation-drawer{position:fixed;top:0;left:0;height:100vh;width:272px;max-width:85vw;background:var(--color-surface);border-right:1px solid var(--color-border);z-index:1099;transform:translate(-100%);transition:transform .3s cubic-bezier(.22,1,.36,1);display:flex;flex-direction:column;overflow:hidden}.navigation-drawer.open{transform:translate(0);box-shadow:8px 0 40px #00000080}.drawer-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 1.25rem;border-bottom:1px solid var(--color-border);background:var(--color-surface)}.drawer-logo{display:flex;align-items:center;gap:.5rem;text-decoration:none}.drawer-logo .logo-star{font-size:1.25rem;color:var(--color-accent)}.drawer-logo .logo-text{font-family:var(--font-display);font-size:1.25rem;font-weight:700;font-style:italic;margin:0;color:var(--color-text);letter-spacing:-.01em}.drawer-close-button{background:none;border:none;font-size:1.125rem;cursor:pointer;color:var(--color-text-muted);padding:.25rem;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all .2s}.drawer-close-button:hover{background:var(--color-surface-2);color:var(--color-text-soft)}.drawer-content{flex:1;display:flex;flex-direction:column;overflow-y:auto;padding:1rem 0}.drawer-nav-links{display:flex;flex-direction:column;gap:.25rem;padding:0 .75rem}.drawer-nav-link{display:flex;align-items:center;gap:.875rem;padding:.875rem 1rem;border-radius:var(--radius-md);text-decoration:none;color:var(--color-text-soft);transition:all .18s ease;font-weight:400;font-size:.9375rem;position:relative}.drawer-nav-link:hover{background:var(--color-surface-2);color:var(--color-text)}.drawer-nav-link.active{background:var(--color-accent-dim);color:var(--color-accent);font-weight:500}.drawer-nav-link.active:before{content:"";position:absolute;left:0;top:20%;bottom:20%;width:2px;background:var(--color-accent);border-radius:1px}.nav-link-icon{font-size:1.25rem;width:1.75rem;text-align:center;flex-shrink:0}.nav-link-text{flex:1;letter-spacing:.01em}.drawer-user-section{margin-top:auto;border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border)}.drawer-user-info{display:flex;align-items:center;gap:.875rem;padding:1rem 1.25rem}.drawer-user-avatar{width:40px;height:40px;border-radius:50%;-o-object-fit:cover;object-fit:cover;border:1.5px solid var(--color-border-mid)}.drawer-user-details{flex:1;min-width:0}.drawer-user-name{font-weight:500;color:var(--color-text);font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.drawer-user-email{font-size:.8125rem;color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:.125rem}.drawer-footer{padding:1rem .75rem;display:flex;flex-direction:column;gap:.75rem}.drawer-wallet-section{width:100%}.drawer-wallet-section .connect-wallet-button{width:100%;padding:.625rem 1rem;font-size:.875rem;background:linear-gradient(135deg,#08c,#06a);color:#fff;border:none;border-radius:var(--radius-md);font-weight:500;cursor:pointer;transition:all .2s ease;font-family:var(--font-body)}.drawer-wallet-section .connect-wallet-button:hover:not(:disabled){filter:brightness(1.1);transform:translateY(-1px);box-shadow:0 4px 16px #0088cc4d}.drawer-wallet-section .connect-wallet-button:disabled{opacity:.45;cursor:not-allowed}.drawer-wallet-section .connect-wallet-error{padding:.5rem;background:var(--color-coral-dim);color:var(--color-coral);border-radius:var(--radius-sm);font-size:.75rem;text-align:center;margin-top:.5rem}.drawer-language-selector{display:flex;flex-direction:column;gap:.375rem}.drawer-language-selector label{font-size:.8125rem;font-weight:500;color:var(--color-text-muted);letter-spacing:.05em;text-transform:uppercase}.language-select{padding:.5rem .625rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.875rem;background:var(--color-surface-2);color:var(--color-text-soft);cursor:pointer;font-family:var(--font-body);transition:border-color .2s}.language-select:hover{border-color:var(--color-border-mid)}.drawer-logout-button{width:100%;padding:.75rem;background:#e07b6e1a;color:var(--color-coral);border:1px solid rgba(224,123,110,.2);border-radius:var(--radius-md);font-family:var(--font-body);font-size:.9375rem;font-weight:500;cursor:pointer;transition:all .2s ease}.drawer-logout-button:hover{background:#e07b6e2e;border-color:#e07b6e66}.dashboard-summary{padding:2rem;max-width:1200px;margin:0 auto}.summary-header{margin-bottom:2.5rem}.summary-header h1{font-family:var(--font-display);font-size:2.5rem;font-weight:700;font-style:italic;color:var(--color-text);margin:0 0 .5rem;letter-spacing:-.02em;line-height:1.1}.summary-header p{font-size:.9375rem;color:var(--color-text-soft);margin:0;font-weight:300}.summary-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin-bottom:3rem}.summary-stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.5rem;display:flex;align-items:center;gap:1rem;transition:border-color .2s ease,box-shadow .2s ease;position:relative;overflow:hidden}.summary-stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--color-accent-dim),transparent)}.summary-stat-card:hover{border-color:var(--color-border-mid);box-shadow:var(--shadow-md)}.stat-icon{font-size:2.25rem;flex-shrink:0;line-height:1}.stat-content{flex:1;min-width:0}.stat-value{font-family:var(--font-mono);font-size:1.875rem;font-weight:500;color:var(--color-accent);margin-bottom:.25rem;line-height:1.1;letter-spacing:-.02em}.stat-label{font-size:.8125rem;color:var(--color-text-soft);margin-bottom:.375rem;letter-spacing:.03em;font-weight:400}.stat-detail{font-size:.75rem;color:var(--color-text-muted);font-family:var(--font-mono)}.summary-loading{text-align:center;padding:3rem;color:var(--color-text-muted);font-weight:300;font-style:italic;font-family:var(--font-display);font-size:1.125rem}.summary-sections{margin-top:2rem}.summary-sections h2{font-family:var(--font-display);font-size:1.5rem;font-weight:600;font-style:italic;color:var(--color-text-soft);margin-bottom:1.25rem;letter-spacing:-.01em}.summary-section-tiles{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem}.summary-section-tile{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.875rem 1.75rem;cursor:pointer;transition:border-color .2s ease,background .2s ease,box-shadow .2s ease;text-align:left;position:relative;overflow:hidden}.summary-section-tile:after{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--color-accent);border-radius:0 1px 1px 0;opacity:0;transition:opacity .2s ease}.summary-section-tile:hover{background:var(--color-surface-2);border-color:var(--color-border-mid);box-shadow:var(--shadow-md)}.summary-section-tile:hover:after{opacity:1}.section-tile-icon{font-size:2rem;margin-bottom:1rem;display:block;line-height:1}.summary-section-tile h3{font-family:var(--font-display);font-size:1.3rem;font-weight:600;font-style:italic;color:var(--color-text);margin:0 0 .5rem;letter-spacing:-.01em}.summary-section-tile p{font-size:.875rem;color:var(--color-text-soft);margin:0;font-weight:300;line-height:1.5}@media (max-width: 768px){.dashboard-summary{padding:1rem}.summary-stats{grid-template-columns:1fr 1fr;gap:.75rem}.summary-section-tiles{grid-template-columns:1fr}.summary-header h1{font-size:1.875rem}}@media (max-width: 480px){.summary-stats{grid-template-columns:1fr}}.notification-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:10000;padding:1rem;opacity:0;visibility:hidden;transition:opacity .25s ease,visibility .25s ease;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.notification-overlay.visible{opacity:1;visibility:visible}.notification-container{background:var(--color-surface);border:1px solid var(--color-border-mid);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);max-width:420px;width:100%;max-height:90vh;overflow-y:auto;transform:scale(.92) translateY(16px);transition:transform .3s cubic-bezier(.22,1,.36,1);position:relative}.notification-overlay.visible .notification-container{transform:scale(1) translateY(0)}.notification-header{display:flex;align-items:center;gap:1rem;padding:1.5rem;border-bottom:1px solid var(--color-border)}.notification-icon{font-size:1.75rem;width:2.75rem;height:2.75rem;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);flex-shrink:0}.notification-title{flex:1;margin:0;font-family:var(--font-display);font-size:1.25rem;font-weight:600;font-style:italic;color:var(--color-text);letter-spacing:-.01em}.notification-close{background:transparent;border:none;font-size:1.125rem;color:var(--color-text-muted);cursor:pointer;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all .2s}.notification-close:hover{background:var(--color-surface-2);color:var(--color-text-soft)}.notification-content{padding:1.5rem}.notification-message{margin:0;font-size:.9375rem;line-height:1.6;color:var(--color-text-soft);white-space:pre-wrap;word-wrap:break-word;font-weight:300}.notification-actions{display:flex;gap:.75rem;padding:1rem 1.5rem 1.5rem;border-top:1px solid var(--color-border);justify-content:flex-end}.notification-button{padding:.625rem 1.25rem;border:none;border-radius:var(--radius-md);font-family:var(--font-body);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;min-width:80px}.notification-button-cancel{background:var(--color-surface-2);color:var(--color-text-soft);border:1px solid var(--color-border)}.notification-button-cancel:hover{background:var(--color-surface-3);color:var(--color-text)}.notification-button-confirm{background:var(--color-mint);color:#0d0f14;font-weight:600}.notification-button-confirm:hover{filter:brightness(1.1);box-shadow:0 0 12px #4eca8b4d}.notification-info .notification-icon{background:var(--color-sky-dim);color:var(--color-sky)}.notification-success .notification-icon{background:var(--color-mint-dim);color:var(--color-mint)}.notification-warning .notification-icon{background:#f0b4291f;color:var(--color-accent)}.notification-error .notification-icon{background:var(--color-coral-dim);color:var(--color-coral)}.notification-confirm .notification-icon{background:var(--color-accent-dim);color:var(--color-accent)}.notification-info{border-left:3px solid var(--color-sky)}.notification-success{border-left:3px solid var(--color-mint)}.notification-warning{border-left:3px solid var(--color-accent)}.notification-error{border-left:3px solid var(--color-coral)}.notification-confirm{border-left:3px solid var(--color-accent)}@media (max-width: 640px){.notification-overlay{padding:.5rem}.notification-container{width:100%;max-width:none;border-radius:var(--radius-lg)}.notification-header,.notification-content{padding:1rem}.notification-actions{flex-direction:column-reverse;padding:1rem;gap:.5rem}.notification-button{width:100%}}.strava-details-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:2000;padding:1rem}.strava-details-container{background:#fff;border-radius:1rem;width:100%;max-width:900px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 25px -5px #0000004d;overflow:hidden}.strava-details-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e5e7eb;background:#f9fafb}.strava-details-header h2{margin:0;font-size:1.5rem;font-weight:700;color:#1a1a1a}.strava-details-close{background:none;border:none;font-size:2rem;cursor:pointer;color:#6b7280;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:.5rem;transition:background-color .2s}.strava-details-close:hover{background-color:#e5e7eb;color:#1a1a1a}.strava-details-content{padding:1.5rem;overflow-y:auto;flex:1}.strava-details-loading,.strava-details-error{text-align:center;padding:3rem;color:#6b7280}.strava-details-error{color:#ef4444}.strava-details-main{margin-bottom:2rem;padding-bottom:2rem;border-bottom:2px solid #e5e7eb}.strava-details-title-section{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1rem}.strava-details-icon{font-size:3rem;line-height:1}.strava-details-title-section h3{margin:0 0 .5rem;font-size:1.75rem;font-weight:700;color:#1a1a1a}.strava-details-type{display:inline-block;padding:.25rem .75rem;background:#e5e7eb;border-radius:.5rem;font-size:.875rem;font-weight:600;color:#374151}.strava-details-description{margin-top:1rem;padding:1rem;background:#f9fafb;border-radius:.5rem;border-left:4px solid #10b981}.strava-details-description p{margin:0;color:#4b5563;line-height:1.6}.strava-details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.strava-details-section{background:#f9fafb;padding:1.25rem;border-radius:.75rem;border:1px solid #e5e7eb}.strava-details-section h4{margin:0 0 1rem;font-size:1.125rem;font-weight:700;color:#1a1a1a;border-bottom:2px solid #10b981;padding-bottom:.5rem}.strava-details-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;border-bottom:1px solid #e5e7eb}.strava-details-item:last-child{border-bottom:none}.strava-details-label{font-size:.875rem;color:#6b7280;font-weight:500}.strava-details-value{font-size:1rem;color:#1a1a1a;font-weight:600;text-align:right}@media (max-width: 768px){.strava-details-overlay{padding:0}.strava-details-container{max-width:100%;max-height:100vh;border-radius:0}.strava-details-grid{grid-template-columns:1fr}.strava-details-header,.strava-details-content{padding:1rem}.strava-details-title-section h3{font-size:1.5rem}.strava-details-icon{font-size:2.5rem}}.progress-chart-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b8;display:flex;align-items:center;justify-content:center;z-index:2000;padding:1rem;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);animation:overlayIn .2s ease}@keyframes overlayIn{0%{opacity:0}to{opacity:1}}.progress-chart-modal{background:var(--color-surface);border:1px solid var(--color-border-mid);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);max-width:90vw;max-height:90vh;width:100%;display:flex;flex-direction:column;overflow:hidden;animation:modalSlide .3s cubic-bezier(.22,1,.36,1)}@keyframes modalSlide{0%{opacity:0;transform:scale(.94) translateY(12px)}to{opacity:1;transform:scale(1) translateY(0)}}.progress-chart-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--color-border)}.progress-chart-header h3{margin:0;font-family:var(--font-display);font-size:1.375rem;font-weight:600;font-style:italic;color:var(--color-text);letter-spacing:-.01em}.progress-chart-close{background:transparent;border:none;font-size:1.5rem;color:var(--color-text-muted);cursor:pointer;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all .2s}.progress-chart-close:hover{background:var(--color-surface-2);color:var(--color-text-soft)}.progress-chart-content{padding:1.5rem;overflow-y:auto;flex:1}.progress-chart-loading,.progress-chart-error,.progress-chart-empty{text-align:center;padding:3rem;color:var(--color-text-muted);font-style:italic;font-family:var(--font-display);font-size:1rem}.progress-chart-container{display:flex;flex-direction:column;gap:1.5rem}.progress-chart-tabs{display:flex;gap:.25rem;border-bottom:1px solid var(--color-border);margin-bottom:1rem}.progress-chart-tab{padding:.625rem 1.25rem;background:transparent;border:none;border-bottom:2px solid transparent;font-family:var(--font-body);font-size:.9rem;font-weight:500;color:var(--color-text-muted);cursor:pointer;transition:all .2s;margin-bottom:-1px;letter-spacing:.01em}.progress-chart-tab:hover{color:var(--color-text-soft);background:var(--color-surface-2)}.progress-chart-tab.active{color:var(--color-accent);border-bottom-color:var(--color-accent)}.progress-chart-tab-content{display:flex;flex-direction:column;gap:1rem}.progress-chart-legend{display:flex;gap:1.5rem;flex-wrap:wrap;justify-content:center;padding:.875rem 1rem;background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-md)}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;color:var(--color-text-soft)}.legend-color{width:14px;height:14px;border-radius:2px;display:inline-block}.progress-chart-svg-container{width:100%;overflow-x:auto;background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1rem}.progress-chart-svg{width:100%;min-width:600px;height:440px}.progress-chart-table{overflow-x:auto}.progress-chart-table table{width:100%;border-collapse:collapse;font-size:.875rem}.progress-chart-table th,.progress-chart-table td{padding:.75rem;text-align:left;border-bottom:1px solid var(--color-border);color:var(--color-text-soft)}.progress-chart-table th{background:var(--color-surface-2);font-weight:500;color:var(--color-text-muted);position:sticky;top:0;font-size:.8125rem;letter-spacing:.04em;text-transform:uppercase}.progress-chart-table tbody tr:hover{background:var(--color-surface-2)}.change-value{font-family:var(--font-mono);font-weight:500;font-size:.8125rem;margin-left:.25rem;padding:.125rem .375rem;border-radius:3px}.change-value.positive{color:var(--color-mint);background:var(--color-mint-dim)}.change-value.negative{color:var(--color-coral);background:var(--color-coral-dim)}.change-value.no-change{color:var(--color-text-muted);background:transparent}@media (max-width: 768px){.progress-chart-modal{max-width:95vw;max-height:95vh}.progress-chart-header{padding:1rem}.progress-chart-header h3{font-size:1.125rem}.progress-chart-content{padding:1rem}.progress-chart-legend{flex-direction:column;gap:.625rem}.progress-chart-svg{min-width:400px}}.training-section{width:100%}.training-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;position:relative}.training-header-title{display:flex;flex-direction:column;gap:.5rem}.selected-date-display{font-size:.875rem;color:#6b7280;font-weight:500}.training-header-actions{display:flex;align-items:center;gap:.75rem}.calendar-icon{font-size:1.5rem;padding:.5rem;background:transparent;border:none;cursor:pointer;transition:transform .2s}.calendar-icon:hover{transform:scale(1.1)}.training-header h3{font-size:1.5rem;font-weight:700;color:#1a1a1a;margin:0}.btn{padding:.75rem 1.5rem;border:none;border-radius:.5rem;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:inline-flex;align-items:center;gap:.5rem}.btn-primary:hover{background:#059669}.btn-secondary:hover{background:#f9fafb;border-color:#d1d5db}.btn-icon{background:transparent;border:none;font-size:1.25rem;cursor:pointer;padding:.25rem .5rem;border-radius:.25rem;transition:all .2s}.training-form-container{background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;padding:2rem;margin-bottom:2rem;box-shadow:0 1px 3px #0000001a}.training-form h4{font-size:1.25rem;font-weight:700;color:#1a1a1a;margin:0 0 1.5rem}.form-group{margin-bottom:1rem}.form-group label{display:block;font-size:.875rem;font-weight:500;color:#374151;margin-bottom:.5rem}.form-group input{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:.9375rem;transition:border-color .3s}.form-group input:focus{outline:none;border-color:#10b981}.form-select{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:.9375rem;background-color:#fff;cursor:pointer;transition:border-color .3s}.form-select:focus{outline:none;border-color:#10b981}.form-select:disabled{background-color:#f3f4f6;cursor:not-allowed}.autocomplete-container{position:relative}.autocomplete-wrapper{position:relative;width:100%}.autocomplete-suggestions{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid #d1d5db;border-top:none;border-radius:0 0 .5rem .5rem;list-style:none;margin:0;padding:0;max-height:200px;overflow-y:auto;z-index:1000;box-shadow:0 4px 6px #0000001a}.autocomplete-suggestion-item{padding:.75rem;cursor:pointer;transition:background-color .2s;border-bottom:1px solid #f3f4f6}.autocomplete-suggestion-item:active{background-color:#f3f4f6}.sets-section{margin-top:1.5rem}.sets-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.add-set-button-container{margin-top:1rem;margin-bottom:.5rem;display:flex;justify-content:flex-start;padding:.5rem 0}.sets-header label{font-size:1rem;font-weight:600;color:#1a1a1a}.set-row{display:flex;align-items:center;gap:1rem;padding:1rem;background:#f9fafb;border-radius:.5rem;margin-bottom:.75rem}.set-number{font-weight:600;color:#6b7280;min-width:80px;font-size:.875rem}.set-inputs{display:flex;gap:1rem;flex:1}.set-inputs .form-group{flex:1;margin-bottom:0}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem;padding-top:1.5rem;border-top:1px solid #e5e7eb}.exercises-list{display:flex;flex-direction:column;gap:1rem}.exercise-card{background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.exercise-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.exercise-header h4{font-size:1.25rem;font-weight:700;color:#1a1a1a;margin:0}.exercise-title-section{display:flex;flex-direction:column;gap:.5rem;flex:1}.exercise-type-badge{display:inline-block;padding:.25rem .75rem;background:#e0f2fe;color:#0369a1;border-radius:.375rem;font-size:.75rem;font-weight:600;width:-moz-fit-content;width:fit-content}.exercise-actions{display:flex;gap:.5rem}.exercise-date{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;background:#eff6ff;border-radius:.375rem;margin-top:1rem;margin-bottom:.5rem}.date-label{font-weight:500;color:#3b82f6;font-size:.875rem}.date-value{font-weight:600;color:#1e40af;font-size:.875rem}.exercise-sets{display:flex;flex-direction:column;gap:.5rem;margin-top:1rem;padding-top:1rem;border-top:1px solid #f3f4f6}.set-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;background:#f9fafb;border-radius:.375rem}.set-label{font-weight:500;color:#6b7280;font-size:.875rem}.set-value{font-weight:600;color:#1a1a1a;font-size:.9375rem}.empty-state p{font-size:1.125rem;margin:0}.calendar-container{background:#fff;border-radius:1rem;padding:1.5rem;box-shadow:0 10px 25px #0003;max-width:400px;width:90%;max-height:90vh;overflow-y:auto}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.calendar-nav-btn{background:#f3f4f6;border:none;border-radius:.5rem;width:2.5rem;height:2.5rem;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.5rem;color:#374151;transition:background-color .2s}.calendar-nav-btn:hover{background:#e5e7eb}.calendar-month-year{font-size:1.25rem;font-weight:600;color:#1a1a1a;margin:0}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:.25rem;margin-bottom:.5rem}.calendar-weekday{text-align:center;font-size:.875rem;font-weight:600;color:#6b7280;padding:.5rem}.calendar-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:.5rem;cursor:pointer;font-size:.9375rem;transition:all .2s;border:2px solid transparent}.calendar-day:hover:not(.empty){background:#f3f4f6}.calendar-day.today{border-color:#10b981;font-weight:600}.calendar-day.has-exercises{background:#d1fae5;color:#065f46;font-weight:600}.calendar-day.has-exercises:hover{background:#a7f3d0}.calendar-day.selected{background:#10b981;color:#fff;font-weight:700}.calendar-day.selected.has-exercises{background:#059669;color:#fff}.calendar-day.selected:hover{background:#047857}.btn-add-mobile{min-width:48px;min-height:48px;padding:0;border-radius:50%;font-size:1.5rem;font-weight:700;display:flex;align-items:center;justify-content:center}.btn-copy-mobile{min-width:48px;min-height:48px;padding:.5rem;display:flex;align-items:center;justify-content:center}.copy-icon{font-size:1.25rem}@media (max-width: 768px){.training-header{flex-direction:column;align-items:flex-start;gap:1rem}.training-header-actions{width:100%;justify-content:space-between;gap:.5rem}.btn-add-mobile{min-width:48px;min-height:48px;padding:0;border-radius:50%;font-size:1.5rem;font-weight:700}.btn-copy-mobile{min-width:48px;min-height:48px;padding:.5rem}.calendar-container{width:95%;padding:1rem}.calendar-day{font-size:.875rem}.calendar-weekday{font-size:.75rem}.set-row{flex-direction:column;align-items:stretch}.set-number{margin-bottom:.5rem}.set-inputs,.form-actions{flex-direction:column}.form-actions .btn{width:100%}}.strava-activity-card{border-left:4px solid #FC4C02;background:linear-gradient(to right,#fff5f0,#fff 10%)}.strava-activity-card .exercise-header{margin-bottom:.75rem}.strava-icon{margin-right:.5rem;font-size:1.25rem}.strava-badge{background-color:#fc4c02;color:#fff}.strava-activity-stats{display:flex;gap:1.5rem;flex-wrap:wrap;margin-top:.5rem}.strava-stat{display:flex;align-items:center;gap:.5rem}.strava-stat-label{font-weight:600;color:#6b7280;font-size:.875rem}.strava-stat-value{font-weight:700;color:#1a1a1a;font-size:.9375rem}.food-section{width:100%;padding-top:2rem;padding-bottom:6rem}.food-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-left:2rem;padding-right:2rem}.food-header h3{font-size:1.75rem;font-weight:700;color:#1a1a1a;margin:0}.food-header-actions{display:flex;gap:1rem;align-items:center}.btn-icon{background:none;border:none;font-size:1.5rem;cursor:pointer;padding:.5rem;border-radius:.5rem;transition:background-color .2s}.btn-icon:hover{background-color:#f3f4f6}.calendar-icon{font-size:1.5rem}.calendar-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.calendar-container{background:#fff;border-radius:1rem;padding:1.5rem;max-width:400px;width:90%;box-shadow:0 20px 25px -5px #0000001a}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.calendar-nav-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;padding:.5rem;border-radius:.5rem;transition:background-color .2s}.calendar-nav-btn:hover{background-color:#f3f4f6}.calendar-month-year{font-size:1.25rem;font-weight:600;margin:0}.calendar-grid{display:flex;flex-direction:column;gap:.5rem}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:.25rem}.calendar-weekday{text-align:center;font-weight:600;font-size:.875rem;color:#6b7280;padding:.5rem}.calendar-days{display:grid;grid-template-columns:repeat(7,1fr);gap:.25rem}.calendar-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:.5rem;cursor:pointer;transition:all .2s;font-weight:500}.calendar-day:hover{background-color:#f3f4f6}.calendar-day.empty{cursor:default}.calendar-day.has-entries{background-color:#d1fae5;color:#065f46}.calendar-day.selected{background-color:#10b981;color:#fff;font-weight:700}.calendar-day.today{border:2px solid #10b981}.food-form-container{background:#fff;border-radius:1rem;padding:2rem;margin-bottom:2rem;margin-left:2rem;margin-right:2rem;box-shadow:0 4px 6px -1px #0000001a}.food-form h4{font-size:1.5rem;font-weight:700;margin:0 0 1.5rem;color:#1a1a1a}.form-group{margin-bottom:1.5rem}.form-group label{display:block;font-weight:600;margin-bottom:.5rem;color:#374151}.form-input,.form-select{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:1rem;transition:border-color .2s}.form-input:focus,.form-select:focus{outline:none;border-color:#10b981;box-shadow:0 0 0 3px #10b9811a}.autocomplete-container,.autocomplete-wrapper{position:relative}.autocomplete-suggestions{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid #d1d5db;border-radius:.5rem;margin-top:.25rem;max-height:300px;overflow-y:auto;z-index:100;box-shadow:0 10px 15px -3px #0000001a}.autocomplete-suggestion-item{padding:.75rem;cursor:pointer;border-bottom:1px solid #f3f4f6;transition:background-color .2s}.autocomplete-suggestion-item:last-child{border-bottom:none}.autocomplete-suggestion-item:hover{background-color:#f9fafb}.product-suggestion{display:flex;justify-content:space-between;align-items:center}.product-name{font-weight:500;color:#1a1a1a}.product-macros{font-size:.875rem;color:#6b7280}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem}.btn{padding:.75rem 1.5rem;border:none;border-radius:.5rem;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-primary{background-color:#10b981;color:#fff}.btn-primary:hover:not(:disabled){background-color:#059669}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background-color:#e5e7eb;color:#374151}.btn-secondary:hover:not(:disabled){background-color:#d1d5db}.food-entries-list{margin-bottom:2rem;padding-left:0;padding-right:0}.food-entry-card{background:#fff;border-radius:0;padding:1rem 1.5rem;margin-bottom:0;box-shadow:none;border-bottom:1px solid #e5e7eb;transition:background-color .2s}.food-entry-card:hover{background-color:#f9fafb}.food-entry-header{display:flex;justify-content:space-between;align-items:center;gap:1rem}.food-entry-title-section{flex:1;display:flex;align-items:center;gap:.75rem;min-width:0}.food-entry-title-section h4{font-size:1rem;font-weight:600;margin:0;color:#1a1a1a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex-shrink:1}.food-entry-weight{font-size:.875rem;color:#6b7280;font-weight:500;white-space:nowrap;flex-shrink:0}.food-entry-actions{display:flex;gap:.5rem;flex-shrink:0}.food-entry-macros{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:1rem;padding-top:1rem;border-top:1px solid #e5e7eb}.macro-item{display:flex;flex-direction:column}.macro-label{font-size:.875rem;color:#6b7280;margin-bottom:.25rem}.macro-value{font-size:1.125rem;font-weight:700;color:#1a1a1a}.food-summary{position:fixed;bottom:0;left:0;right:0;background:#10b981;padding:1rem 2rem;box-shadow:0 -4px 6px -1px #0000001a;z-index:1000;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}.food-summary h4{font-size:1rem;font-weight:700;margin:0;color:#fff;white-space:nowrap}.summary-stats{display:flex;gap:2rem;align-items:center;flex-wrap:wrap}.summary-stat{display:flex;flex-direction:column;align-items:center;min-width:80px}.summary-label{font-size:.75rem;color:#ffffffe6;margin-bottom:.25rem;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.summary-value{font-size:1.25rem;font-weight:700;color:#fff}@media (max-width: 768px){.food-section{padding-top:1rem;padding-bottom:8rem}.food-header{flex-direction:column;align-items:flex-start;gap:1rem;padding-left:1rem;padding-right:1rem}.food-header-actions{width:100%;justify-content:space-between}.food-summary{padding:.75rem 1rem;flex-direction:column;align-items:flex-start}.food-summary h4{font-size:.875rem}.summary-stats{width:100%;justify-content:space-between;gap:.5rem}.summary-stat{flex:1;min-width:0}.summary-label{font-size:.625rem}.summary-value{font-size:1rem}.food-form-container{margin-left:1rem;margin-right:1rem}.food-entry-card{padding:.75rem 1rem}.food-entry-title-section h4{font-size:.875rem}.food-entry-weight{font-size:.75rem}}.dashboard-section{padding:2rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg)}.dashboard-section h2{font-family:var(--font-display);font-size:2rem;font-weight:700;font-style:italic;color:var(--color-text);margin:0 0 .625rem;letter-spacing:-.02em;line-height:1.15}.dashboard-section>p{font-size:1rem;color:var(--color-text-soft);margin:0 0 1.5rem;font-weight:300}.section-content{margin-top:1.5rem}.section-content p{color:var(--color-text-soft);line-height:1.6}.health-tiles{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-top:2rem}.health-tile{background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.5rem 1.25rem;text-align:left;cursor:pointer;transition:border-color .2s ease,background .2s ease,box-shadow .2s ease;position:relative;overflow:hidden}.health-tile:after{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--color-mint);opacity:0;transition:opacity .2s ease}.health-tile:hover{background:var(--color-surface-3);border-color:var(--color-border-mid);box-shadow:var(--shadow-md)}.health-tile:hover:after{opacity:1}.health-tile .tile-icon{font-size:2rem;margin-bottom:.875rem;display:block;line-height:1}.health-tile h3{font-family:var(--font-display);font-size:1.2rem;font-weight:600;font-style:italic;color:var(--color-text);margin:0 0 .375rem;letter-spacing:-.01em}.health-tile p{color:var(--color-text-soft);line-height:1.5;margin:0;font-size:.875rem;font-weight:300}.dashboard-page{width:100%;min-height:100vh;background-color:var(--color-bg)}.nav{position:fixed;top:0;left:0;right:0;z-index:1000;background:#0d0f14d9;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--color-border);padding:1rem 0;width:100%}.nav-container{max-width:1400px;margin:0 auto;padding:0 2rem;display:flex;justify-content:space-between;align-items:center}.nav-logo-link{text-decoration:none;display:flex;align-items:center}.nav-logo{display:flex;align-items:center;gap:.625rem}.logo-star{font-size:1.125rem;color:var(--color-accent);line-height:1}.logo-text{font-family:var(--font-display);font-size:1.4rem;font-weight:700;font-style:italic;color:var(--color-text);margin:0;letter-spacing:-.01em}.nav-center{display:flex;gap:2.5rem;align-items:center}.nav-center a{color:var(--color-text-soft);text-decoration:none;font-weight:400;font-size:.9375rem;transition:color .2s ease;letter-spacing:.01em}.nav-center a:hover{color:var(--color-text)}.nav-right{display:flex;gap:1.25rem;align-items:center}.user-info{display:flex;align-items:center;gap:.75rem}.user-avatar{width:30px;height:30px;border-radius:50%;border:1.5px solid var(--color-border-mid)}.user-name{font-size:.875rem;font-weight:500;color:var(--color-text-soft)}.btn{padding:.625rem 1.375rem;border:none;border-radius:var(--radius-md);font-family:var(--font-body);font-size:.9375rem;font-weight:500;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;gap:.5rem}.btn-primary{background:var(--color-accent);color:#0d0f14}.btn-primary:hover{background:#f8c43a;box-shadow:0 0 16px var(--color-accent-glow)}.btn-secondary{background:var(--color-surface-2);color:var(--color-text-soft);border:1px solid var(--color-border)}.btn-secondary:hover{background:var(--color-surface-3);color:var(--color-text);border-color:var(--color-border-mid)}.btn-small{padding:.5rem 1rem;font-size:.875rem}.language-selector{background:transparent;border:1px solid var(--color-border);color:var(--color-text-soft);padding:.4rem .625rem;border-radius:var(--radius-sm);cursor:pointer;font-size:.8125rem;font-family:var(--font-body);transition:all .2s}.language-selector:hover{border-color:var(--color-border-mid);color:var(--color-text)}.dashboard-main{padding:5.5rem 2rem 4rem;min-height:100vh}.dashboard-container{max-width:1200px;margin:0 auto}.dashboard-header{margin-bottom:3rem;position:relative}.dashboard-header h1{font-family:var(--font-display);font-size:3rem;font-weight:700;font-style:italic;color:var(--color-text);margin:0 0 .75rem;letter-spacing:-.02em;line-height:1.1}.dashboard-header h1 span{color:var(--color-accent)}.dashboard-header p{font-size:1rem;color:var(--color-text-soft);margin:0;font-weight:300}.dashboard-tiles{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.25rem;margin-top:2rem}.dashboard-tile{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:2rem 1.75rem;text-align:left;cursor:pointer;transition:border-color .25s ease,box-shadow .25s ease,background .25s ease;position:relative;overflow:hidden}.dashboard-tile:before{content:"";position:absolute;top:0;left:0;width:3px;height:100%;background:var(--color-accent);opacity:0;transition:opacity .25s ease}.dashboard-tile:hover{background:var(--color-surface-2);border-color:var(--color-border-mid);box-shadow:var(--shadow-md)}.dashboard-tile:hover:before{opacity:1}.tile-icon{font-size:2rem;margin-bottom:1.25rem;display:block;line-height:1}.dashboard-tile h3{font-family:var(--font-display);font-size:1.5rem;font-weight:600;font-style:italic;color:var(--color-text);margin:0 0 .75rem;letter-spacing:-.01em}.dashboard-tile p{color:var(--color-text-soft);line-height:1.6;margin:0;font-size:.9rem;font-weight:300}.dashboard-section-wrapper{animation:sectionReveal .35s cubic-bezier(.22,1,.36,1) both}@keyframes sectionReveal{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.back-button{background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text-soft);padding:.5rem 1.125rem;border-radius:var(--radius-md);font-family:var(--font-body);font-size:.875rem;font-weight:500;cursor:pointer;margin-bottom:2rem;transition:all .2s ease;display:inline-flex;align-items:center;gap:.375rem}.back-button:hover{background:var(--color-surface-2);border-color:var(--color-border-mid);color:var(--color-text)}@media (max-width: 768px){.nav-container{flex-direction:column;gap:.75rem}.nav-center{order:3;width:100%;justify-content:center;gap:1.5rem}.nav-right{order:2;flex-wrap:wrap;justify-content:center}.dashboard-header h1{font-size:2.25rem}.dashboard-main{padding:5.5rem 1.25rem 1.5rem}}.products-section{width:100%}.products-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.products-header h3{font-size:1.5rem;font-weight:700;color:#1a1a1a;margin:0}.product-form-container{background:#fff;border:1px solid #e5e7eb;border-radius:1rem;padding:1.5rem;margin-bottom:2rem;box-shadow:0 2px 8px #0000000d}.form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid #e5e7eb}.form-header h4{font-size:1.25rem;font-weight:700;color:#1a1a1a;margin:0}.form-close{background:none;border:none;font-size:1.5rem;color:#6b7280;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:.5rem;transition:all .2s ease}.form-close:hover{background:#f3f4f6;color:#1a1a1a}.product-form{width:100%}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:1.5rem}.form-group{display:flex;flex-direction:column}.form-group.full-width{grid-column:1 / -1}.form-group label{font-size:.875rem;font-weight:500;color:#374151;margin-bottom:.5rem}.form-group input,.form-group textarea{padding:.625rem .75rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:.9375rem;color:#1a1a1a;transition:border-color .3s ease}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#10b981;box-shadow:0 0 0 3px #10b9811a}.form-actions{display:flex;gap:1rem;justify-content:flex-end}.products-list{display:flex;flex-direction:column;gap:1rem}.empty-state{text-align:center;padding:3rem;color:#6b7280}.empty-state p{margin:0;font-size:1rem}.product-card{background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;padding:1.5rem;transition:box-shadow .3s ease,transform .3s ease}.product-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.product-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.product-header h4{font-size:1.125rem;font-weight:600;color:#1a1a1a;margin:0}.product-actions{display:flex;gap:.5rem}.btn-icon{background:transparent;border:none;font-size:1.125rem;cursor:pointer;padding:.25rem .5rem;border-radius:.5rem;transition:background .2s ease}.btn-icon:hover{background:#f3f4f6}.product-description{color:#6b7280;font-size:.875rem;margin:0 0 1rem;line-height:1.5}.product-nutrition{display:flex;flex-direction:column;gap:.75rem}.nutrition-item{display:flex;justify-content:space-between;align-items:center;font-size:.875rem}.nutrition-label{color:#6b7280;font-weight:500}.nutrition-value{color:#1a1a1a;font-weight:600}.nutrition-macros{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;padding:1rem;background:#f9fafb;border-radius:.5rem}.macro-item{display:flex;flex-direction:column;align-items:center;gap:.25rem}.macro-label{font-size:.75rem;color:#6b7280;text-transform:uppercase;font-weight:500}.macro-value{font-size:1.125rem;color:#1a1a1a;font-weight:700}.nutrition-extras{display:flex;gap:1rem;font-size:.875rem;color:#6b7280;padding-top:.5rem;border-top:1px solid #e5e7eb}@media (max-width: 768px){.form-grid,.nutrition-macros{grid-template-columns:1fr}.form-actions{flex-direction:column}.form-actions button{width:100%}}.settings-page{width:100%;min-height:100vh;background:var(--color-bg)}.settings-container{display:flex;min-height:100vh;padding-top:1rem}.settings-sidebar{width:272px;background:var(--color-surface);border-right:1px solid var(--color-border);padding:2rem 0;position:sticky;top:0;height:100vh;overflow-y:auto}.sidebar-title{font-family:var(--font-display);font-size:1.25rem;font-weight:700;font-style:italic;color:var(--color-text);margin:0 0 1.5rem 1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--color-border);letter-spacing:-.01em}.sidebar-nav{display:flex;flex-direction:column;gap:.2rem;padding:0 .75rem}.sidebar-category{display:flex;flex-direction:column}.sidebar-nav-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:transparent;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .18s ease;text-align:left;width:100%;color:var(--color-text-soft);font-family:var(--font-body);font-size:.9375rem;font-weight:400;position:relative}.nav-item-arrow{margin-left:auto;font-size:.7rem;color:var(--color-text-muted);opacity:.6}.sidebar-nav-item:hover{background:var(--color-surface-2);color:var(--color-text)}.sidebar-nav-item.active{background:var(--color-accent-dim);color:var(--color-accent);font-weight:500}.sidebar-nav-item.active:before{content:"";position:absolute;left:0;top:20%;bottom:20%;width:2px;background:var(--color-accent);border-radius:1px}.sidebar-subcategories{display:flex;flex-direction:column;margin-left:1rem;margin-top:.2rem;padding-left:.5rem;border-left:1px solid var(--color-border)}.sidebar-subcategory-item{padding:.625rem 1rem;font-size:.875rem;margin-left:.25rem}.sidebar-subcategory-item.active{background:var(--color-accent-dim);color:var(--color-accent)}.nav-item-icon{font-size:1.125rem;width:22px;text-align:center;flex-shrink:0}.nav-item-label{flex:1}.settings-main{flex:1;padding:3rem;background:var(--color-bg)}.category-content{max-width:800px}.category-content h2{font-family:var(--font-display);font-size:2rem;font-weight:700;font-style:italic;color:var(--color-text);margin:0 0 .75rem;letter-spacing:-.02em}.category-content p{font-size:1rem;color:var(--color-text-soft);line-height:1.7;margin:0;font-weight:300}.drawer-toggle-btn{position:fixed;top:.875rem;left:1rem;z-index:1000;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:.625rem .875rem;font-size:1.25rem;cursor:pointer;display:none;transition:all .2s;color:var(--color-text-soft)}.drawer-toggle-btn:hover{background:var(--color-surface-2);color:var(--color-text)}.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:998;display:none;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.drawer-header{display:flex;justify-content:space-between;align-items:center;padding:0 1.5rem 1rem;margin-bottom:1.5rem;border-bottom:1px solid var(--color-border)}.drawer-close-btn{background:transparent;border:none;font-size:1.25rem;cursor:pointer;color:var(--color-text-muted);padding:.25rem .5rem;border-radius:var(--radius-sm);transition:all .2s;font-family:var(--font-body)}.drawer-close-btn:hover{background:var(--color-surface-2);color:var(--color-text-soft)}@media (max-width: 768px){.drawer-toggle-btn,.drawer-overlay{display:block}.settings-container{flex-direction:column;position:relative}.settings-sidebar{position:fixed;top:0;left:0;width:272px;height:100vh;z-index:999;transform:translate(-100%);transition:transform .3s cubic-bezier(.22,1,.36,1);box-shadow:8px 0 32px #00000080}.settings-sidebar.drawer-open{transform:translate(0)}.settings-main{padding:2rem 1.25rem;width:100%}}.strava-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:1rem}.strava-modal-container{background:#fff;border-radius:1rem;max-width:800px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 10px 25px #0003}.strava-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e5e7eb}.strava-modal-header h2{margin:0;font-size:1.5rem;font-weight:700;color:#1a1a1a}.strava-modal-close{background:none;border:none;font-size:2rem;cursor:pointer;color:#6b7280;line-height:1;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:.25rem;transition:background-color .2s}.strava-modal-close:hover{background-color:#f3f4f6}.strava-modal-content{padding:1.5rem;overflow-y:auto;flex:1}.strava-connect-section{text-align:center;padding:3rem 1rem}.strava-connect-section p{margin-bottom:1.5rem;color:#6b7280;font-size:1rem}.strava-connect-button{background:#fc4c02;color:#fff;border:none;padding:.75rem 2rem;border-radius:.5rem;font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .2s}.strava-connect-button:hover:not(:disabled){background:#e04402}.strava-connect-button:disabled{background:#d1d5db;cursor:not-allowed}.strava-config-warning{background:#fef3c7;border:1px solid #f59e0b;border-radius:.5rem;padding:1.5rem;margin-top:1rem;text-align:left}.strava-config-warning p{margin:0 0 .75rem;color:#92400e;font-weight:600}.strava-config-warning p:last-child{margin-bottom:0}.strava-config-help{font-size:.875rem;font-weight:400!important;color:#78350f!important;line-height:1.6}.strava-config-help code{background:#fef3c7;padding:.125rem .375rem;border-radius:.25rem;font-family:Courier New,monospace;font-size:.875rem;color:#92400e}.strava-error{background:#fee2e2;color:#991b1b;padding:.75rem;border-radius:.5rem;margin-top:1rem;font-size:.875rem}.strava-loading,.strava-empty{text-align:center;padding:3rem 1rem;color:#6b7280}.strava-activities-list{display:flex;flex-direction:column;gap:1rem}.strava-activity-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:.75rem;padding:1.25rem;transition:box-shadow .2s}.strava-activity-card:hover{box-shadow:0 4px 6px #0000001a}.strava-activity-header{display:flex;align-items:flex-start;gap:1rem;margin-bottom:.75rem}.strava-activity-icon{font-size:2rem;line-height:1}.strava-activity-title{flex:1}.strava-activity-title h3{margin:0 0 .25rem;font-size:1.125rem;font-weight:600;color:#1a1a1a}.strava-activity-type{display:inline-block;background:#e0f2fe;color:#0369a1;padding:.25rem .75rem;border-radius:.375rem;font-size:.75rem;font-weight:600}.strava-activity-date{color:#6b7280;font-size:.875rem;margin-bottom:1rem}.strava-activity-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.75rem;margin-bottom:.75rem}.strava-stat{display:flex;flex-direction:column;gap:.25rem}.strava-stat-label{font-size:.75rem;color:#6b7280;font-weight:500}.strava-stat-value{font-size:.9375rem;color:#1a1a1a;font-weight:600}.strava-activity-description{margin-top:.75rem;padding-top:.75rem;border-top:1px solid #e5e7eb;color:#4b5563;font-size:.875rem;line-height:1.5}.strava-pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:2rem;padding-top:1.5rem;border-top:1px solid #e5e7eb}.strava-pagination-button{background:#10b981;color:#fff;border:none;padding:.5rem 1rem;border-radius:.5rem;font-size:.875rem;font-weight:600;cursor:pointer;transition:background-color .2s}.strava-pagination-button:hover:not(:disabled){background:#059669}.strava-pagination-button:disabled{background:#d1d5db;cursor:not-allowed}.strava-pagination-info{color:#6b7280;font-size:.875rem}@media (max-width: 768px){.strava-modal-container{max-width:100%;max-height:95vh}.strava-activity-stats{grid-template-columns:1fr}}.premium-payment-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:1rem}.premium-payment-modal{background:#fff;border-radius:1rem;box-shadow:0 10px 25px #0003;max-width:500px;width:100%;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column}.premium-payment-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e5e7eb}.premium-payment-header h2{margin:0;font-size:1.5rem;font-weight:700;color:#1a1a1a}.premium-payment-close{background:transparent;border:none;font-size:2rem;color:#6b7280;cursor:pointer;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:.25rem;transition:all .2s}.premium-payment-close:hover{background:#f3f4f6;color:#1a1a1a}.premium-payment-content{padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem}.premium-features{display:flex;flex-direction:column;gap:1rem}.premium-features h3{margin:0;font-size:1.125rem;font-weight:600;color:#1a1a1a}.premium-features ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem}.premium-features li{padding-left:1.5rem;position:relative;color:#374151;font-size:.9375rem}.premium-features li:before{content:"✓";position:absolute;left:0;color:#10b981;font-weight:700}.premium-price{text-align:center;padding:1.5rem;background:#f9fafb;border-radius:.75rem;border:2px solid #e5e7eb}.price-amount{display:flex;align-items:baseline;justify-content:center;gap:.5rem;margin-bottom:.5rem}.price-value{font-size:2.5rem;font-weight:700;color:#1a1a1a}.price-currency{font-size:1.5rem;font-weight:600;color:#6b7280}.price-description{margin:0;font-size:.875rem;color:#6b7280}.premium-error{padding:.75rem;background:#fee2e2;color:#dc2626;border-radius:.5rem;font-size:.875rem;text-align:center}.premium-payment-actions{display:flex;gap:1rem;justify-content:flex-end}.premium-payment-actions .btn{padding:.75rem 1.5rem;border:none;border-radius:.5rem;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .3s ease}.premium-payment-actions .btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:#10b981;color:#fff}.btn-primary:hover:not(:disabled){background:#059669}.btn-secondary{background:#fff;color:#1a1a1a;border:1px solid #e5e7eb}.btn-secondary:hover:not(:disabled){background:#f9fafb;border-color:#d1d5db}@media (max-width: 768px){.premium-payment-modal{max-width:95vw}.premium-payment-header,.premium-payment-content{padding:1rem}.premium-payment-actions{flex-direction:column}.premium-payment-actions .btn{width:100%}}.profile-page{min-height:100vh;padding:5.5rem 2rem 2rem;background:var(--color-bg)}.profile-container{max-width:800px;margin:0 auto;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:2.5rem;box-shadow:var(--shadow-md)}.profile-container h1{font-family:var(--font-display);font-size:2rem;font-weight:700;font-style:italic;color:var(--color-text);margin-bottom:2rem;letter-spacing:-.02em}.profile-form{margin-bottom:3rem}.form-group{margin-bottom:1.375rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;font-size:.875rem;color:var(--color-text-soft);letter-spacing:.02em}.form-group input,.form-group select{width:100%;padding:.75rem 1rem;border:1px solid var(--color-border-mid);border-radius:var(--radius-md);font-size:.9375rem;font-family:var(--font-body);background:var(--color-surface-2);color:var(--color-text);box-sizing:border-box;transition:border-color .2s ease,box-shadow .2s ease}.form-group input::-moz-placeholder{color:var(--color-text-muted)}.form-group input::placeholder{color:var(--color-text-muted)}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 2px var(--color-accent-dim)}.form-group select option{background:var(--color-surface-2);color:var(--color-text)}.submit-button{background:var(--color-accent);color:#0d0f14;padding:.75rem 2rem;border:none;border-radius:var(--radius-md);font-family:var(--font-body);font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s ease}.submit-button:hover:not(:disabled){filter:brightness(1.08);box-shadow:0 0 16px var(--color-accent-glow)}.submit-button:disabled{opacity:.4;cursor:not-allowed}.error-message{background:var(--color-coral-dim);color:var(--color-coral);border:1px solid rgba(224,123,110,.25);padding:1rem;border-radius:var(--radius-md);margin-bottom:1rem;font-size:.9rem}.loading{text-align:center;padding:2rem;color:var(--color-text-muted);font-style:italic;font-family:var(--font-display);font-size:1rem}.premium-section,.wallet-section,.strava-section{margin-top:2.5rem;padding-top:2rem;border-top:1px solid var(--color-border)}.premium-section h2,.wallet-section h2,.strava-section h2{font-family:var(--font-display);font-size:1.5rem;font-weight:600;font-style:italic;color:var(--color-text);margin-bottom:.75rem;letter-spacing:-.01em}.premium-section p,.wallet-section p,.strava-section p{margin-bottom:1rem;color:var(--color-text-soft);font-size:.9375rem;line-height:1.6;font-weight:300}.premium-section .btn,.premium-section .btn-primary{background:var(--color-accent);color:#0d0f14;padding:.75rem 1.5rem;border:none;border-radius:var(--radius-md);font-family:var(--font-body);font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s ease}.premium-section .btn-primary:hover{filter:brightness(1.08);box-shadow:0 0 16px var(--color-accent-glow)}.wallet-connected{display:flex;flex-direction:column;gap:1rem}.wallet-status{display:flex;align-items:center;gap:.75rem;padding:1rem;background:var(--color-mint-dim);border:1px solid rgba(78,202,139,.2);border-radius:var(--radius-md);color:var(--color-mint)}.wallet-status-icon{font-size:1.25rem;font-weight:700}.wallet-status-text{font-weight:500;font-size:.9375rem}.wallet-address{display:flex;flex-direction:column;gap:.25rem;padding:.875rem 1rem;background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-md)}.wallet-address-label{font-size:.8125rem;color:var(--color-text-muted);font-weight:500;letter-spacing:.03em;text-transform:uppercase}.wallet-address-value{font-size:.875rem;color:var(--color-text-soft);font-family:var(--font-mono);word-break:break-all}.wallet-disconnect-button{padding:.75rem 1.5rem;background:#e07b6e1a;color:var(--color-coral);border:1px solid rgba(224,123,110,.25);border-radius:var(--radius-md);font-family:var(--font-body);font-size:.9375rem;font-weight:500;cursor:pointer;align-self:flex-start;transition:all .2s ease}.wallet-disconnect-button:hover{background:#e07b6e2e}.wallet-not-connected{padding:1.25rem;background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-md)}.strava-connected{display:flex;flex-direction:column;gap:1rem}.strava-status{display:flex;align-items:center;gap:.75rem;padding:1rem;background:var(--color-mint-dim);border:1px solid rgba(78,202,139,.2);border-radius:var(--radius-md);color:var(--color-mint)}.strava-status-icon{font-size:1.25rem;font-weight:700}.strava-status-text{font-weight:500;font-size:.9375rem}.strava-view-activities-button,.strava-connect-button,.strava-disconnect-button{padding:.75rem 1.5rem;border:none;border-radius:var(--radius-md);font-family:var(--font-body);font-size:.9375rem;font-weight:500;cursor:pointer;transition:all .2s ease}.strava-view-activities-button,.strava-connect-button{background:#fc4c02;color:#fff}.strava-view-activities-button:hover,.strava-connect-button:hover:not(:disabled){filter:brightness(1.1);box-shadow:0 4px 16px #fc4c024d}.strava-connect-button:disabled{opacity:.45;cursor:not-allowed}.strava-disconnect-button{background:#e07b6e1a;color:var(--color-coral);border:1px solid rgba(224,123,110,.25)}.strava-disconnect-button:hover{background:#e07b6e2e}.strava-not-connected{padding:1.25rem;background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-md)}.strava-config-warning{margin-top:.5rem;color:var(--color-accent);font-size:.875rem;opacity:.8}@media (max-width: 768px){.profile-page{padding:5rem 1.25rem 1.25rem}.profile-container{padding:1.75rem 1.25rem}}.admin-page{width:100%;min-height:100vh;background:var(--color-bg)}.admin-boot{display:flex;align-items:center;justify-content:center;height:100vh}.admin-boot-dots{display:flex;gap:7px}.admin-boot-dots span{display:block;width:5px;height:5px;border-radius:50%;background:var(--color-accent);animation:boot-blink 1.2s ease-in-out infinite both}.admin-boot-dots span:nth-child(2){animation-delay:.18s}.admin-boot-dots span:nth-child(3){animation-delay:.36s}@keyframes boot-blink{0%,80%,to{opacity:.15;transform:scale(.75)}40%{opacity:1;transform:scale(1)}}.admin-shell{display:flex;min-height:100vh;padding-left:3.5rem}.admin-sidebar{width:220px;flex-shrink:0;position:fixed;left:3.5rem;top:0;bottom:0;display:flex;flex-direction:column;justify-content:space-between;background:#090b10;border-right:1px solid var(--color-border);z-index:5;background-image:radial-gradient(circle,rgba(255,255,255,.035) 1px,transparent 1px);background-size:22px 22px}.admin-sidebar-top{display:flex;flex-direction:column;flex:1;overflow-y:auto}.admin-wordmark{padding:1.75rem 1.375rem 1.375rem;border-bottom:1px solid var(--color-border);display:flex;align-items:center;gap:.75rem}.admin-wordmark-main{font-family:var(--font-display);font-size:1.25rem;font-weight:700;font-style:italic;letter-spacing:-.02em;color:var(--color-accent);white-space:nowrap}.admin-wordmark-rule{display:block;flex:1;height:1px;background:linear-gradient(to right,var(--color-border-mid),transparent)}.admin-nav{display:flex;flex-direction:column;gap:1px;padding:1.125rem .625rem}.admin-nav-btn{position:relative;display:flex;align-items:center;gap:.875rem;width:100%;padding:.8125rem .875rem;border:none;border-radius:var(--radius-md);background:transparent;cursor:pointer;text-align:left;transition:background .16s ease;animation:nav-enter .35s cubic-bezier(.22,1,.36,1) both;animation-delay:var(--delay, 0ms)}@keyframes nav-enter{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.admin-nav-btn:hover{background:#f0b4290d}.admin-nav-btn.is-active{background:#f0b42912}.admin-nav-bar{position:absolute;left:0;top:18%;bottom:18%;width:2px;border-radius:0 2px 2px 0;background:var(--color-accent);box-shadow:0 0 10px var(--color-accent-glow),0 0 20px var(--color-accent-dim);opacity:0;transform:scaleY(.3);transition:opacity .2s ease,transform .25s cubic-bezier(.22,1,.36,1)}.admin-nav-btn.is-active .admin-nav-bar{opacity:1;transform:scaleY(1)}.admin-nav-index{font-size:.6875rem;font-weight:600;letter-spacing:.04em;color:var(--color-text-muted);font-family:var(--font-mono);flex-shrink:0;width:1.5rem;transition:color .16s}.admin-nav-btn.is-active .admin-nav-index{color:var(--color-accent)}.admin-nav-body{display:flex;flex-direction:column;gap:.125rem;min-width:0}.admin-nav-name{font-size:.875rem;font-weight:500;color:var(--color-text-soft);line-height:1;transition:color .16s}.admin-nav-btn.is-active .admin-nav-name,.admin-nav-btn:hover .admin-nav-name{color:var(--color-text)}.admin-nav-hint{font-size:.7rem;color:var(--color-text-muted);line-height:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-sidebar-foot{display:flex;align-items:center;gap:.5rem;padding:1rem 1.375rem;border-top:1px solid var(--color-border)}.admin-status-pip{width:6px;height:6px;border-radius:50%;background:var(--color-mint);box-shadow:0 0 6px var(--color-mint);flex-shrink:0;animation:pip-breathe 2.4s ease-in-out infinite}@keyframes pip-breathe{0%,to{opacity:1}50%{opacity:.4}}.admin-status-text{font-size:.6875rem;color:var(--color-text-muted);letter-spacing:.04em;text-transform:uppercase;font-family:var(--font-mono)}.admin-main{flex:1;margin-left:220px;min-height:100vh;display:flex;flex-direction:column}.admin-pane{flex:1;transition:opacity .16s ease,transform .16s ease}.admin-pane.is-fading{opacity:0;transform:translateY(5px)}.admin-header{padding:2.75rem 2.5rem 0;max-width:860px}.admin-eyebrow{font-size:.6875rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--color-accent);margin:0 0 .4rem;font-family:var(--font-mono)}.admin-headline{font-family:var(--font-display);font-size:3.25rem;font-weight:700;font-style:italic;letter-spacing:-.035em;color:var(--color-text);margin:0 0 .6rem;line-height:1}.admin-subtitle{font-size:.9375rem;color:var(--color-text-soft);margin:0 0 2rem;font-weight:300;max-width:460px;line-height:1.6;border-bottom:1px solid var(--color-border);padding-bottom:1.75rem}.admin-error{background:#e07b6e12;border:1px solid rgba(224,123,110,.18);color:var(--color-coral);border-radius:var(--radius-md);padding:.875rem 1.125rem;font-size:.9rem;margin-bottom:1rem}.admin-loading{display:flex;align-items:center;gap:.75rem;color:var(--color-text-soft);font-size:.9375rem;padding:1.5rem 0}.admin-spinner{width:18px;height:18px;border:1.5px solid var(--color-border-mid);border-top-color:var(--color-accent);border-radius:50%;animation:admin-spin .75s linear infinite;flex-shrink:0}@keyframes admin-spin{to{transform:rotate(360deg)}}.admin-section-body{padding:0 2.5rem 4rem;max-width:980px}.recipe-search-form{margin-bottom:1.5rem}.recipe-search-row{display:flex;gap:.625rem;flex-wrap:wrap}.recipe-search-input{flex:1;min-width:240px;padding:.625rem 1rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text);font-family:var(--font-body);font-size:.9375rem;transition:border-color .18s,box-shadow .18s}.recipe-search-input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-dim)}.recipe-search-input::-moz-placeholder{color:var(--color-text-muted)}.recipe-search-input::placeholder{color:var(--color-text-muted)}.recipe-search-input:disabled{opacity:.5}.recipe-max-select{padding:.625rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text);font-family:var(--font-body);font-size:.9375rem;cursor:pointer;transition:border-color .18s}.recipe-max-select:focus{outline:none;border-color:var(--color-accent)}.btn-primary{padding:.625rem 1.5rem;background:var(--color-accent);color:#09090b;border:none;border-radius:var(--radius-md);font-family:var(--font-body);font-size:.9rem;font-weight:600;cursor:pointer;transition:background .18s,box-shadow .18s;white-space:nowrap;letter-spacing:.01em}.btn-primary:hover:not(:disabled){background:#f8c444;box-shadow:0 0 20px var(--color-accent-glow)}.btn-primary:disabled{opacity:.35;cursor:not-allowed}.recipe-count{font-size:.8125rem;color:var(--color-text-muted);margin:0 0 1rem;font-family:var(--font-mono);letter-spacing:.02em}.recipe-card{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);margin-bottom:.5rem;overflow:hidden;transition:border-color .18s,box-shadow .18s}.recipe-card:hover{border-color:var(--color-border-mid);box-shadow:0 4px 20px #00000059}.recipe-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;padding:.875rem 1rem;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;flex-wrap:wrap}.recipe-card-left{display:flex;align-items:flex-start;gap:.75rem;flex:1;min-width:0}.recipe-expand-icon{color:var(--color-text-muted);font-size:.75rem;margin-top:.25rem;flex-shrink:0;transition:transform .2s ease}.recipe-title{font-weight:600;color:var(--color-text);font-size:.9375rem;line-height:1.4}.recipe-match-reason{font-size:.8125rem;color:var(--color-text-soft);margin-top:.2rem;font-style:italic}.recipe-macros{display:flex;gap:.375rem;align-items:center;flex-wrap:wrap;flex-shrink:0}.macro-badge{font-size:.75rem;font-weight:500;padding:.2rem .5rem;border-radius:999px;background:var(--color-surface-2);color:var(--color-text-soft);white-space:nowrap;font-family:var(--font-mono)}.macro-badge.macro-p{color:var(--color-sky)}.macro-badge.macro-c{color:var(--color-accent)}.macro-badge.macro-f{color:var(--color-coral)}.recipe-card-body{padding:.875rem 1rem 1rem 2.625rem;border-top:1px solid var(--color-border)}.recipe-description{font-size:.9rem;color:var(--color-text-soft);margin:0 0 .75rem;line-height:1.6}.recipe-ingredients{font-size:.875rem;color:var(--color-text-soft);margin-bottom:.75rem}.recipe-ingredients p{margin:.25rem 0 0;line-height:1.6}.recipe-link{display:inline-block;font-size:.875rem;font-weight:500;color:var(--color-accent);text-decoration:none;transition:opacity .18s}.recipe-link:hover{opacity:.75;text-decoration:underline}@media (max-width: 860px){.admin-shell{flex-direction:column;padding-left:0}.admin-sidebar{position:relative;left:0;width:100%;min-height:auto;flex-direction:row;border-right:none;border-bottom:1px solid var(--color-border);background-image:none;background-color:#090b10}.admin-sidebar-top{flex-direction:row;align-items:center;overflow-x:auto;flex:1}.admin-wordmark{border-bottom:none;border-right:1px solid var(--color-border);padding:.875rem 1.25rem;flex-shrink:0}.admin-wordmark-rule{display:none}.admin-nav{flex-direction:row;padding:.5rem;gap:2px}.admin-nav-btn{flex-direction:column;align-items:center;padding:.625rem .875rem;gap:.25rem;animation:none}.admin-nav-bar{top:0;left:15%;right:15%;bottom:auto;width:auto;height:2px;border-radius:0 0 2px 2px}.admin-nav-index,.admin-nav-hint{display:none}.admin-nav-name{font-size:.8125rem}.admin-sidebar-foot{display:none}.admin-main{margin-left:0}.admin-header{padding:1.75rem 1.25rem 0}.admin-headline{font-size:2.25rem}.admin-section-body{padding:0 1.25rem 3rem}.recipe-search-row{flex-direction:column}.recipe-search-input{min-width:0;width:100%}.recipe-card-header{flex-direction:column;gap:.625rem}.recipe-macros{margin-left:1.5rem}}.app{width:100%;min-height:100vh;background-color:var(--color-bg);color:var(--color-text)}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:DM Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.visible{visibility:visible}.collapse{visibility:collapse}.absolute{position:absolute}.relative{position:relative}.block{display:block}.inline-block{display:inline-block}.flex{display:flex}.table{display:table}.grid{display:grid}.hidden{display:none}.grow{flex-grow:1}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.resize{resize:both}.border{border-width:1px}.italic{font-style:italic}.blur{--tw-blur: blur(8px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}:root{--font-display: "Cormorant Garamond", Georgia, serif;--font-body: "DM Sans", system-ui, sans-serif;--font-mono: "DM Mono", "Courier New", monospace;--color-bg: #0d0f14;--color-surface: #141720;--color-surface-2: #1c2030;--color-surface-3: #222840;--color-border: rgba(255, 255, 255, .07);--color-border-mid: rgba(255, 255, 255, .12);--color-accent: #f0b429;--color-accent-dim: rgba(240, 180, 41, .12);--color-accent-glow: rgba(240, 180, 41, .25);--color-mint: #4eca8b;--color-mint-dim: rgba(78, 202, 139, .12);--color-coral: #e07b6e;--color-coral-dim: rgba(224, 123, 110, .12);--color-sky: #5aabee;--color-sky-dim: rgba(90, 171, 238, .12);--color-text: #e8e4dc;--color-text-soft: #8b8fa8;--color-text-muted: #4a4e62;--radius-sm: .375rem;--radius-md: .625rem;--radius-lg: 1rem;--radius-xl: 1.5rem;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .4);--shadow-md: 0 4px 16px rgba(0, 0, 0, .5);--shadow-lg: 0 12px 40px rgba(0, 0, 0, .6);--shadow-glow: 0 0 24px var(--color-accent-glow)}*,*:before,*:after{box-sizing:border-box}:root{font-family:var(--font-body);line-height:1.6;font-weight:400;color-scheme:dark;color:var(--color-text);background-color:var(--color-bg);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh;background-color:var(--color-bg);background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.03'/%3E%3C/svg%3E")}#root{width:100%;min-height:100vh}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:600;color:var(--color-text);line-height:1.2}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--color-bg)}::-webkit-scrollbar-thumb{background:var(--color-surface-3);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}::-moz-selection{background:var(--color-accent-glow);color:var(--color-text)}::selection{background:var(--color-accent-glow);color:var(--color-text)}
