:root{--c-bg-deep: #020c07;--c-bg-forest: #051a10;--c-primary: #10B981;--c-primary-glow: #34D399;--c-primary-dim: rgba(16, 185, 129, .15);--c-accent: #A7F3D0;--c-danger: #F87171;--c-warning: #FBBF24;--c-text-main: #ECFDF5;--c-text-muted: #6EE7B7;--c-text-dim: #34D399;--c-surface-glass: rgba(10, 35, 25, .65);--c-surface-glass-border: rgba(52, 211, 153, .15);--c-surface-glass-hover: rgba(20, 60, 45, .75);--c-surface-glass-border-hover: rgba(52, 211, 153, .3);--space-xs: clamp(.25rem, .5vw, .5rem);--space-sm: clamp(.5rem, 1vw, .75rem);--space-md: clamp(.75rem, 1.5vw, 1.25rem);--space-lg: clamp(1rem, 2.5vw, 1.5rem);--space-xl: clamp(1.25rem, 3vw, 2rem);--text-xs: clamp(.75rem, 1.2vw, .875rem);--text-sm: clamp(.875rem, 1.4vw, 1rem);--text-base: clamp(1rem, 1.6vw, 1.125rem);--text-lg: clamp(1rem, 2vw, 1.25rem);--text-xl: clamp(1.25rem, 2.5vw, 1.5rem);--text-2xl: clamp(1.5rem, 3vw, 2rem);--text-3xl: clamp(1.75rem, 4vw, 2.5rem);--text-hero: clamp(1.5rem, 4.5vw, 2.8rem);--font-serif: "Fraunces", serif;--font-sans: "Manrope", sans-serif;--radius-sm: 8px;--radius-md: 16px;--radius-lg: 24px;--radius-pill: 9999px;--shadow-glow: 0 0 20px rgba(16, 185, 129, .15);--shadow-card: 0 10px 30px -5px rgba(0, 0, 0, .5);--ease-spring: cubic-bezier(.175, .885, .32, 1.275);--ease-smooth: cubic-bezier(.4, 0, .2, 1);--fab-size: clamp(52px, 8vw, 64px);--fab-gap: clamp(.75rem, 2vw, 1rem);--fab-edge: clamp(1rem, 3vw, 2rem)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield;appearance:texfield}body{background-color:var(--c-bg-deep);background-image:radial-gradient(circle at 10% 20%,rgba(16,185,129,.08) 0%,transparent 40%),radial-gradient(circle at 90% 80%,rgba(5,150,105,.08) 0%,transparent 40%);color:var(--c-text-main);font-family:var(--font-sans);font-size:16px;line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased;overflow-x:hidden}button{border:none;background:none;font-family:inherit;cursor:pointer;color:inherit;-webkit-tap-highlight-color:transparent}h1,h2,h3,h4,h5,h6{font-family:var(--font-serif);font-weight:600;line-height:1.2;color:var(--c-text-main)}.container{width:100%;max-width:min(640px,100%);margin:0 auto;padding:var(--space-md);display:flex;flex-direction:column;min-height:100vh;position:relative;padding-bottom:calc(var(--fab-edge) + var(--fab-size) + var(--fab-edge))}header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-sm) 0;margin-bottom:var(--space-xl);gap:var(--space-sm);z-index:10;width:100%}.header-content{display:flex;align-items:center;gap:var(--space-sm);min-width:0;flex:1 1 auto}.logo-img{height:clamp(80px,15vw,100px);width:auto;flex-shrink:0}.header-text{display:flex;flex-direction:column;min-width:0}header h1{font-size:var(--text-2xl);background:linear-gradient(to right,var(--c-text-main),var(--c-primary-glow));background-clip:text;-webkit-background-clip:text;color:transparent;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.subtitle{font-size:var(--text-xs);color:var(--c-text-muted);font-weight:500;text-transform:uppercase;letter-spacing:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-actions{display:flex;align-items:center;gap:var(--space-xs);flex-shrink:0}.user-badge{font-size:var(--text-xs);font-weight:600;color:var(--c-text-muted);background:var(--c-primary-dim);padding:.35rem .75rem;border-radius:var(--radius-pill);max-width:clamp(50px,15vw,100px);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}#settings-btn,.logout-btn{width:clamp(36px,6vw,44px);height:clamp(36px,6vw,44px);border-radius:var(--radius-md);background:var(--c-surface-glass);border:1px solid var(--c-surface-glass-border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:grid;place-items:center;font-size:1.25rem;transition:all .3s var(--ease-smooth)}#settings-btn:hover{background:var(--c-surface-glass-hover);border-color:var(--c-surface-glass-border-hover);transform:rotate(45deg);box-shadow:var(--shadow-glow)}.logout-btn:hover{background:#f8717126;border-color:#f871714d;box-shadow:0 0 15px #f8717126}.streak-strip{display:flex;flex-direction:column;gap:var(--space-sm);margin-bottom:var(--space-xl);animation:fadeUp .4s var(--ease-spring)}.streak-mini-card{background:linear-gradient(135deg,#064e3bd9,#022c22e6);border:1px solid rgba(52,211,153,.3);border-radius:var(--radius-lg);padding:.75rem 1rem;display:flex;align-items:center;gap:var(--space-md);box-shadow:0 0 14px #10b9811a}.streak-mini-top{display:flex;align-items:baseline;gap:6px;flex-shrink:0}#streak-days{font-family:var(--font-serif);font-size:var(--text-3xl);color:var(--c-primary-glow);text-shadow:0 0 12px rgba(52,211,153,.4);line-height:1}.streak-mini-emoji{font-size:1.3rem}.streak-mini-label{font-size:.8rem;color:var(--c-text-dim);line-height:1.3}.streak-mini-label strong{display:block;color:var(--c-text-main);font-size:.9rem}#ach-chips{display:flex;flex-wrap:wrap;gap:var(--space-sm)}.ach-chip{border-radius:var(--radius-lg);padding:.65rem .9rem;display:flex;flex-direction:column;gap:4px;flex:1 1 140px}.ach-chip-header{display:flex;align-items:center;gap:6px;font-size:.85rem;font-weight:700}.ach-chip-desc{font-size:.72rem;line-height:1.3;opacity:.75}.ach-chip--done{background:#10b9811a;border:1px solid rgba(52,211,153,.2);color:var(--c-primary-glow)}.ach-chip--next{background:#ffffff08;border:1px solid rgba(255,255,255,.08);color:var(--c-text-dim)}.ach-chip-bar{width:100%;height:3px;background:#ffffff14;border-radius:2px;overflow:hidden;margin-top:2px}.ach-chip-bar>div{height:100%;background:var(--c-primary);border-radius:2px;transition:width .4s ease}.view-toggles{display:flex;background:#0006;padding:.35rem;border-radius:var(--radius-pill);margin-bottom:var(--space-xl);border:1px solid var(--c-surface-glass-border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.view-toggles button{flex:1;padding:clamp(.5rem,1.5vw,.75rem) clamp(.5rem,2vw,1rem);border-radius:var(--radius-pill);font-weight:600;font-size:var(--text-sm);color:var(--c-text-dim);transition:all .3s var(--ease-smooth)}.view-toggles button.active{background:var(--c-surface-glass);color:var(--c-text-main);box-shadow:0 4px 15px #0003;border:1px solid rgba(255,255,255,.1)}.card,.stat-card,.chart-container,.calendar-container,.achievement-card,.chart-card{background:var(--c-surface-glass);border:1px solid var(--c-surface-glass-border);border-radius:var(--radius-lg);padding:var(--space-lg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:var(--shadow-card);margin-bottom:var(--space-lg);transition:transform .3s var(--ease-smooth),border-color .3s}.card:hover,.stat-card:hover,.achievement-card:hover{border-color:var(--c-surface-glass-border-hover);transform:translateY(-2px)}section{animation:fadeInScale .4s var(--ease-smooth)}@keyframes fadeInScale{0%{opacity:0;transform:scale(.98)}to{opacity:1;transform:scale(1)}}#dashboard-widgets{display:flex;flex-direction:column;gap:var(--space-md);margin-bottom:var(--space-lg)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:var(--space-md);margin-bottom:var(--space-lg)}.stat-card.highlight{background:linear-gradient(135deg,#10b9811a,#064e3b66);border-color:#34d39933}.stat-header h3{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:1px;color:var(--c-text-dim);font-family:var(--font-sans)}.big-number{font-family:var(--font-serif);font-size:var(--text-hero);color:var(--c-text-main);margin:var(--space-xs) 0;font-weight:800;letter-spacing:-1px}.stat-card .big-number{font-size:clamp(2rem,6vw,2.8rem)}.sub-label{font-size:var(--text-xs);color:var(--c-text-muted)}.trend-indicator{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:var(--radius-pill);font-size:.75rem;font-weight:700;background:#0003}.trend-up{color:var(--c-danger);border:1px solid rgba(248,113,113,.2)}.trend-down{color:var(--c-primary);border:1px solid rgba(16,185,129,.2)}.chart-card h3{margin-bottom:var(--space-lg);color:var(--c-text-muted);font-size:.9rem;text-transform:uppercase;letter-spacing:2px}.chart-wrapper{height:220px;position:relative}.progress-bar-container{background:var(--c-surface-glass);border:1px solid var(--c-surface-glass-border);height:10px;border-radius:var(--radius-pill);overflow:hidden}.progress-bar-fill{height:100%;transition:width .8s var(--ease-spring);box-shadow:0 0 10px #10b9814d}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-lg)}.calendar-header h2{font-size:var(--text-xl);color:var(--c-text-main)}.calendar-header button{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--c-text-muted);transition:background .2s;font-size:1.5rem}.calendar-header button:hover{background:#ffffff1a;color:#fff}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:clamp(.2rem,.8vw,.5rem)}.calendar-weekday{text-align:center;font-size:clamp(.6rem,1.5vw,.75rem);font-weight:700;color:var(--c-text-dim);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}.calendar-day{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:clamp(4px,1vw,8px);font-size:clamp(.7rem,1.8vw,.9rem);color:var(--c-text-muted);transition:all .2s;position:relative}.calendar-day:hover{background:#ffffff0d;color:#fff}.calendar-day.today{border:1px solid var(--c-primary);color:var(--c-primary);font-weight:700}.calendar-day.selected{background:var(--c-surface-glass-hover);border:1px solid var(--c-accent);color:#fff;box-shadow:0 0 10px #a7f3d01a}.calendar-day.has-session{background:rgba(14,68,41,calc(.2 + var(--intensity, 0) * .6));color:var(--c-text-main);font-weight:600}.calendar-day.over-limit{background:rgba(180,40,20,calc(.12 + var(--intensity, 0) * .38));color:var(--c-danger)}.calendar-day.sf-violated{outline:2px solid rgba(96,165,250,.45);outline-offset:3px}.calendar-day.smoke-free{background:#10b98114;color:var(--c-text-muted);cursor:pointer}.calendar-day.smoke-free-explicit{background:#10b9812e;border:1px solid rgba(16,185,129,.35)}.smoke-free-indicator{font-size:clamp(.5rem,1.2vw,.65rem);position:absolute;top:2px;right:3px;line-height:1;opacity:.7}.calendar-day.smoke-free-explicit .smoke-free-indicator{opacity:1}.sf-prompt{display:flex;gap:.75rem;align-items:flex-start;background:#10b98114;border:1px solid rgba(16,185,129,.25);border-radius:var(--radius-md);padding:.9rem 1rem;margin-bottom:1rem}.sf-prompt-icon{font-size:1.4rem;flex-shrink:0;margin-top:.1rem}.sf-prompt-body{flex:1;display:flex;flex-direction:column;gap:.25rem}.sf-prompt-title{font-weight:600;font-size:.9rem;color:var(--c-text-main)}.sf-prompt-sub{font-size:.82rem;color:var(--c-text-muted)}.sf-prompt-rows{display:flex;flex-direction:column;gap:.4rem;margin-top:.6rem}.sf-prompt-row{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.4rem .6rem;background:#ffffff0a;border-radius:var(--radius-sm);flex-wrap:wrap}.sf-prompt-date{font-size:.83rem;color:var(--c-text-main);flex:1;min-width:120px}.sf-prompt-row-actions{display:flex;gap:.4rem;flex-shrink:0}.sf-prompt-actions{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.6rem}.btn-sf-mark{background:#10b98126;border:1px solid rgba(16,185,129,.4);color:var(--c-primary);padding:.35rem .75rem;border-radius:var(--radius-pill);font-size:.82rem;font-weight:600;cursor:pointer;transition:background .2s}.btn-sf-mark:hover{background:#10b98140}.btn-sf-log{background:#ffffff0f;border:1px solid var(--c-surface-glass-border);color:var(--c-text-main);padding:.35rem .75rem;border-radius:var(--radius-pill);font-size:.82rem;cursor:pointer;transition:background .2s}.btn-sf-log:hover{background:#ffffff1a}.btn-sf-dismiss{background:transparent;border:none;color:var(--c-text-muted);padding:.35rem .5rem;font-size:.78rem;cursor:pointer;text-decoration:underline}.btn-sf-dismiss:hover{color:var(--c-text-main)}.sf-modal-banner{display:flex;align-items:center;justify-content:space-between;gap:.75rem;flex-wrap:wrap;background:#10b98114;border-bottom:1px solid rgba(16,185,129,.2);padding:.65rem var(--space-lg);font-size:.83rem}.sf-modal-banner.hidden{display:none}.sf-banner-text{color:var(--c-text-muted);flex:1;min-width:160px}.btn-sf-mark-modal{background:#10b98126;border:1px solid rgba(16,185,129,.4);color:var(--c-primary);padding:.3rem .7rem;border-radius:var(--radius-pill);font-size:.8rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:background .2s}.btn-sf-mark-modal:hover{background:#10b98140}.smoke-free-summary{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.6rem 1rem;margin-top:var(--space-sm);background:#10b98114;border:1px solid rgba(16,185,129,.15);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--c-primary);font-weight:600}.day-detail{margin-top:1rem;animation:fadeUp .4s ease-out}.day-sf-section{margin-bottom:1rem}.day-sf-unmarked{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1.25rem;background:#10b9810f;border:1px dashed rgba(16,185,129,.3);border-radius:var(--radius-md);text-align:center}.day-sf-hint{font-size:.88rem;color:var(--c-text-muted)}.day-sf-marked{display:flex;align-items:center;gap:.6rem;padding:.75rem 1rem;background:#10b9811a;border:1px solid rgba(16,185,129,.3);border-radius:var(--radius-md);font-size:.88rem;color:var(--c-primary);font-weight:500}.day-sf-marked span{flex:1}.btn-sf-unmark{background:transparent;border:none;color:var(--c-text-muted);font-size:.78rem;cursor:pointer;text-decoration:underline;padding:0}.btn-sf-unmark:hover{color:var(--c-danger)}.day-detail h3{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--c-surface-glass-border)}.session-item{background:#0003;border-radius:var(--radius-md);padding:var(--space-md);margin-bottom:.75rem;display:flex;justify-content:space-between;align-items:flex-start;border:1px solid transparent;transition:all .2s}.session-item:hover{background:#0000004d;border-color:var(--c-surface-glass-border)}.session-item.session-over-limit{outline:2px solid rgba(202,138,4,.5);outline-offset:2px}.session-item.session-sf-violated{outline:2px solid rgba(96,165,250,.45);outline-offset:2px}.session-left{display:flex;gap:1rem;align-items:flex-start}.session-emoji{font-size:1.25rem;width:36px;height:36px;background:#ffffff0d;border-radius:50%;display:flex;align-items:center;justify-content:center}.session-time{font-weight:600;color:var(--c-text-main);font-size:var(--text-base)}.session-meta{display:flex;flex-direction:column}.meta-row{display:flex;align-items:center;gap:.5rem}.session-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.25rem}.tag{font-size:var(--text-xs);padding:.15rem .5rem;background:#10b9811a;border-radius:4px;color:var(--c-text-muted)}.tag-friend{background:#a7f3d01a;color:var(--c-text-muted)}.tag-time{background:#fbbf241a;color:var(--c-warning)}.tag-warning{background:#f871711a;color:var(--c-danger)}.tag-active{background:#10b98133;color:var(--c-primary);border:1px solid var(--c-primary)}.amount-wrapper{display:flex;flex-direction:column;align-items:flex-end;gap:.4rem}.amount-badge{background:var(--c-primary-dim);color:var(--c-accent);padding:.25rem .75rem;border-radius:var(--radius-pill);font-weight:700;font-size:.85rem;letter-spacing:.5px;white-space:nowrap}.amount-actions{display:flex;gap:.3rem;align-items:center}.empty-state{text-align:center;color:var(--c-text-dim);font-style:italic;padding:2rem 0}dialog{background:var(--c-bg-deep);color:var(--c-text-main);border:1px solid var(--c-surface-glass-border);border-radius:var(--radius-lg);box-shadow:0 25px 100px -20px #000c;padding:0;width:min(420px,calc(100vw - 2rem));max-height:calc(100dvh - 2rem);margin:auto;position:fixed;inset:0;overflow-y:auto}dialog::backdrop{background:#000c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}dialog[open]{animation:slideUpFade .4s var(--ease-spring)}.modal-header{padding:var(--space-lg);border-bottom:1px solid var(--c-surface-glass-border);border-top-right-radius:20px;border-top-left-radius:20px;display:flex;justify-content:space-between;align-items:center;background:#ffffff05;margin-bottom:5%}.close-btn{font-size:1.5rem;color:var(--c-text-muted);transition:color .2s}.close-btn:hover{color:var(--c-danger)}.modal-actions{display:flex;gap:var(--space-md);margin-top:var(--space-lg)}.modal-actions button{flex:1;width:auto}.urge-modal-content{padding:1.75rem 1.5rem 1.5rem;position:relative;text-align:center}.urge-close-btn{position:absolute;top:.75rem;right:.75rem;background:none;border:none;cursor:pointer;font-size:1.25rem;opacity:.4;line-height:1;padding:.25rem .4rem;color:inherit;border-radius:6px;transition:opacity .15s}.urge-close-btn:hover{opacity:.8}.urge-phase{display:flex;flex-direction:column;align-items:center}.urge-emoji{font-size:2.5rem;margin-bottom:.5rem}.urge-emoji--pop{animation:urgePop .4s var(--ease-spring)}.urge-heading{font-size:1.15rem;font-weight:700;margin:0 0 .4rem}.urge-subtext{font-size:.84rem;opacity:.65;line-height:1.5;margin:0 0 1.25rem;max-width:28ch}.urge-breathing-row{display:flex;align-items:center;gap:1rem;margin-bottom:1.25rem;text-align:left}.urge-breath-circle{flex-shrink:0;width:64px;height:64px;background:#10b98126;border-radius:50%;animation:boxBreathe 16s infinite linear}.urge-breath-phase{font-weight:600;font-size:.95rem;min-height:1.4em;margin:0 0 .15rem}.urge-breath-label{font-size:.72rem;opacity:.45;margin:0}.urge-timer{font-size:2.4rem;font-weight:700;color:var(--c-primary);letter-spacing:-.02em;margin-bottom:1.25rem}.urge-distraction-panel{width:100%}.urge-distract-prompt{font-size:.82rem;opacity:.65;margin:0 0 .75rem}.urge-distract-grid{display:grid;grid-template-columns:1fr 1fr;gap:.6rem;margin-bottom:.75rem}.urge-distract-btn{display:flex;flex-direction:column;align-items:center;gap:.35rem;padding:.85rem .5rem;border-radius:10px;background:transparent;color:inherit;cursor:pointer;font-size:.8rem;font-weight:600;font-family:inherit;transition:opacity .15s,transform .15s}.urge-distract-btn:hover{opacity:.85;transform:translateY(-1px)}.urge-distract-btn--green{border:1px solid rgba(16,185,129,.3);background:#10b9810f}.urge-distract-btn--purple{border:1px solid rgba(102,126,234,.3);background:#667eea0f}.urge-distract-icon{font-size:1.5rem}.urge-btn-full{width:100%}.urge-btn-dim{opacity:.65;font-size:.82rem}.urge-still-need{font-size:.84rem;opacity:.55;margin:0 0 1.25rem}.urge-decision-btns{display:flex;gap:.75rem;width:100%}.urge-decision-btns button{flex:1}.urge-intensity-labels{display:flex;justify-content:space-between;width:100%;font-size:.72rem;opacity:.5;margin-bottom:.4rem;padding:0 .1rem}.urge-intensity-grid{display:grid;grid-template-columns:repeat(10,1fr);gap:.3rem;width:100%;margin-bottom:.75rem}.urge-intensity-btn{aspect-ratio:1;border-radius:8px;border:1px solid transparent;font-size:.85rem;font-weight:600;font-family:inherit;cursor:pointer;transition:transform .1s,opacity .15s}.urge-intensity-btn:hover{transform:scale(1.12)}.urge-intensity-btn.selected{transform:scale(1.18);outline:2px solid white}.urge-intensity-btn--low{background:#10b98133;color:#065f46;border-color:#10b9814d}.urge-intensity-btn--mid{background:#fbbf2433;color:#92400e;border-color:#fbbf244d}.urge-intensity-btn--high{background:#ef44442e;color:#991b1b;border-color:#ef444440}.urge-intensity-hint{font-size:.75rem;opacity:.45;margin:0}.sfh-task-card{width:100%;background:#10b98112;border:1px solid rgba(16,185,129,.2);border-radius:12px;padding:.85rem 1rem;margin-bottom:1.25rem;text-align:left}.sfh-task-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;opacity:.5;margin:0 0 .35rem}.sfh-task-text{font-size:.9rem;line-height:1.5;margin:0}.sfh-confirm-panel{width:100%;margin-top:.75rem;padding:.85rem;border-radius:10px;border:1px dashed rgba(239,68,68,.4);background:#ef44440a}.sfh-confirm-text{font-size:.85rem;margin:0 0 .75rem}@keyframes boxBreathe{0%{transform:scale(1);animation-timing-function:ease-in}25%{transform:scale(1.25);animation-timing-function:linear}50%{transform:scale(1.25);animation-timing-function:ease-out}75%{transform:scale(1);animation-timing-function:linear}to{transform:scale(1)}}@keyframes urgePop{0%{transform:scale(.5);opacity:0}70%{transform:scale(1.2)}to{transform:scale(1);opacity:1}}form{padding:var(--space-lg)}form>p{margin-top:var(--space-lg)}.form-group{margin-bottom:var(--space-lg);margin-top:.5rem}.form-group label{display:block;margin-bottom:.5rem;font-size:var(--text-sm);color:var(--c-text-dim);font-weight:600;letter-spacing:.5px}.form-row{display:flex;gap:1rem;margin-bottom:1.25rem}.form-row .form-group{flex:1}@media(max-width:400px){.form-row{flex-direction:column;gap:0}}input,select,textarea{width:100%;background:#ffffff0d;border:1px solid var(--c-surface-glass-border);border-radius:var(--radius-sm);padding:.8rem 1rem;color:#fff;font-family:var(--font-sans);font-size:1rem;transition:all .2s;outline:none}input:focus,select:focus,textarea:focus{border-color:var(--c-primary);background:#ffffff14;box-shadow:0 0 0 2px #10b98133}.stepper{display:flex;align-items:center;gap:.5rem;background:#ffffff08;padding:.5rem;border-radius:var(--radius-md);width:max-content}.stepper button{width:36px;height:36px;background:#ffffff1a;border-radius:var(--radius-sm);font-size:1.25rem;display:grid;place-items:center;transition:background .2s}.stepper button:hover{background:var(--c-primary);color:#022c22}.stepper input{width:60px;text-align:center;border:none;background:transparent;font-size:1.25rem;font-weight:700;padding:0}.friends-toggle-wrapper{display:flex;align-items:center;gap:.75rem;cursor:pointer;background:#ffffff0d;padding:.75rem 1rem;border-radius:var(--radius-sm);border:1px solid var(--c-surface-glass-border);transition:all .2s;-webkit-user-select:none;user-select:none}.friends-toggle-wrapper label{font-size:var(--text-sm);font-weight:500;color:var(--c-text-main);cursor:pointer;line-height:1;margin:0;flex:1}.friends-toggle-wrapper input[type=checkbox]{appearance:none;width:20px;height:20px;border:2px solid var(--c-text-dim);border-radius:4px;background:transparent;cursor:pointer;position:relative;display:flex;align-items:center;justify-content:center;flex-shrink:0}.friends-toggle-wrapper input[type=checkbox]:checked{background:var(--c-primary);border-color:var(--c-primary)}.friends-toggle-wrapper input[type=checkbox]:checked:after{content:"✓";font-size:.8rem;color:#020c07;font-weight:800}.toggle-switch{position:relative;display:inline-flex;width:44px;height:24px;flex-shrink:0;cursor:pointer}.toggle-switch input[type=checkbox]{position:absolute;opacity:0;width:100%;height:100%;margin:0;cursor:pointer;z-index:2}.toggle-slider{position:absolute;inset:0;border-radius:var(--radius-pill);background:#ffffff26;border:1px solid var(--c-surface-glass-border);transition:background .2s,border-color .2s}.toggle-slider:after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:#fff;transition:transform .2s var(--ease-smooth);box-shadow:0 1px 4px #0006}.toggle-switch input[type=checkbox]:checked+.toggle-slider{background:var(--c-primary);border-color:var(--c-primary)}.toggle-switch input[type=checkbox]:checked+.toggle-slider:after{transform:translate(20px)}.consent-item{display:flex;align-items:center;justify-content:space-between;padding:.65rem 0;border-bottom:1px solid var(--c-surface-glass-border)}.consent-item:last-of-type{border-bottom:none}.consent-item-label{font-size:var(--text-sm);color:var(--c-text-main);font-weight:500}.btn-primary{background:var(--c-primary);color:#022c22;padding:1rem 1.5rem;border-radius:var(--radius-pill);font-weight:700;font-size:1rem;width:100%;transition:all .3s;text-transform:uppercase;letter-spacing:1px}.btn-primary:hover{background:var(--c-accent);transform:translateY(-2px);box-shadow:0 5px 20px #10b9814d}.btn-secondary{background:transparent;border:1px solid var(--c-surface-glass-border);color:var(--c-text-muted);padding:.8rem 1rem;border-radius:var(--radius-sm);font-weight:600;width:100%;transition:all .2s}.btn-secondary:hover{border-color:var(--c-text-muted);color:var(--c-text-main)}.btn-danger{background:var(--c-danger);color:#fff}.btn-danger-outline{background:transparent;border:1px solid rgba(248,113,113,.4);color:var(--c-danger);padding:.8rem 1rem;border-radius:var(--radius-sm);font-weight:600;transition:all .2s}.btn-danger-outline:hover{background:#f8717126;border-color:var(--c-danger)}.craving-btn{background:linear-gradient(135deg,#fb923c26,#fbbf241a);border:1px solid rgba(251,146,60,.4);color:#fbbf24;padding:1.1rem 1.5rem;border-radius:var(--radius-md);font-weight:700;font-size:1.05rem;letter-spacing:.5px;transition:all .3s var(--ease-smooth);position:relative;overflow:hidden;animation:cravingPulse 3s ease-in-out infinite}.craving-btn-container{display:flex;justify-content:center;margin:var(--space-lg) auto}.craving-btn:before{content:"";position:absolute;inset:0;border-radius:inherit;background:linear-gradient(135deg,rgba(251,146,60,.08),transparent);opacity:0;transition:opacity .3s}.craving-btn:hover{background:linear-gradient(135deg,#fb923c40,#fbbf242e);border-color:#fbbf24b3;transform:translateY(-2px);box-shadow:0 8px 30px #fb923c33,0 0 20px #fbbf241a;color:#fcd34d}.craving-btn:hover:before{opacity:1}.craving-btn:active{transform:translateY(0)}@keyframes cravingPulse{0%,to{box-shadow:0 0 #fb923c00}50%{box-shadow:0 0 20px 2px #fb923c26}}#add-session-fab,#end-session-fab{position:fixed;bottom:var(--fab-edge);width:var(--fab-size);height:var(--fab-size);border-radius:50%;display:grid;place-items:center;font-size:clamp(1.5rem,4vw,2rem);z-index:100;transition:all .3s var(--ease-spring);border:2px solid rgba(255,255,255,.2)}#add-session-fab{right:var(--fab-edge);background:var(--c-primary);color:#022c22;box-shadow:0 4px 20px #10b98166}#end-session-fab{right:calc(var(--fab-edge) + var(--fab-size) + var(--fab-gap));background:var(--c-warning);color:#451a03;box-shadow:0 4px 20px #fbbf2466}#add-session-fab:hover,#add-session-fab:active{transform:translateY(-5px) scale(1.1);background:var(--c-accent);box-shadow:0 0 50px #34d39999}#add-session-fab.exceeded{background:var(--c-warning);color:#451a03;box-shadow:0 4px 20px #fbbf2466;border-color:#fbbf2466}#add-session-fab.exceeded:hover,#add-session-fab.exceeded:active{background:#fcd34d;box-shadow:0 0 50px #fbbf2499}#add-session-fab.smoke-free-active{background:#3b82f6;color:#fff;box-shadow:0 4px 20px #3b82f666;border-color:#3b82f666}#add-session-fab.smoke-free-active:hover,#add-session-fab.smoke-free-active:active{background:#2563eb;box-shadow:0 0 50px #3b82f699}#end-session-fab:hover,#end-session-fab:active{transform:translateY(-5px) scale(1.1);background:#fcd34d;box-shadow:0 0 50px #fbbf2499}#quick-stop-container{position:fixed;bottom:calc(var(--fab-edge) + var(--fab-size) / 2);right:calc(var(--fab-edge) + var(--fab-size) * 1.5 + var(--fab-gap));width:0;height:0;z-index:99}#quick-stop-container.hidden{display:none}.quick-stop-btn{position:absolute;width:32px;height:32px;border-radius:50%;background:#fbbf242e;border:1.5px solid rgba(251,191,36,.5);color:var(--c-warning);font-size:.62rem;font-weight:700;cursor:pointer;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:grid;place-items:center;transition:box-shadow .2s ease,background .2s ease;animation:quickStopIn .32s var(--ease-spring) both}.quick-stop-btn:nth-child(1){--tx: -50%;--ty: calc(-50% - 75px) ;animation-delay:0s}.quick-stop-btn:nth-child(2){--tx: calc(-50% - 38px) ;--ty: calc(-50% - 65px) ;animation-delay:.05s}.quick-stop-btn:nth-child(3){--tx: calc(-50% - 65px) ;--ty: calc(-50% - 38px) ;animation-delay:.1s}.quick-stop-btn:nth-child(4){--tx: calc(-50% - 75px) ;--ty: -50%;animation-delay:.15s}.quick-stop-btn:hover{background:#fbbf2459;box-shadow:0 0 14px #fbbf2473;transform:translate(var(--tx),var(--ty)) scale(1.2)}.quick-stop-btn:disabled{opacity:.4;cursor:default}@keyframes quickStopIn{0%{opacity:0;transform:translate(-50%,-50%) scale(.3)}to{opacity:1;transform:translate(var(--tx),var(--ty))}}.active-session-card{background:linear-gradient(135deg,#052819e6,#02140ff2);border:1px solid var(--c-primary-dim);border-left:4px solid var(--c-primary);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-xl);box-shadow:var(--shadow-card),0 0 30px #10b9810d;display:flex;flex-direction:column;align-items:center;gap:var(--space-md);position:relative;overflow:hidden;animation:fadeUp .6s var(--ease-spring)}.timer-display{font-family:var(--font-serif);font-size:clamp(2.5rem,8vw,3.5rem);font-weight:700;color:var(--c-text-main);line-height:1;text-shadow:0 0 20px rgba(52,211,153,.2);font-variant-numeric:tabular-nums}.timer-header{font-size:var(--text-sm);text-transform:uppercase;letter-spacing:2px;color:var(--c-primary);font-weight:700}.live-stats{display:flex;gap:var(--space-sm);flex-wrap:wrap;justify-content:center;font-size:var(--text-xs);color:var(--c-text-muted);background:#ffffff08;padding:.25rem .75rem;border-radius:var(--radius-pill)}.achievements-grid{display:grid;grid-template-columns:1fr;gap:1rem}.achievement-card{display:flex;align-items:center;gap:var(--space-md)}.achievement-card.locked{opacity:.5;filter:grayscale(1)}.achievement-card.unlocked .ach-icon{background:var(--c-primary);color:#022c22;box-shadow:0 0 20px var(--c-primary-glow)}.ach-icon{width:clamp(40px,8vw,50px);height:clamp(40px,8vw,50px);border-radius:50%;background:#ffffff1a;display:grid;place-items:center;font-size:clamp(1.2rem,3vw,1.5rem);flex-shrink:0}.ach-info h4{font-size:var(--text-base);color:var(--c-text-main);margin-bottom:.25rem}.ach-info p{font-size:var(--text-xs);color:var(--c-text-muted)}.ach-date{font-size:.75rem;color:var(--c-primary-glow);font-weight:700;text-transform:uppercase;margin-top:.25rem}.session-reminder{background:#fbbf241a;border:1px solid rgba(251,191,36,.3);color:var(--c-warning);padding:.75rem 1rem;border-radius:var(--radius-md);font-size:.9rem;text-align:center;animation:fadeUp .3s ease-out;width:100%}.auth-page{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:1.5rem}.auth-card{width:100%;max-width:400px;background:var(--c-surface-glass);border:1px solid var(--c-surface-glass-border);border-radius:var(--radius-lg);padding:clamp(1.5rem,4vw,2.5rem) clamp(1rem,3vw,2rem);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:var(--shadow-card);animation:fadeUp .6s var(--ease-spring)}.auth-header{text-align:center;margin-bottom:2rem}.auth-header h1{font-size:var(--text-3xl);background:linear-gradient(to right,var(--c-text-main),var(--c-primary-glow));background-clip:text;-webkit-background-clip:text;color:transparent}.auth-subtitle{font-size:.85rem;color:var(--c-text-muted);text-transform:uppercase;letter-spacing:2px}.auth-logo{height:120px;width:auto;margin:0 auto .5rem;display:block}.auth-tabs{display:flex;background:#0006;padding:.3rem;border-radius:var(--radius-pill);margin-bottom:1.5rem;border:1px solid var(--c-surface-glass-border)}.auth-tab{flex:1;padding:.7rem 1rem;border-radius:var(--radius-pill);font-weight:600;font-size:.85rem;color:var(--c-text-dim);transition:all .3s var(--ease-smooth);text-align:center}.auth-tab.active{background:var(--c-surface-glass);color:var(--c-text-main)}.auth-error{background:#f8717126;border:1px solid rgba(248,113,113,.3);color:var(--c-danger);padding:.75rem 1rem;border-radius:var(--radius-sm);font-size:.85rem;margin-bottom:1rem}.auth-footer{text-align:center;margin-top:1.5rem;color:var(--c-text-muted);font-size:var(--text-sm);opacity:.8}.onboarding-wizard{max-width:800px;margin:clamp(1rem,4vh,4rem) auto;padding:var(--space-xl);background:var(--c-surface-glass);border:1px solid var(--c-surface-glass-border);border-radius:var(--radius-lg)}.wizard-header{text-align:center;margin-bottom:2.5rem}.wizard-logo{font-size:3rem;margin-bottom:1rem;animation:float 6s ease-in-out infinite}.wizard-header h1{font-size:clamp(1.75rem,4vw,2.5rem);margin-bottom:.5rem}.wizard-subtitle{color:var(--c-text-muted);font-size:var(--text-base)}.step-indicator{display:flex;justify-content:center;gap:.75rem;margin-top:1.5rem}.progress-dot{width:10px;height:10px;border-radius:50%;background:#ffffff1a;transition:all .3s ease}.progress-dot.active{background:var(--c-primary);transform:scale(1.3);box-shadow:0 0 10px var(--c-primary-dim)}.progress-dot.complete{background:var(--c-primary-glow)}.wizard-body{min-height:400px;margin-bottom:2rem}.step-content{animation:fadeUp .4s ease-out;text-align:center}.step-content h2{font-size:1.75rem;margin-bottom:.5rem;color:var(--c-text-main)}.step-subtitle{color:var(--c-text-muted);margin-bottom:2rem}.method-grid,.goal-grid,.cost-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(150px,100%),1fr));gap:1rem}.method-card,.option-card{background:#ffffff08;border:1px solid rgba(255,255,255,.05);border-radius:var(--radius-md);padding:var(--space-lg);cursor:pointer;transition:all .2s;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:180px}.method-card.selected,.option-card.selected{background:var(--c-primary-dim);border-color:var(--c-primary)}.frequency-list{display:flex;flex-direction:column;gap:.75rem;max-width:500px;margin:0 auto}.frequency-option{display:flex;align-items:center;justify-content:flex-start;gap:1.25rem;padding:1.25rem;background:#ffffff08;border:1px solid rgba(255,255,255,.05);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease}.frequency-option:hover{background:#ffffff0f}.frequency-option.selected{background:var(--c-primary-dim);border-color:var(--c-primary)}.radio-dot{width:20px;height:20px;border-radius:50%;border:2px solid var(--c-text-muted);position:relative;transition:all .2s ease}.frequency-option.selected .radio-dot{border-color:var(--c-primary);background:var(--c-primary);box-shadow:inset 0 0 0 4px #00000080}.profile-panel{display:flex;flex-direction:column;gap:0}.profile-header{display:flex;align-items:center;gap:1.25rem;padding:var(--space-xl);margin-bottom:.5rem;background:var(--c-surface-glass);border:1px solid var(--c-surface-glass-border);border-radius:var(--radius-md)}.acc-item{background:var(--c-surface-glass);border:1px solid var(--c-surface-glass-border);border-radius:var(--radius-md);margin-top:.75rem;overflow:hidden}.acc-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:1rem var(--space-xl);background:none;border:none;color:var(--c-text-main);cursor:pointer;text-align:left;gap:.75rem;-webkit-tap-highlight-color:transparent}.acc-header:active{background:#ffffff0a}.acc-header-text{flex:1;min-width:0}.acc-header-title{font-size:var(--text-base);font-weight:700;color:var(--c-text-main);display:block}.acc-header-preview{font-size:var(--text-sm);color:var(--c-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block;margin-top:.15rem}.acc-chevron{flex-shrink:0;font-size:1.1rem;color:var(--c-text-muted);transition:transform .22s ease;line-height:1}.acc-item--open>.acc-header .acc-chevron{transform:rotate(180deg)}.acc-body{display:none;padding:0 var(--space-xl) var(--space-xl);border-top:1px solid var(--c-surface-glass-border)}.acc-item--open>.acc-body{display:block}.acc-item--danger{border-color:#f8717140}.acc-item--danger .acc-header-title{color:var(--c-danger)}.profile-avatar{flex-shrink:0;width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,var(--c-primary),var(--c-primary-glow));color:#022c22;font-size:1.75rem;font-weight:800;display:grid;place-items:center;box-shadow:0 0 20px #10b9814d}.profile-info{display:flex;flex-direction:column;gap:.2rem;min-width:0}.profile-info h2{font-size:var(--text-lg);font-weight:700;color:var(--c-text-main);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.profile-email{font-size:var(--text-sm);color:var(--c-text-muted);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.profile-role-badge{display:inline-block;margin-top:.2rem;padding:.15rem .6rem;border-radius:var(--radius-pill);background:var(--c-primary-dim);color:var(--c-primary-glow);font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em;width:fit-content}.profile-section{display:flex;flex-direction:column;margin-top:.75rem;padding:var(--space-xl);background:var(--c-surface-glass);border:1px solid var(--c-surface-glass-border);border-radius:var(--radius-md)}.profile-section h3{font-size:var(--text-base);font-weight:700;color:var(--c-text-main);margin:0 0 1.25rem}.profile-form{display:flex;flex-direction:column;gap:0}.profile-message{padding:.75rem 1rem;border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:500;margin-bottom:1rem}.profile-message.hidden{display:none}.profile-message.error{background:#f871711a;border:1px solid rgba(248,113,113,.3);color:var(--c-danger)}.profile-message.success{background:#10b9811a;border:1px solid rgba(16,185,129,.3);color:var(--c-primary-glow)}.profile-danger-zone{border-color:#f8717140}.profile-danger-zone h3{color:var(--c-danger)}.profile-danger-text{font-size:var(--text-sm);color:var(--c-text-muted);margin:0 0 1.25rem;line-height:1.5}.wizard-footer{display:flex;flex-direction:column;align-items:center;gap:1.5rem;border-top:1px solid rgba(255,255,255,.05);padding-top:2rem}.wizard-nav{display:flex;width:100%;justify-content:space-between;align-items:center}.wizard-back{color:var(--c-text-muted);font-size:.9rem;padding-left:0}.wizard-back:hover{color:var(--c-text-main);background:none}.wizard-next{min-width:140px}.wizard-skip-link{background:none;border:none;color:var(--c-text-dim);font-size:.85rem;cursor:pointer;text-decoration:underline;opacity:.6;transition:opacity .2s}.wizard-skip-link:hover{opacity:1}.wizard-error{background:#f8717133;border:1px solid var(--c-danger);color:#fca5a5;padding:.75rem;border-radius:var(--radius-md);margin-bottom:1.5rem;display:flex;align-items:center;justify-content:center;animation:shake .4s cubic-bezier(.36,.07,.19,.97) both}.settings-section{display:flex;flex-direction:column;padding:var(--space-xl);background:var(--c-surface-glass);border:1px solid var(--c-surface-glass-border);border-radius:var(--radius-md);margin-bottom:var(--space-md);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}#settings-modal form{padding-top:5}.settings-section h3{font-size:var(--text-sm);font-weight:700;color:var(--c-text-dim);text-transform:uppercase;letter-spacing:.08em;margin-bottom:1rem}.settings-section .btn-secondary+.btn-secondary,.settings-section .methods-list+.btn-secondary{margin-top:.5rem}.methods-list{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.75rem}.method-item{display:flex;justify-content:space-between;align-items:center;background:#10b9811a;border:1px solid rgba(52,211,153,.3);padding:.75rem 1rem;border-radius:var(--radius-sm);transition:background .2s,border-color .2s}.method-item:hover{background:#10b98129;border-color:#34d39980}.method-icon{font-size:1.2rem;width:2rem;text-align:center;flex-shrink:0}.method-name{font-size:var(--text-sm);font-weight:600;color:var(--c-text-main)}.method-info{display:flex;align-items:center;gap:.75rem;flex:1;min-width:0}.settings-form-card{background:#10b9810a;border:1px solid var(--c-surface-glass-border);border-radius:var(--radius-sm);padding:var(--space-lg)}.settings-form-card h4{font-size:var(--text-base);font-weight:700;color:var(--c-text-main);margin-bottom:1rem}.badge-primary{display:inline-block;padding:.15rem .55rem;border-radius:var(--radius-pill);background:var(--c-primary-dim);color:var(--c-primary-glow);font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.btn-icon{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--c-text-muted);transition:all .2s;font-size:1.1rem;background:transparent;border:none;cursor:pointer;flex-shrink:0}.btn-icon:hover{background:#f8717126;color:var(--c-danger);transform:scale(1.1)}.btn-icon.edit-method:hover{background:#10b98126;color:var(--c-primary)}.warning-box{background:#fbbf241a;border:1px solid rgba(251,191,36,.3);color:var(--c-warning);padding:var(--space-md);border-radius:var(--radius-md);margin:var(--space-lg) 0;display:flex;gap:var(--space-md);align-items:flex-start}.warning-box div:first-child{font-size:1.5rem;flex-shrink:0}.session-now-row{display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem;margin-bottom:var(--space-lg);background:#ffffff0a;border:1px solid var(--c-surface-glass-border);border-radius:var(--radius-sm)}.session-now-label{font-size:var(--text-sm);color:var(--c-text-muted)}.session-link-btn{background:none;border:none;color:var(--c-primary);font-size:var(--text-sm);cursor:pointer;padding:0;text-decoration:underline;text-underline-offset:2px}.session-link-btn:hover{opacity:.8}.session-more-btn{width:100%;background:none;border:1px dashed var(--c-surface-glass-border);border-radius:var(--radius-sm);color:var(--c-text-muted);font-size:var(--text-sm);padding:.5rem;cursor:pointer;margin-bottom:var(--space-md);transition:border-color .15s,color .15s}.session-more-btn:hover{border-color:var(--c-primary);color:var(--c-primary)}.grams-display-muted{font-size:var(--text-sm);color:var(--c-text-muted);margin-left:.5rem}.warning-box strong{display:block;margin-bottom:.25rem;color:var(--c-warning)}.warning-box p{margin:0;font-size:.9em;opacity:.9}#interval-comparison{margin-top:.5rem;font-size:.85em;font-family:monospace;opacity:.8}.hidden{display:none!important}.full-width{width:100%!important}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes fadeUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUpFade{0%{opacity:0;transform:translateY(50px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes pulse{0%,to{opacity:1;text-shadow:0 0 5px var(--c-primary)}50%{opacity:.5;text-shadow:0 0 0 transparent}}.pulse{animation:pulse 2s infinite}.onboarding-success{text-align:center;padding:3rem 0;animation:fadeIn .6s ease-out;display:flex;flex-direction:column;align-items:center}.onboarding-success .btn-primary{width:auto;min-width:220px;margin-top:2rem}.success-burst{font-size:4rem;margin-bottom:1.5rem;animation:popIn .5s cubic-bezier(.175,.885,.32,1.275)}@keyframes popIn{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}@keyframes shake{10%,90%{transform:translate3d(-1px,0,0)}20%,80%{transform:translate3d(2px,0,0)}30%,50%,70%{transform:translate3d(-4px,0,0)}40%,60%{transform:translate3d(4px,0,0)}}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#0000001a}::-webkit-scrollbar-thumb{background:#10b9814d;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#10b98180}@media(max-width:480px){.subtitle{display:none}header h1{white-space:normal;overflow:visible;text-overflow:unset;font-size:var(--text-xl)}.user-badge{display:none}.logo-img{height:clamp(56px,12vw,80px)}.header-actions{gap:.25rem}#settings-btn,.logout-btn{width:36px;height:36px;font-size:1.1rem}}@media(max-width:319px){:root{--fab-size: 44px;--fab-gap: .5rem;--fab-edge: .75rem}.user-badge{display:none}}@media(min-width:640px){.container{max-width:720px;padding:var(--space-xl)}.stats-grid{grid-template-columns:repeat(3,1fr)}.view-toggles{max-width:500px;margin-left:auto;margin-right:auto}}@media(max-height:500px)and (orientation:landscape){header{margin-bottom:var(--space-md)}.streak-strip,.view-toggles{margin-bottom:var(--space-md)}#add-session-fab,#end-session-fab{--fab-edge: .75rem;--fab-size: 48px}}.finish-btn{background:var(--c-warning);color:#451a03;border:none;border-radius:4px;cursor:pointer;padding:2px 6px;display:inline-flex;align-items:center;justify-content:center}.finish-btn:hover{background:#fcd34d}.mood-picker-dialog{width:min(480px,calc(100vw - 2rem))}.mood-picker-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg);border-bottom:1px solid var(--c-surface-glass-border);font-weight:600;font-size:1rem}.mood-picker-body{padding:var(--space-lg)}.mood-intensity-labels{display:flex;justify-content:space-between;width:100%;font-size:.72rem;opacity:.5;margin-bottom:.4rem;padding:0 .1rem}.mood-emoji-grid{display:grid;grid-template-columns:repeat(10,1fr);gap:.3rem;width:100%}.mood-emoji-btn{aspect-ratio:1;border-radius:8px;border:1px solid transparent;font-size:1.25rem;cursor:pointer;transition:transform .1s;display:flex;align-items:center;justify-content:center}.mood-emoji-btn:hover{transform:scale(1.18)}.mood-emoji-btn:active{transform:scale(.92)}.mood-emoji-btn.selected{transform:scale(1.22);outline:2px solid white}.mood-emoji-btn--distress{background:#ef44442e;border-color:#ef444440}.mood-emoji-btn--struggle{background:#fbbf2433;border-color:#fbbf244d}.mood-emoji-btn--safety{background:#10b98133;border-color:#10b9814d}.mood-emoji-grid--compact .mood-emoji-btn{font-size:1rem}.mood-picker-dialog .mood-picker-skip.btn-secondary{margin:0 var(--space-lg) var(--space-lg);width:calc(100% - 2 * var(--space-lg))}
