@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,600;1,300;1,400&family=Cinzel:wght@400;600;700&family=Share+Tech+Mono&display=swap');

:root {
  --black:        #080808;
  --deep:         #0d0d0d;
  --surface:      #111111;
  --surface-2:    #161616;
  --surface-3:    #1c1c1c;
  --border:       #2a2a2a;
  --border-light: #333333;
  --gold:         #c9a84c;
  --gold-dim:     #8a6f32;
  --gold-bright:  #e8c96a;
  --gold-glow:    rgba(201,168,76,0.15);
  --gold-glow-2:  rgba(201,168,76,0.06);
  --cream:        #d4c5a0;
  --text:         #b8a98a;
  --text-dim:     #5a5040;
  --text-bright:  #e0d4b8;
  --ember:        #c0392b;
  --green-soft:   #4a7c59;
  --green-glow:   rgba(74,124,89,0.2);
  --font-display: 'Cinzel', serif;
  --font-body:    'Cormorant Garamond', serif;
  --font-mono:    'Share Tech Mono', monospace;
  --nav-width:    220px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{background:var(--black);color:var(--text);font-family:var(--font-body);font-size:17px;line-height:1.6;min-height:100vh;overflow-x:hidden;}

body::before{content:'';position:fixed;inset:0;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");pointer-events:none;z-index:9999;opacity:0.4;}

/* LAYOUT */
.shell{display:grid;grid-template-columns:var(--nav-width) 1fr;min-height:100vh;}

/* SIDEBAR */
.sidebar{grid-row:1/-1;background:var(--deep);border-right:1px solid var(--border);position:sticky;top:0;height:100vh;display:flex;flex-direction:column;padding:40px 0;overflow-y:auto;}
.sidebar-brand{padding:0 24px 40px;border-bottom:1px solid var(--border);margin-bottom:40px;}
.brand-name{font-family:var(--font-display);font-size:13px;font-weight:600;letter-spacing:0.25em;color:var(--gold);text-transform:uppercase;display:block;margin-bottom:4px;}
.brand-sub{font-family:var(--font-mono);font-size:10px;color:var(--text-dim);letter-spacing:0.1em;}
.nav-section-label{font-family:var(--font-mono);font-size:9px;letter-spacing:0.2em;color:var(--text-dim);text-transform:uppercase;padding:0 24px;margin-bottom:8px;margin-top:24px;}
.nav-link{display:flex;align-items:center;gap:8px;padding:9px 24px;color:var(--text-dim);text-decoration:none;font-family:var(--font-display);font-size:12px;letter-spacing:0.15em;text-transform:uppercase;transition:color 0.2s,background 0.2s,border-left-color 0.2s;border-left:2px solid transparent;}
.nav-link:hover,.nav-link.active{color:var(--gold);background:var(--gold-glow-2);border-left-color:var(--gold);}
.nav-icon{font-size:13px;width:16px;text-align:center;flex-shrink:0;}
.sidebar-footer{margin-top:auto;padding:24px;border-top:1px solid var(--border);}
.date-display{font-family:var(--font-mono);font-size:10px;color:var(--text-dim);letter-spacing:0.1em;}

/* SEARCH BAR */
.search-wrap{padding:0 16px 16px;position:relative;}
.search-input{width:100%;background:var(--surface);border:1px solid var(--border);color:var(--text-bright);font-family:var(--font-mono);font-size:11px;padding:8px 12px;letter-spacing:0.05em;outline:none;transition:border-color 0.2s;}
.search-input:focus{border-color:var(--gold-dim);}
.search-results{position:absolute;left:0;right:0;background:var(--surface-2);border:1px solid var(--border);border-top:none;z-index:100;max-height:300px;overflow-y:auto;}
.search-result-item{padding:10px 16px;cursor:pointer;border-bottom:1px solid var(--border);transition:background 0.2s;}
.search-result-item:hover{background:var(--surface-3);}
.search-result-section{font-family:var(--font-mono);font-size:9px;color:var(--gold-dim);letter-spacing:0.15em;text-transform:uppercase;margin-bottom:2px;}
.search-result-term{font-family:var(--font-display);font-size:13px;color:var(--text-bright);}

/* MAIN */
.main{grid-column:2;min-height:100vh;}
.page{display:none;animation:fadeUp 0.3s ease both;}
.page.active{display:block;}

/* PAGE HEADER */
.page-header{background:var(--deep);border-bottom:1px solid var(--border);padding:40px 64px;position:relative;overflow:hidden;}
.page-header::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--gold-dim),transparent);}
.page-eyebrow{font-family:var(--font-mono);font-size:10px;letter-spacing:0.25em;color:var(--gold-dim);text-transform:uppercase;margin-bottom:8px;}
.page-title{font-family:var(--font-display);font-size:clamp(28px,4vw,48px);font-weight:600;color:var(--text-bright);letter-spacing:0.1em;line-height:1.1;}
.page-title span{color:var(--gold);}

