/* KetoDock - Components: MD3 */

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--sp-2);padding:var(--sp-3) var(--sp-6);border:none;border-radius:var(--r-full);font-weight:500;font-size:.9375rem;height:40px;cursor:pointer;transition:background .15s,opacity .15s;-webkit-tap-highlight-color:transparent}
.btn:active{transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}
.btn-primary{background:var(--accent);color:var(--on-accent)}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}
.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:var(--danger-hover)}
.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary)}
.btn-lg{padding:var(--sp-4) var(--sp-8);font-size:1rem;height:48px}
.btn-block{width:100%}

/* Forms */
.form-group{display:flex;flex-direction:column;gap:var(--sp-2)}
.form-label{font-size:.875rem;font-weight:500;color:var(--text-secondary)}
.form-input{width:100%;padding:var(--sp-3) var(--sp-4);background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--r-md);color:var(--text-primary);font-size:1rem;transition:border-color .15s}
.form-input:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 2px var(--accent-faint)}
.form-input::placeholder{color:var(--text-muted)}
.form-input-lg{padding:var(--sp-4) var(--sp-5);font-size:1.5rem;font-weight:600;text-align:center;font-family:var(--font-mono)}

/* Cards */
.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--r-md);padding:var(--sp-5)}
.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--sp-4)}
.card-title{font-size:.875rem;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}

/* GKI Display */
.gki-display{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--sp-8);border-radius:var(--r-xl);text-align:center;position:relative;overflow:hidden}
.gki-display::before{content:'';position:absolute;inset:0;background:var(--zone-color,var(--zone-green));opacity:.15;border-radius:inherit}
.gki-display::after{content:'';position:absolute;inset:0;border:2px solid var(--zone-color,var(--zone-green));border-radius:inherit;opacity:.4}
.gki-value{font-size:4rem;font-weight:800;line-height:1;color:var(--zone-color,var(--zone-green));position:relative;z-index:1;font-family:var(--font-mono)}
.gki-label{font-size:.875rem;font-weight:500;color:var(--text-secondary);margin-top:var(--sp-2);position:relative;z-index:1}
.gki-zone-label{font-size:.875rem;font-weight:600;color:var(--zone-color,var(--zone-green));text-transform:uppercase;letter-spacing:.08em;margin-top:var(--sp-1);position:relative;z-index:1}

/* Reading Values */
.reading-pair{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-3)}
.reading-value-card{display:flex;flex-direction:column;align-items:center;padding:var(--sp-4);background:var(--bg-primary);border-radius:var(--r-md)}
.reading-number{font-size:1.75rem;font-weight:700;font-family:var(--font-mono);line-height:1.2}
.reading-unit{font-size:.875rem;color:var(--text-muted);margin-top:var(--sp-1)}
.reading-name{font-size:.875rem;color:var(--text-secondary);font-weight:500;margin-top:var(--sp-1)}