/* CONTENT */
.content-area{padding:40px 64px;max-width:1100px;}
.section-header{display:flex;align-items:baseline;gap:16px;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--border);position:relative;}
.section-header::after{content:'';position:absolute;bottom:-1px;left:0;width:60px;height:1px;background:var(--gold);}
.section-title{font-family:var(--font-display);font-size:13px;font-weight:600;letter-spacing:0.25em;text-transform:uppercase;color:var(--gold);}
.section-count{font-family:var(--font-mono);font-size:10px;color:var(--text-dim);}

/* BUTTONS */
.btn{font-family:var(--font-display);font-size:11px;letter-spacing:0.2em;text-transform:uppercase;padding:10px 20px;border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;transition:all 0.2s;}
.btn:hover{border-color:var(--gold-dim);color:var(--gold);}
.btn-gold{background:var(--gold-glow);border-color:var(--gold-dim);color:var(--gold);}
.btn-gold:hover{background:var(--gold);color:var(--black);}
.btn-sm{padding:6px 14px;font-size:10px;}
.btn-danger{border-color:var(--ember);color:var(--ember);}
.btn-danger:hover{background:rgba(192,57,43,0.1);}

/* FORMS */
.form-group{margin-bottom:20px;}
.form-label{font-family:var(--font-mono);font-size:10px;letter-spacing:0.2em;text-transform:uppercase;color:var(--text-dim);display:block;margin-bottom:8px;}
.form-input,.form-select,.form-textarea{width:100%;background:var(--surface);border:1px solid var(--border);color:var(--text-bright);font-family:var(--font-body);font-size:16px;padding:10px 14px;outline:none;transition:border-color 0.2s;-webkit-appearance:none;}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--gold-dim);}
.form-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M0 0l6 8 6-8z' fill='%238a6f32'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px;}
.form-textarea{resize:vertical;min-height:120px;font-family:var(--font-body);}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.form-panel{background:var(--surface);border:1px solid var(--border);padding:24px;margin-bottom:32px;}
.form-panel-title{font-family:var(--font-display);font-size:12px;letter-spacing:0.2em;text-transform:uppercase;color:var(--gold);margin-bottom:20px;}

/* STAR RATING */
.star-rating{display:flex;gap:8px;margin-top:4px;}
.star{font-size:22px;color:var(--text-dim);cursor:pointer;transition:color 0.15s;}
.star.active,.star:hover{color:var(--gold);}

/* CARDS */
.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;}
.card{background:var(--surface);border:1px solid var(--border);padding:20px;position:relative;transition:border-color 0.2s,transform 0.2s;}
.card:hover{border-color:var(--border-light);transform:translateY(-2px);}
.card-tag{font-family:var(--font-mono);font-size:9px;letter-spacing:0.2em;text-transform:uppercase;color:var(--text-dim);margin-bottom:6px;}
.card-title{font-family:var(--font-display);font-size:16px;font-weight:600;color:var(--text-bright);margin-bottom:4px;}
.card-meta{font-family:var(--font-mono);font-size:10px;color:var(--text-dim);margin-bottom:10px;}
.card-body{font-size:14px;color:var(--text);line-height:1.5;font-style:italic;}
.card-footer{margin-top:12px;padding-top:12px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;}
.card-stars{color:var(--gold);font-size:13px;letter-spacing:2px;}
.card-date{font-family:var(--font-mono);font-size:9px;color:var(--text-dim);}

/* MEDIA TYPE TABS */
.type-tabs{display:flex;gap:8px;margin-bottom:24px;flex-wrap:wrap;}
.type-tab{font-family:var(--font-display);font-size:11px;letter-spacing:0.15em;text-transform:uppercase;padding:8px 16px;border:1px solid var(--border);background:var(--surface);color:var(--text-dim);cursor:pointer;transition:all 0.2s;}
.type-tab:hover,.type-tab.active{border-color:var(--gold-dim);color:var(--gold);background:var(--gold-glow-2);}

/* CHECK-IN STONES */
.checkin-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:16px;margin-bottom:32px;}
.checkin-stone{background:var(--surface);border:1px solid var(--border);padding:24px;cursor:pointer;transition:all 0.3s cubic-bezier(0.4,0,0.2,1);position:relative;overflow:hidden;user-select:none;text-align:center;}
.checkin-stone::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at center,var(--gold-glow) 0%,transparent 70%);opacity:0;transition:opacity 0.4s;}
.checkin-stone.lit{border-color:var(--gold-dim);background:var(--surface-2);}
.checkin-stone.lit::before{opacity:1;}
.checkin-stone.lit .stone-icon{color:var(--gold);text-shadow:0 0 20px rgba(201,168,76,0.6);}
.checkin-stone.lit .stone-label{color:var(--gold);}
.checkin-stone.lit .stone-glyph{opacity:1;}
.stone-icon{font-size:28px;display:block;margin-bottom:8px;transition:all 0.3s;color:var(--text-dim);}
.stone-label{font-family:var(--font-display);font-size:11px;font-weight:600;letter-spacing:0.2em;text-transform:uppercase;color:var(--text-dim);transition:color 0.3s;display:block;}
.stone-glyph{position:absolute;top:8px;right:8px;font-size:10px;color:var(--gold);opacity:0;transition:opacity 0.3s;font-family:var(--font-mono);}

/* WEEK PATH */
.waypath{margin-top:24px;padding:20px;background:var(--surface);border:1px solid var(--border);}
.waypath-label{font-family:var(--font-mono);font-size:10px;letter-spacing:0.2em;color:var(--text-dim);text-transform:uppercase;margin-bottom:16px;}
.waypath-stones{display:flex;gap:8px;align-items:center;}
.path-stone{width:36px;height:36px;border-radius:50%;border:1px solid var(--border);background:var(--surface-2);display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:9px;color:var(--text-dim);transition:all 0.3s;flex-shrink:0;}
.path-stone.today-stone{border-color:var(--gold-dim);color:var(--gold);}
.path-stone.complete{background:var(--gold-glow);border-color:var(--gold);color:var(--gold);box-shadow:0 0 12px rgba(201,168,76,0.2);}
.path-stone.partial{background:var(--surface-3);border-color:var(--gold-dim);color:var(--gold-dim);}
.path-connector{flex:1;height:1px;background:var(--border);}
.path-stone.complete+.path-connector{background:var(--gold-dim);}