/* Week Dots */
.week-dots{display:flex;justify-content:space-between;gap:var(--sp-2);padding:var(--sp-2) 0}
.week-dot{display:flex;flex-direction:column;align-items:center;gap:var(--sp-1);flex:1}
.week-dot-circle{width:32px;height:32px;border-radius:50%;background:var(--bg-hover);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;font-family:var(--font-mono)}
.week-dot-circle[data-zone="purple"]{background:var(--zone-purple);color:#fff}
.week-dot-circle[data-zone="blue"]{background:var(--zone-blue);color:#fff}
.week-dot-circle[data-zone="green"]{background:var(--zone-green);color:#0F172A}
.week-dot-circle[data-zone="orange"]{background:var(--zone-orange);color:#fff}
.week-dot-circle[data-zone="red"]{background:var(--zone-red);color:#fff}
.week-dot-day{font-size:.75rem;color:var(--text-muted);text-transform:uppercase}

/* Modal */
.modal-overlay{position:fixed;inset:0;background:var(--scrim);backdrop-filter:blur(4px);display:flex;align-items:flex-end;justify-content:center;z-index:100;opacity:0;pointer-events:none;transition:opacity .2s}
.modal-overlay.active{opacity:1;pointer-events:auto}
.modal{background:var(--bg-secondary);border-radius:var(--r-xl) var(--r-xl) 0 0;width:100%;max-width:480px;max-height:90dvh;overflow-y:auto;padding:var(--sp-6);transform:translateY(100%);transition:transform .3s cubic-bezier(.32,.72,0,1)}
.modal-overlay.active .modal{transform:translateY(0)}
.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--sp-6)}
.modal-title{font-size:1.25rem;font-weight:600}
.modal-close{width:32px;height:32px;border-radius:var(--r-full);background:var(--bg-hover);border:none;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.25rem;line-height:1}
.modal-close:hover{background:var(--border-color)}
.modal-body{display:flex;flex-direction:column;gap:var(--sp-5)}
.modal-footer{margin-top:var(--sp-6);display:flex;gap:var(--sp-3)}

/* GKI Preview */
.gki-preview{text-align:center;padding:var(--sp-4);border-radius:var(--r-md);background:var(--bg-primary)}
.gki-preview-value{font-size:2rem;font-weight:700;font-family:var(--font-mono)}
.gki-preview-label{font-size:.875rem;color:var(--text-secondary);margin-top:var(--sp-1)}

/* Bottom Nav — MD3: 80px content + safe area below */
.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:var(--bg-secondary);border-top:1px solid var(--border-color);display:flex;height:calc(var(--nav-h) + env(safe-area-inset-bottom,0));padding-bottom:env(safe-area-inset-bottom,0);z-index:50}
.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;background:none;border:none;color:var(--text-muted);font-size:.75rem;font-weight:500;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:color .15s;text-decoration:none;position:relative}
.bottom-nav-item.active{color:var(--accent)}.bottom-nav-item:hover{color:var(--text-primary)}
.bottom-nav-icon{width:22px;height:22px}
/* Active indicator pill */
.bottom-nav-item.active::before{content:'';position:absolute;top:4px;left:50%;transform:translateX(-50%);width:48px;height:28px;border-radius:var(--r-full);background:var(--accent-faint);z-index:-1}

/* FAB */
.fab{position:fixed;bottom:calc(var(--nav-h) + env(safe-area-inset-bottom,0) + 16px);right:16px;width:56px;height:56px;border-radius:var(--r-lg);background:var(--accent);color:var(--on-accent);border:none;box-shadow:var(--shadow-lg);cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:40;font-size:1.5rem;transition:background .15s,transform .1s}
.fab:hover{background:var(--accent-hover)}.fab:active{transform:scale(.93)}
.fab-secondary{bottom:calc(var(--nav-h) + env(safe-area-inset-bottom,0) + 84px);background:var(--bg-secondary);color:var(--text-primary);border:2px solid var(--border-color);font-size:1.25rem}
.fab-secondary:hover{background:var(--bg-hover)}

/* Sidebar */
.sidebar{display:none}
.sidebar-logo{font-size:1.25rem;font-weight:700;color:var(--text-primary);padding:var(--sp-6) var(--sp-5);border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between}
.sidebar-nav{padding:var(--sp-4) var(--sp-3);display:flex;flex-direction:column;gap:var(--sp-1)}
.sidebar-item{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);border-radius:var(--r-full);color:var(--text-secondary);font-weight:500;font-size:.9375rem;cursor:pointer;transition:background .15s,color .15s;border:none;background:none;width:100%;text-align:left;text-decoration:none}
.sidebar-item:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar-item.active{background:var(--accent-faint);color:var(--accent)}
.sidebar-icon{width:20px;height:20px;flex-shrink:0}
.sidebar-footer{margin-top:auto;padding:var(--sp-4) var(--sp-3);border-top:1px solid var(--border-color)}

/* Top Bar */
.top-bar{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-3) var(--sp-4);padding-top:calc(env(safe-area-inset-top,0px) + var(--sp-3));background:var(--bg-secondary);border-bottom:1px solid var(--border-color);position:sticky;top:0;z-index:30}
.top-bar-title{font-size:1.125rem;font-weight:700}
.top-bar-avatar{width:32px;height:32px;border-radius:50%;background:var(--accent);color:var(--on-accent);display:flex;align-items:center;justify-content:center;font-size:.8125rem;font-weight:600;cursor:pointer;border:none}

/* Auth */
.auth-container{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:var(--sp-6)}
.auth-card{width:100%;max-width:400px}
.auth-header{text-align:center;margin-bottom:var(--sp-8)}
.auth-logo{font-size:2rem;font-weight:800;margin-bottom:var(--sp-2)}
.auth-subtitle{color:var(--text-secondary);font-size:.9375rem}
.auth-form{display:flex;flex-direction:column;gap:var(--sp-5)}
.auth-toggle{text-align:center;margin-top:var(--sp-6);color:var(--text-secondary);font-size:.875rem}
.auth-toggle a{font-weight:500}
.auth-alert{padding:var(--sp-3) var(--sp-4);border-radius:var(--r-md);font-size:.875rem;background:rgba(239,68,68,.15);color:var(--danger);border:1px solid rgba(239,68,68,.3)}

/* Profile */
.profile-info{display:flex;flex-direction:column;gap:var(--sp-5)}
.profile-avatar-lg{width:64px;height:64px;border-radius:50%;background:var(--accent);color:var(--on-accent);display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;margin:0 auto}
.profile-field{display:flex;flex-direction:column;gap:var(--sp-1)}
.profile-field-label{font-size:.875rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}
.profile-field-value{font-size:1rem;color:var(--text-primary)}

/* Toast */
.toast-container{position:fixed;top:var(--sp-4);right:var(--sp-4);z-index:200;display:flex;flex-direction:column;gap:var(--sp-2)}
.toast{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--r-md);padding:var(--sp-3) var(--sp-4);font-size:.875rem;box-shadow:var(--shadow-lg);animation:toast-in .3s ease-out;max-width:320px}
.toast-success{border-left:3px solid var(--success)}.toast-error{border-left:3px solid var(--danger)}
@keyframes toast-in{from{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}

/* Skeleton */
.skeleton{background:linear-gradient(90deg,var(--bg-hover) 25%,var(--bg-input) 50%,var(--bg-hover) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--r-md)}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* Readings List */
.readings-list{display:flex;flex-direction:column;gap:var(--sp-2)}
.reading-item{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);background:var(--bg-primary);border-radius:var(--r-md)}
.reading-item-zone{width:8px;height:36px;border-radius:4px;flex-shrink:0}
.reading-item-values{flex:1;display:flex;flex-direction:column;gap:2px}
.reading-item-main{font-weight:600;font-family:var(--font-mono);font-size:.9375rem}
.reading-item-sub{font-size:.875rem;color:var(--text-muted)}
.reading-item-time{font-size:.875rem;color:var(--text-muted);text-align:right}

/* Context Select */
.context-select{display:flex;gap:var(--sp-2)}
.context-option{flex:1;padding:var(--sp-2) var(--sp-3);border:1px solid var(--border-color);border-radius:var(--r-full);background:var(--bg-primary);color:var(--text-secondary);font-size:.875rem;text-align:center;cursor:pointer;transition:border-color .15s,color .15s}
.context-option.active{border-color:var(--accent);color:var(--accent);background:var(--accent-faint)}

/* Empty State */
.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--sp-12) var(--sp-6);text-align:center;color:var(--text-muted)}
.empty-state-icon{font-size:3rem;margin-bottom:var(--sp-4);opacity:.4}
.empty-state-text{font-size:.9375rem;margin-bottom:var(--sp-4)}