/* SUPPLEMENTS */
.supp-list{display:flex;flex-direction:column;gap:8px;}
.supp-row{display:flex;align-items:center;gap:16px;padding:14px 16px;background:var(--surface);border:1px solid var(--border);cursor:pointer;transition:all 0.2s;user-select:none;}
.supp-row:hover{border-color:var(--border-light);}
.supp-row.taken{background:var(--surface-2);border-color:var(--green-soft);}
.supp-check{width:18px;height:18px;border:1px solid var(--border-light);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:10px;color:transparent;transition:all 0.2s;}
.supp-row.taken .supp-check{background:var(--green-soft);border-color:var(--green-soft);color:white;box-shadow:0 0 8px var(--green-glow);}
.supp-info{flex:1;}
.supp-name{font-family:var(--font-display);font-size:15px;color:var(--text-bright);display:block;}
.supp-dose{font-family:var(--font-mono);font-size:10px;color:var(--text-dim);}
.supp-notes-text{font-size:13px;color:var(--text-dim);font-style:italic;margin-top:2px;}
.supp-delete{opacity:0;color:var(--ember);font-size:12px;font-family:var(--font-mono);cursor:pointer;transition:opacity 0.2s;padding:4px 8px;border:1px solid transparent;}
.supp-row:hover .supp-delete{opacity:1;}

/* SLEEP */
.sleep-log-list{display:flex;flex-direction:column;gap:8px;margin-top:24px;}
.sleep-row{display:flex;align-items:center;gap:16px;padding:14px 16px;background:var(--surface);border:1px solid var(--border);}
.sleep-hours{font-family:var(--font-display);font-size:24px;color:var(--gold);min-width:60px;}
.sleep-unit{font-family:var(--font-mono);font-size:10px;color:var(--text-dim);}
.sleep-date{font-family:var(--font-mono);font-size:10px;color:var(--text-dim);margin-left:auto;}
.sleep-notes-text{font-size:13px;color:var(--text);font-style:italic;flex:1;}
.sleep-bar-wrap{margin-top:8px;display:flex;align-items:center;gap:12px;}
.sleep-bar{flex:1;height:3px;background:var(--border);border-radius:2px;overflow:hidden;}
.sleep-bar-fill{height:100%;background:var(--gold);transition:width 0.6s;}

/* DICTIONARY */
.dict-list{display:flex;flex-direction:column;gap:8px;}
.dict-row{padding:16px 20px;background:var(--surface);border:1px solid var(--border);transition:border-color 0.2s;}
.dict-row:hover{border-color:var(--border-light);}
.dict-term{font-family:var(--font-display);font-size:17px;font-weight:600;color:var(--text-bright);margin-bottom:4px;}
.dict-def{font-size:15px;color:var(--text);line-height:1.5;}
.dict-domain{font-family:var(--font-mono);font-size:9px;color:var(--gold-dim);letter-spacing:0.15em;text-transform:uppercase;margin-top:6px;}
.dict-footer{display:flex;align-items:center;justify-content:space-between;margin-top:8px;}
.dict-date{font-family:var(--font-mono);font-size:9px;color:var(--text-dim);}
.dict-delete{opacity:0;color:var(--ember);font-size:11px;font-family:var(--font-mono);cursor:pointer;transition:opacity 0.2s;}
.dict-row:hover .dict-delete{opacity:1;}
.domain-filters{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap;}
.domain-chip{font-family:var(--font-mono);font-size:10px;letter-spacing:0.1em;text-transform:uppercase;padding:5px 12px;border:1px solid var(--border);background:var(--surface);color:var(--text-dim);cursor:pointer;transition:all 0.2s;}
.domain-chip:hover,.domain-chip.active{border-color:var(--gold-dim);color:var(--gold);}

/* ANCHOR */
.anchor-block{background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--gold);padding:40px;position:relative;overflow:hidden;margin-bottom:32px;}
.anchor-block::before{content:'"';position:absolute;top:-20px;left:24px;font-family:var(--font-display);font-size:120px;color:var(--gold-glow);line-height:1;pointer-events:none;}
.anchor-quote{font-family:var(--font-body);font-size:20px;font-style:italic;color:var(--cream);line-height:1.6;position:relative;z-index:1;margin-bottom:16px;}
.anchor-attribution{font-family:var(--font-mono);font-size:10px;letter-spacing:0.2em;color:var(--gold-dim);text-transform:uppercase;}