/* History Tabs */
.history-tabs{display:flex;gap:var(--sp-2);padding:var(--sp-2) 0}
.history-tab{flex:1;padding:var(--sp-2) var(--sp-3);border:1px solid var(--border-color);border-radius:var(--r-full);background:var(--bg-card);color:var(--text-secondary);font-size:.875rem;font-weight:500;text-align:center;cursor:pointer;transition:all .15s}
.history-tab.active{border-color:var(--accent);color:var(--accent);background:var(--accent-faint)}
.history-tab:hover:not(.active){background:var(--bg-hover)}

/* History List */
.history-list{display:flex;flex-direction:column;gap:var(--sp-2);margin-top:var(--sp-4)}
.history-date-header{font-size:.875rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;padding:var(--sp-4) 0 var(--sp-2);border-bottom:1px solid var(--border-color)}
.history-item{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--r-md)}
.history-item-body{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}
.history-item-meta{display:flex;flex-direction:column;align-items:flex-end;gap:var(--sp-1);flex-shrink:0}
.history-item-actions{display:flex;gap:var(--sp-1)}
.history-action-btn{width:32px;height:32px;border-radius:var(--r-sm);border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.875rem;transition:all .15s}
.history-action-btn:hover{background:var(--bg-hover);color:var(--text-primary)}
.history-action-delete:hover{background:rgba(239,68,68,.1);color:var(--danger);border-color:var(--danger)}
.history-ctx{font-size:.8125rem;color:var(--text-muted);font-weight:400;font-family:var(--font-sans);text-transform:capitalize}

/* Chart Container */
.chart-container{width:100%;overflow:hidden}
.chart-container canvas{width:100%;display:block}

/* Settings Components */
.settings-list{display:flex;flex-direction:column;gap:0}
.settings-row{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-4);padding:var(--sp-4) 0;border-bottom:1px solid var(--border-color)}
.settings-row:last-child{border-bottom:none}
.settings-row-label{flex:1;min-width:0}
.settings-row-title{font-size:.9375rem;font-weight:500;color:var(--text-primary)}
.settings-row-desc{font-size:.875rem;color:var(--text-muted);margin-top:2px}
.settings-toggle-group{display:flex;border:1px solid var(--border-color);border-radius:var(--r-full);overflow:hidden;flex-shrink:0}
.settings-toggle-btn{padding:var(--sp-2) var(--sp-4);border:none;background:var(--bg-primary);color:var(--text-secondary);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s}
.settings-toggle-btn.active{background:var(--accent);color:var(--on-accent)}
.settings-toggle-btn:hover:not(.active){background:var(--bg-hover)}

/* MD3 Switch (52x32, state-layer thumb) */
.settings-switch{background:none;border:none;cursor:pointer;padding:0;flex-shrink:0}
.settings-switch-track{display:block;width:52px;height:32px;background:var(--bg-hover);border:2px solid var(--border-color);border-radius:var(--r-full);position:relative;transition:background .2s,border-color .2s}
.settings-switch.active .settings-switch-track{background:var(--accent);border-color:var(--accent)}
.settings-switch-thumb{display:block;width:16px;height:16px;background:var(--text-muted);border-radius:50%;position:absolute;top:50%;left:6px;transform:translateY(-50%);transition:transform .2s,width .2s,height .2s,left .2s,background .2s}
.settings-switch.active .settings-switch-thumb{transform:translateY(-50%) translateX(20px);width:24px;height:24px;left:2px;background:#fff}

/* Theme Toggle Button */
.theme-toggle{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--r-full);border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-secondary);cursor:pointer;transition:background .15s,color .15s,border-color .15s;-webkit-tap-highlight-color:transparent;padding:0;flex-shrink:0}
.theme-toggle:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--text-muted)}
.theme-toggle:active{transform:scale(.93)}
.theme-toggle svg{width:18px;height:18px;pointer-events:none}
.theme-icon-sun{display:none}
.theme-icon-moon{display:block}
html.light .theme-icon-sun{display:block}
html.light .theme-icon-moon{display:none}