/* QUESTIONS */
.questions-list{display:flex;flex-direction:column;gap:8px;}
.question-item{background:var(--surface);border:1px solid var(--border);padding:16px 20px;font-family:var(--font-body);font-size:16px;font-style:italic;color:var(--text);display:flex;gap:16px;align-items:flex-start;transition:all 0.2s;cursor:default;}
.question-item:hover{border-color:var(--gold-dim);color:var(--text-bright);background:var(--surface-2);}
.question-num{font-family:var(--font-mono);font-size:10px;color:var(--gold-dim);margin-top:4px;flex-shrink:0;}

/* WRAPPED */
.wrapped-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;}
.wrapped-card{background:var(--surface);border:1px solid var(--border);padding:24px;text-align:center;position:relative;overflow:hidden;}
.wrapped-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--gold);}
.wrapped-num{font-family:var(--font-display);font-size:48px;color:var(--gold);font-weight:300;line-height:1;margin-bottom:8px;}
.wrapped-label{font-family:var(--font-mono);font-size:10px;letter-spacing:0.15em;text-transform:uppercase;color:var(--text-dim);}
.wrapped-sub{font-size:13px;color:var(--text-dim);font-style:italic;margin-top:4px;}
.wrapped-year-header{font-family:var(--font-display);font-size:clamp(32px,5vw,64px);color:var(--gold);letter-spacing:0.2em;text-align:center;margin-bottom:40px;opacity:0.15;pointer-events:none;user-select:none;}

/* TOAST */
.toast{position:fixed;bottom:32px;right:32px;background:var(--surface-2);border:1px solid var(--gold-dim);color:var(--gold);font-family:var(--font-mono);font-size:11px;letter-spacing:0.1em;padding:12px 20px;z-index:10000;opacity:0;transform:translateY(8px);transition:all 0.3s;pointer-events:none;}
.toast.show{opacity:1;transform:translateY(0);}

/* LOADING */
.loading{font-family:var(--font-mono);font-size:11px;color:var(--text-dim);letter-spacing:0.1em;padding:24px 0;}

/* EMPTY STATE */
.empty-state{font-family:var(--font-body);font-size:16px;font-style:italic;color:var(--text-dim);padding:32px 0;text-align:center;}

/* STREAK TIERS */
.streak-badge{font-family:var(--font-mono);font-size:9px;letter-spacing:0.15em;text-transform:uppercase;padding:3px 8px;border:1px solid var(--border);border-radius:2px;white-space:nowrap;transition:all 0.3s;}
.streak-0      { color: var(--text-dim); border-color: var(--border); }
.streak-kindled{ color: #c9a84c; border-color: #8a6f32; background: rgba(201,168,76,0.06); }
.streak-burning{ color: #e8c96a; border-color: #c9a84c; background: rgba(201,168,76,0.1); box-shadow: 0 0 8px rgba(201,168,76,0.15); }
.streak-forged { color: #ffd700; border-color: #e8c96a; background: rgba(255,215,0,0.1); box-shadow: 0 0 12px rgba(255,215,0,0.2); animation: forged-pulse 2s ease-in-out infinite; }
.streak-radiant{ color: #fff0a0; border-color: #ffd700; background: rgba(255,240,160,0.12); box-shadow: 0 0 16px rgba(255,215,0,0.3); animation: radiant-pulse 1.8s ease-in-out infinite; }
.streak-legendary{ color: #ffffff; border-color: #fff0a0; background: rgba(255,255,255,0.08); box-shadow: 0 0 24px rgba(255,240,160,0.4), inset 0 0 12px rgba(255,215,0,0.1); animation: legendary-shimmer 1.5s ease-in-out infinite; }

@keyframes forged-pulse {
  0%,100% { box-shadow: 0 0 12px rgba(255,215,0,0.2); }
  50%      { box-shadow: 0 0 20px rgba(255,215,0,0.35); }
}
@keyframes radiant-pulse {
  0%,100% { box-shadow: 0 0 16px rgba(255,215,0,0.3); }
  50%      { box-shadow: 0 0 28px rgba(255,215,0,0.5); }
}
@keyframes legendary-shimmer {
  0%,100% { box-shadow: 0 0 24px rgba(255,240,160,0.4), inset 0 0 12px rgba(255,215,0,0.1); }
  50%      { box-shadow: 0 0 40px rgba(255,255,255,0.5), inset 0 0 20px rgba(255,215,0,0.2); }
}

/* SUPPLEMENT TABS */
.supp-tabs{display:flex;gap:0;margin-bottom:24px;border:1px solid var(--border);overflow:hidden;}
.supp-tab{flex:1;padding:10px;font-family:var(--font-display);font-size:11px;letter-spacing:0.15em;text-transform:uppercase;text-align:center;cursor:pointer;color:var(--text-dim);background:var(--surface);border-right:1px solid var(--border);transition:all 0.2s;}
.supp-tab:last-child{border-right:none;}
.supp-tab.active{color:var(--gold);background:var(--gold-glow-2);}

/* FREQUENCY GRID */
.freq-grid{display:flex;gap:3px;flex-wrap:wrap;margin:12px 0;}
.freq-cell{width:16px;height:16px;border-radius:2px;background:var(--surface-3);border:1px solid var(--border);transition:all 0.2s;position:relative;cursor:default;flex-shrink:0;}
.freq-cell.taken{background:var(--gold-dim);border-color:var(--gold);}
.freq-cell.taken-streak{background:var(--gold);border-color:var(--gold-bright);box-shadow:0 0 4px rgba(201,168,76,0.4);}
.freq-cell[title]:hover::after{content:attr(title);position:absolute;bottom:20px;left:50%;transform:translateX(-50%);background:var(--surface-2);border:1px solid var(--border);color:var(--text-bright);font-family:var(--font-mono);font-size:9px;padding:3px 6px;white-space:nowrap;z-index:10;pointer-events:none;}

/* SUPP HISTORY CARD */
.supp-history-card{background:var(--surface);border:1px solid var(--border);padding:20px;margin-bottom:12px;}
.supp-history-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;flex-wrap:wrap;gap:8px;}
.supp-history-name{font-family:var(--font-display);font-size:16px;color:var(--text-bright);}
.supp-history-meta{font-family:var(--font-mono);font-size:10px;color:var(--text-dim);margin-bottom:8px;}
.supp-history-stats{display:flex;gap:16px;margin-top:12px;flex-wrap:wrap;}
.supp-stat{text-align:center;}
.supp-stat-num{font-family:var(--font-display);font-size:22px;color:var(--gold);display:block;line-height:1;}
.supp-stat-label{font-family:var(--font-mono);font-size:9px;color:var(--text-dim);letter-spacing:0.1em;text-transform:uppercase;}

/* MONTHLY STATS */
.monthly-card{background:var(--surface);border:1px solid var(--border);padding:20px;margin-bottom:12px;}
.monthly-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;}
.monthly-title{font-family:var(--font-display);font-size:14px;letter-spacing:0.1em;color:var(--text-bright);}
.monthly-score{font-family:var(--font-display);font-size:28px;color:var(--gold);}
.monthly-score-label{font-family:var(--font-mono);font-size:9px;color:var(--text-dim);text-transform:uppercase;letter-spacing:0.1em;}
.monthly-bars{display:flex;flex-direction:column;gap:8px;}
.monthly-bar-row{display:flex;align-items:center;gap:10px;}
.monthly-bar-label{font-family:var(--font-mono);font-size:10px;color:var(--text-dim);width:120px;flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.monthly-bar-track{flex:1;height:4px;background:var(--border);border-radius:2px;overflow:hidden;}
.monthly-bar-fill{height:100%;background:var(--gold);border-radius:2px;transition:width 0.6s cubic-bezier(0.4,0,0.2,1);}
.monthly-bar-pct{font-family:var(--font-mono);font-size:10px;color:var(--text-dim);width:36px;text-align:right;flex-shrink:0;}
.insight-block{background:var(--surface-2);border:1px solid var(--border);border-left:3px solid var(--gold-dim);padding:14px 16px;margin-top:12px;font-family:var(--font-body);font-size:14px;font-style:italic;color:var(--text);line-height:1.5;}

/* SLEEP CHART */
.sleep-chart{display:flex;align-items:flex-end;gap:3px;height:80px;margin:16px 0 4px;padding:0 2px;}
.sleep-chart-bar-wrap{display:flex;flex-direction:column;align-items:center;flex:1;height:100%;justify-content:flex-end;gap:4px;cursor:default;}
.sleep-chart-bar{width:100%;min-height:2px;border-radius:1px 1px 0 0;transition:height 0.4s cubic-bezier(0.4,0,0.2,1);}
.sleep-chart-label{font-family:var(--font-mono);font-size:8px;color:var(--text-dim);text-align:center;}
.sleep-chart-legend{font-family:var(--font-mono);font-size:9px;color:var(--text-dim);margin-top:12px;letter-spacing:0.05em;}
/* EDIT MODE */
.form-panel.edit-mode{border-color:var(--gold-dim);background:var(--surface-2);}
.form-panel.edit-mode .form-panel-title{color:var(--gold-bright);}
.edit-cancel{font-family:var(--font-mono);font-size:10px;color:var(--text-dim);letter-spacing:0.1em;cursor:pointer;margin-left:16px;text-decoration:underline;text-underline-offset:3px;transition:color 0.2s;}
.edit-cancel:hover{color:var(--ember);}
.btn-edit{opacity:0;color:var(--gold-dim);font-size:11px;font-family:var(--font-mono);cursor:pointer;transition:opacity 0.2s;padding:4px 8px;border:1px solid transparent;}
.card:hover .btn-edit,.supp-row:hover .btn-edit,.dict-row:hover .btn-edit,.sleep-row:hover .btn-edit{opacity:1;}

::-webkit-scrollbar{width:4px;}
::-webkit-scrollbar-track{background:var(--deep);}
::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:2px;}
::-webkit-scrollbar-thumb:hover{background:var(--gold-dim);}

/* ANIMATIONS */
@keyframes fadeUp{from{opacity:0;transform:translateY(12px);}to{opacity:1;transform:translateY(0);}}
@keyframes pulse-gold{0%,100%{box-shadow:0 0 0 0 rgba(201,168,76,0);}50%{box-shadow:0 0 0 6px rgba(201,168,76,0.1);}}
.checkin-stone.lit{animation:pulse-gold 3s ease-in-out infinite;}

/* MOBILE */
@media(max-width:768px){
  .shell{grid-template-columns:1fr;grid-template-rows:1fr auto;}
  .sidebar{display:none;}
  .main{grid-column:1;padding-bottom:70px;}
  .content-area{padding:20px 16px;}
  .page-header{padding:20px 16px;}
  .form-row{grid-template-columns:1fr;}
  .mobile-nav{display:flex !important;}
}

/* MOBILE BOTTOM NAV */
.mobile-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--deep);border-top:1px solid var(--border);z-index:1000;padding:0;height:64px;overflow-x:auto;-webkit-overflow-scrolling:touch;}
.mobile-nav-inner{display:flex;align-items:stretch;min-width:100%;height:100%;}
.mobile-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:0 16px;cursor:pointer;border-bottom:2px solid transparent;transition:all 0.2s;white-space:nowrap;flex:1;min-width:64px;text-decoration:none;}
.mobile-nav-item.active{border-bottom-color:var(--gold);background:var(--gold-glow-2);}
.mobile-nav-icon{font-size:16px;color:var(--text-dim);transition:color 0.2s;}
.mobile-nav-label{font-family:var(--font-display);font-size:8px;letter-spacing:0.15em;text-transform:uppercase;color:var(--text-dim);transition:color 0.2s;}
.mobile-nav-item.active .mobile-nav-icon,
.mobile-nav-item.active .mobile-nav-label{color:var(--gold);}
