@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-font-weight:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--spacing:.25rem;--text-xs:.75rem;--text-sm:.875rem;--text-sm--line-height:calc(1.25/.875);--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--font-weight-medium:500;--font-weight-semibold:600;--radius-sm:.25rem;--radius-md:.375rem;--radius-lg:.5rem;--radius-xl:.75rem;--radius-2xl:1rem;--shadow-sm:0 1px 3px 0 #0000001a,0 1px 2px -1px #0000001a;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}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;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.static{position:static}.mt-1{margin-top:calc(var(--spacing)*1)}.mt-2{margin-top:calc(var(--spacing)*2)}.mt-3{margin-top:calc(var(--spacing)*3)}.mt-4{margin-top:calc(var(--spacing)*4)}.mb-2{margin-bottom:calc(var(--spacing)*2)}.mb-3{margin-bottom:calc(var(--spacing)*3)}.mb-4{margin-bottom:calc(var(--spacing)*4)}.mb-6{margin-bottom:calc(var(--spacing)*6)}.flex{display:flex}.inline{display:inline}.table{display:table}.min-h-screen{min-height:100vh}.flex-1{flex:1}.cursor-pointer{cursor:pointer}.resize{resize:both}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-1{gap:calc(var(--spacing)*1)}.gap-2{gap:calc(var(--spacing)*2)}.gap-3{gap:calc(var(--spacing)*3)}.gap-4{gap:calc(var(--spacing)*4)}.rounded-lg{border-radius:var(--radius-lg)}.p-3{padding:calc(var(--spacing)*3)}.p-4{padding:calc(var(--spacing)*4)}.py-4{padding-block:calc(var(--spacing)*4)}.py-6{padding-block:calc(var(--spacing)*6)}.text-center{text-align:center}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.italic{font-style:italic}}:root{--font-sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:2rem;--color-bg:#f8fafc;--color-bg-elevated:#fff;--color-bg-subtle:#f1f5f9;--color-bg-inverse:#0f172a;--color-text:#0f172a;--color-text-secondary:#475569;--color-text-tertiary:#94a3b8;--color-text-inverse:#fff;--color-border:#e2e8f0;--color-border-subtle:#f1f5f9;--color-primary:#0ea5e9;--color-primary-hover:#0284c7;--color-primary-subtle:#e0f2fe;--color-primary-muted:#bae6fd;--color-success:#10b981;--color-success-subtle:#d1fae5;--color-success-muted:#6ee7b7;--color-warning:#f59e0b;--color-warning-subtle:#fef3c7;--color-warning-muted:#fcd34d;--color-danger:#ef4444;--color-danger-subtle:#fee2e2;--color-danger-muted:#fca5a5;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--radius-sm:.5rem;--radius-md:.75rem;--radius-lg:1rem;--radius-xl:1.25rem;--radius-2xl:1.5rem;--radius-full:9999px;--shadow-sm:0 1px 2px #0000000a;--shadow-md:0 4px 12px #0000000d;--shadow-lg:0 8px 24px #00000014;--shadow-xl:0 16px 48px #0000001f;--transition-fast:.15s ease;--transition-base:.2s ease;--transition-slow:.3s ease;--safe-bottom:max(1rem,env(safe-area-inset-bottom));--nav-height:5rem}.dark{--color-bg:#0f172a;--color-bg-elevated:#1e293b;--color-bg-subtle:#1e293b;--color-bg-inverse:#f8fafc;--color-text:#f1f5f9;--color-text-secondary:#94a3b8;--color-text-tertiary:#64748b;--color-text-inverse:#0f172a;--color-border:#334155;--color-border-subtle:#1e293b;--color-primary:#38bdf8;--color-primary-hover:#7dd3fc;--color-primary-subtle:#0c4a6e;--color-primary-muted:#075985;--color-success-subtle:#064e3b;--color-warning-subtle:#78350f;--color-danger-subtle:#7f1d1d;--shadow-sm:0 1px 2px #0003;--shadow-md:0 4px 12px #0000004d;--shadow-lg:0 8px 24px #0006;--shadow-xl:0 16px 48px #00000080}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{font-family:var(--font-sans);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-tap-highlight-color:transparent;font-size:16px;line-height:1.6}body{background-color:var(--color-bg);color:var(--color-text);min-height:100dvh;overflow-x:hidden}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.page{min-height:100dvh;padding:var(--space-6);padding-bottom:calc(var(--nav-height) + var(--space-8));max-width:480px;margin:0 auto}.page-header{margin-bottom:var(--space-8)}.page-title{font-size:var(--text-3xl);letter-spacing:-.02em;color:var(--color-text);margin-bottom:var(--space-2);font-weight:700}.page-subtitle{font-size:var(--text-base);color:var(--color-text-secondary)}.section{margin-bottom:var(--space-8)}.section-header{margin-bottom:var(--space-4);justify-content:space-between;align-items:center;display:flex}.section-title{font-size:var(--text-sm);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-tertiary);font-weight:600}.card{background:var(--color-bg-elevated);border-radius:var(--radius-xl);padding:var(--space-5);box-shadow:var(--shadow-sm);border:1px solid var(--color-border-subtle);transition:box-shadow var(--transition-base),transform var(--transition-base)}.card:hover{box-shadow:var(--shadow-md)}.card-interactive{cursor:pointer}.card-interactive:hover{transform:translateY(-2px)}.card-interactive:active{transform:translateY(0)}.card-glass{-webkit-backdrop-filter:blur(20px);background:#ffffffb3;border:1px solid #ffffff4d}.dark .card-glass{background:#1e293bb3;border:1px solid #ffffff1a}.status-grid{gap:var(--space-3);grid-template-columns:repeat(3,1fr);display:grid}.status-card{background:var(--color-bg-elevated);border-radius:var(--radius-lg);padding:var(--space-4);text-align:center;transition:all var(--transition-base);cursor:pointer;border:2px solid #0000}.status-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.status-card:active{transform:translateY(0)}.status-card--success{background:linear-gradient(135deg,var(--color-success-subtle)0%,#10b9810d 100%);border-color:var(--color-success-muted)}.status-card--warning{background:linear-gradient(135deg,var(--color-warning-subtle)0%,#f59e0b0d 100%);border-color:var(--color-warning-muted)}.status-card--danger{background:linear-gradient(135deg,var(--color-danger-subtle)0%,#ef44440d 100%);border-color:var(--color-danger-muted)}.status-card--neutral{background:var(--color-bg-subtle);border-color:var(--color-border)}.status-card__icon{border-radius:var(--radius-md);width:2.5rem;height:2.5rem;margin:0 auto var(--space-3);justify-content:center;align-items:center;display:flex}.status-card__icon--success{background:var(--color-success);color:#fff}.status-card__icon--warning{background:var(--color-warning);color:#fff}.status-card__icon--danger{background:var(--color-danger);color:#fff}.status-card__icon--neutral{background:var(--color-border);color:var(--color-text-tertiary)}.status-card__label{font-size:var(--text-xs);color:var(--color-text-secondary);margin-bottom:var(--space-1);font-weight:600}.status-card__value{font-size:var(--text-sm);color:var(--color-text);font-weight:500}.habit-list{gap:var(--space-2);flex-direction:column;display:flex}.habit-item{align-items:center;gap:var(--space-4);padding:var(--space-4)var(--space-5);background:var(--color-bg-elevated);border-radius:var(--radius-lg);border:1px solid var(--color-border-subtle);cursor:pointer;transition:all var(--transition-base);display:flex}.habit-item:hover{background:var(--color-bg-subtle);border-color:var(--color-border)}.habit-item--completed{background:var(--color-success-subtle);border-color:var(--color-success-muted)}.habit-checkbox{appearance:none;border:2px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-elevated);cursor:pointer;width:1.5rem;height:1.5rem;transition:all var(--transition-fast);flex-shrink:0;justify-content:center;align-items:center;display:flex}.habit-checkbox:checked{background:var(--color-success);border-color:var(--color-success)}.habit-checkbox:checked:after{content:"✓";color:#fff;font-size:.875rem;font-weight:700}.habit-checkbox:hover:not(:checked){border-color:var(--color-primary)}.habit-content{flex:1;min-width:0}.habit-name{font-size:var(--text-base);color:var(--color-text);transition:color var(--transition-fast);font-weight:500}.habit-item--completed .habit-name{color:var(--color-text-secondary);text-decoration:line-through}.habit-check-icon{color:var(--color-success);opacity:0;transition:opacity var(--transition-fast)}.habit-item--completed .habit-check-icon{opacity:1}.session-list{gap:var(--space-3);flex-direction:column;display:flex}.session-card{align-items:center;gap:var(--space-4);padding:var(--space-4);background:var(--color-bg-elevated);border-radius:var(--radius-lg);border:1px solid var(--color-border-subtle);display:flex}.session-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:3rem;height:3rem;display:flex}.session-icon--cafe{color:#fff;background:linear-gradient(135deg,#fde68a,#f59e0b)}.session-icon--home{color:#fff;background:linear-gradient(135deg,#93c5fd,#3b82f6)}.session-icon--other{color:#fff;background:linear-gradient(135deg,#c4b5fd,#8b5cf6)}.session-content{flex:1;min-width:0}.session-location{font-size:var(--text-base);color:var(--color-text);align-items:center;gap:var(--space-2);font-weight:600;display:flex}.session-meta{font-size:var(--text-sm);color:var(--color-text-secondary);margin-top:var(--space-1)}.session-delete{padding:var(--space-2);color:var(--color-text-tertiary);transition:color var(--transition-fast)}.session-delete:hover{color:var(--color-danger)}.empty-state{padding:var(--space-10)var(--space-6);text-align:center;background:var(--color-bg-elevated);border-radius:var(--radius-xl);border:2px dashed var(--color-border)}.empty-state__icon{width:4rem;height:4rem;margin:0 auto var(--space-4);color:var(--color-text-tertiary);opacity:.5}.empty-state__title{font-size:var(--text-lg);color:var(--color-text);margin-bottom:var(--space-2);font-weight:600}.empty-state__text{font-size:var(--text-sm);color:var(--color-text-secondary);margin-bottom:var(--space-6)}.btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-3)var(--space-5);font-size:var(--text-base);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);white-space:nowrap;border:none;min-height:3rem;font-weight:600;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--color-primary)0%,var(--color-primary-hover)100%);color:#fff;box-shadow:0 4px 14px #0ea5e966}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #0ea5e980}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-secondary{background:var(--color-bg-subtle);color:var(--color-text);border:1px solid var(--color-border)}.btn-secondary:hover:not(:disabled){background:var(--color-border);border-color:var(--color-border)}.btn-ghost{color:var(--color-text-secondary);padding:var(--space-2);background:0 0;min-height:auto}.btn-ghost:hover:not(:disabled){background:var(--color-bg-subtle);color:var(--color-text)}.btn-danger{background:linear-gradient(135deg,var(--color-danger)0%,#dc2626 100%);color:#fff;box-shadow:0 4px 14px #ef444466}.btn-danger:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #ef444480}.btn-sm{padding:var(--space-2)var(--space-3);font-size:var(--text-sm);min-height:2.25rem}.btn-lg{padding:var(--space-4)var(--space-6);font-size:var(--text-lg);min-height:3.5rem}.btn-block{width:100%}.input{width:100%;padding:var(--space-3)var(--space-4);font-size:var(--text-base);border:2px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-bg-elevated);color:var(--color-text);min-height:3rem;transition:all var(--transition-fast)}.input:focus{border-color:var(--color-primary);box-shadow:0 0 0 4px var(--color-primary-subtle);outline:none}.input::placeholder{color:var(--color-text-tertiary)}.input-label{font-size:var(--text-sm);color:var(--color-text);margin-bottom:var(--space-2);font-weight:600;display:block}.chip-group{gap:var(--space-2);flex-wrap:wrap;display:flex}.chip{align-items:center;gap:var(--space-1);padding:var(--space-2)var(--space-3);font-size:var(--text-sm);border-radius:var(--radius-full);background:var(--color-bg-subtle);color:var(--color-text-secondary);border:1px solid var(--color-border);cursor:pointer;transition:all var(--transition-fast);font-weight:500;display:inline-flex}.chip:hover{background:var(--color-border)}.chip--selected{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.chip--selected:hover{background:var(--color-primary-hover)}.badge{align-items:center;gap:var(--space-1);padding:var(--space-1)var(--space-2);font-size:var(--text-xs);border-radius:var(--radius-sm);text-transform:uppercase;letter-spacing:.02em;font-weight:600;display:inline-flex}.badge-success{background:var(--color-success-subtle);color:var(--color-success)}.badge-warning{background:var(--color-warning-subtle);color:var(--color-warning)}.badge-danger{background:var(--color-danger-subtle);color:var(--color-danger)}.badge-primary{background:var(--color-primary-subtle);color:var(--color-primary)}.streak-banner{align-items:center;gap:var(--space-3);padding:var(--space-3)var(--space-4);border-radius:var(--radius-lg);margin-top:var(--space-4);background:linear-gradient(135deg,#fef3c7,#fde68a);display:flex}.dark .streak-banner{background:linear-gradient(135deg,#78350f,#92400e)}.streak-icon{font-size:1.5rem}.streak-text{font-size:var(--text-sm);color:#92400e;font-weight:600}.dark .streak-text{color:#fde68a}.streak-count{font-size:var(--text-lg);font-weight:700}.bottom-nav{height:var(--nav-height);background:var(--color-bg-elevated);border-top:1px solid var(--color-border-subtle);padding-top:var(--space-2);padding-bottom:var(--safe-bottom);z-index:100;justify-content:space-around;align-items:flex-start;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 20px #0000000d}.dark .bottom-nav{box-shadow:0 -4px 20px #0000004d}.nav-item{align-items:center;gap:var(--space-1);padding:var(--space-2)var(--space-3);color:var(--color-text-tertiary);font-size:var(--text-xs);border-radius:var(--radius-lg);transition:all var(--transition-fast);flex-direction:column;min-width:4rem;font-weight:500;text-decoration:none;display:flex}.nav-item:hover{color:var(--color-text-secondary)}.nav-item.active{color:var(--color-primary)}.nav-item.active .nav-icon-wrapper{background:var(--color-primary-subtle)}.nav-icon-wrapper{border-radius:var(--radius-md);width:2.5rem;height:2.5rem;transition:background var(--transition-fast);justify-content:center;align-items:center;display:flex}.nav-item svg{width:1.25rem;height:1.25rem}.emergency-btn{bottom:calc(var(--nav-height) + var(--space-4));right:var(--space-6);border-radius:var(--radius-full);color:#fff;cursor:pointer;width:3.5rem;height:3.5rem;transition:all var(--transition-base);z-index:50;background:linear-gradient(135deg,#f59e0b,#d97706);border:none;justify-content:center;align-items:center;display:flex;position:fixed;box-shadow:0 8px 24px #f59e0b66}.emergency-btn:hover{transform:scale(1.08);box-shadow:0 12px 32px #f59e0b80}.emergency-btn:active{transform:scale(1)}.emergency-btn svg{width:1.5rem;height:1.5rem}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;animation:fadeIn var(--transition-fast);background:#0009;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--color-bg-elevated);border-radius:var(--radius-2xl)var(--radius-2xl)0 0;width:100%;max-width:500px;max-height:90vh;padding:var(--space-6);animation:slideUp var(--transition-base);overflow-y:auto}@keyframes slideUp{0%{opacity:.5;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@media(min-width:640px){.modal-overlay{padding:var(--space-6);align-items:center}.modal{border-radius:var(--radius-2xl)}}.modal-header{margin-bottom:var(--space-6);justify-content:space-between;align-items:center;display:flex}.modal-title{font-size:var(--text-xl);color:var(--color-text);font-weight:700}.modal-subtitle{font-size:var(--text-sm);color:var(--color-text-secondary);margin-top:var(--space-1)}.modal-close{padding:var(--space-2);color:var(--color-text-tertiary);background:var(--color-bg-subtle);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);border:none}.modal-close:hover{background:var(--color-border);color:var(--color-text)}.modal-section{margin-bottom:var(--space-6)}.modal-section:last-child{margin-bottom:0}.event-card{align-items:flex-start;gap:var(--space-3);padding:var(--space-4);border-radius:var(--radius-lg);border:1px solid;display:flex}.event-card--urge{background:var(--color-warning-subtle);border-color:var(--color-warning-muted)}.event-card--relapse{background:var(--color-danger-subtle);border-color:var(--color-danger-muted)}.event-icon{flex-shrink:0}.event-icon--urge{color:var(--color-warning)}.event-icon--relapse{color:var(--color-danger)}.event-content{flex:1;min-width:0}.event-type{font-size:var(--text-base);color:var(--color-text);font-weight:600}.event-meta{font-size:var(--text-sm);color:var(--color-text-secondary);margin-top:var(--space-1)}.stats-toggle{background:var(--color-bg-subtle);border-radius:var(--radius-lg);padding:var(--space-1);gap:var(--space-1);display:flex}.stats-toggle-btn{padding:var(--space-3);font-size:var(--text-sm);border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;flex:1;font-weight:600}.stats-toggle-btn--active{background:var(--color-bg-elevated);color:var(--color-text);box-shadow:var(--shadow-sm)}.metric-grid{gap:var(--space-3);grid-template-columns:repeat(2,1fr);display:grid}.metric-card{background:var(--color-bg-elevated);border-radius:var(--radius-lg);padding:var(--space-5);border:1px solid var(--color-border-subtle)}.metric-icon{border-radius:var(--radius-md);width:2.5rem;height:2.5rem;margin-bottom:var(--space-3);justify-content:center;align-items:center;display:flex}.metric-icon--success{background:var(--color-success-subtle);color:var(--color-success)}.metric-icon--danger{background:var(--color-danger-subtle);color:var(--color-danger)}.metric-icon--primary{background:var(--color-primary-subtle);color:var(--color-primary)}.metric-value{font-size:var(--text-2xl);color:var(--color-text);margin-bottom:var(--space-1);font-weight:700}.metric-label{font-size:var(--text-sm);color:var(--color-text-secondary)}.insight-card{padding:var(--space-4);border-radius:var(--radius-lg);margin-bottom:var(--space-3);border:1px solid}.insight-card--warning{background:var(--color-warning-subtle);border-color:var(--color-warning-muted)}.insight-card--info{background:var(--color-primary-subtle);border-color:var(--color-primary-muted)}.insight-card--neutral{background:var(--color-bg-elevated);border-color:var(--color-border)}.insight-icon{margin-right:var(--space-2);font-size:1.25rem}.insight-text{font-size:var(--text-sm);color:var(--color-text);line-height:1.5}.progress-bar{background:var(--color-bg-subtle);border-radius:var(--radius-full);height:.5rem;overflow:hidden}.progress-fill{background:linear-gradient(90deg,var(--color-success)0%,var(--color-success-muted)100%);border-radius:var(--radius-full);height:100%;transition:width var(--transition-slow)}.settings-group{margin-bottom:var(--space-8)}.settings-group-title{font-size:var(--text-sm);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-tertiary);margin-bottom:var(--space-4);font-weight:600}.settings-card{background:var(--color-bg-elevated);border-radius:var(--radius-xl);border:1px solid var(--color-border-subtle);overflow:hidden}.settings-item{padding:var(--space-4)var(--space-5);border-bottom:1px solid var(--color-border-subtle);justify-content:space-between;align-items:center;display:flex}.settings-item:last-child{border-bottom:none}.settings-label{font-size:var(--text-base);color:var(--color-text)}.settings-value{font-size:var(--text-sm);color:var(--color-text-secondary)}.theme-grid{gap:var(--space-2);grid-template-columns:repeat(3,1fr);display:grid}.theme-btn{align-items:center;gap:var(--space-2);padding:var(--space-4);border:2px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-bg-elevated);cursor:pointer;transition:all var(--transition-fast);flex-direction:column;display:flex}.theme-btn:hover{border-color:var(--color-primary-muted)}.theme-btn--active{border-color:var(--color-primary);background:var(--color-primary-subtle)}.theme-btn svg{width:1.5rem;height:1.5rem;color:var(--color-text-secondary)}.theme-btn--active svg{color:var(--color-primary)}.theme-btn span{font-size:var(--text-sm);color:var(--color-text);font-weight:500}.mode-grid{gap:var(--space-3);grid-template-columns:repeat(2,1fr);display:grid}.mode-card{align-items:center;gap:var(--space-3);padding:var(--space-5);border:2px solid var(--color-border);border-radius:var(--radius-xl);background:var(--color-bg-elevated);cursor:pointer;transition:all var(--transition-fast);flex-direction:column;display:flex}.mode-card:hover{border-color:var(--color-primary-muted)}.mode-card--active{border-color:var(--color-primary);background:var(--color-primary-subtle)}.mode-card svg{width:2rem;height:2rem;color:var(--color-text-secondary)}.mode-card--active svg{color:var(--color-primary)}.mode-name{font-size:var(--text-base);color:var(--color-text);font-weight:600}.mode-desc{font-size:var(--text-xs);color:var(--color-text-secondary)}.day-list{gap:var(--space-2);flex-direction:column;display:flex}.day-card{align-items:center;gap:var(--space-4);padding:var(--space-4);background:var(--color-bg-elevated);border-radius:var(--radius-lg);border:1px solid var(--color-border-subtle);cursor:pointer;transition:all var(--transition-base);display:flex}.day-card:hover{border-color:var(--color-border);transform:translate(4px)}.day-card:disabled{opacity:.5;cursor:not-allowed}.day-card:disabled:hover{transform:none}.day-indicator{border-radius:var(--radius-lg);flex-shrink:0;justify-content:center;align-items:center;width:3rem;height:3rem;display:flex}.day-indicator--clean{background:var(--color-success-subtle);color:var(--color-success)}.day-indicator--relapse{background:var(--color-danger-subtle);color:var(--color-danger)}.day-indicator--neutral{background:var(--color-bg-subtle);color:var(--color-text-tertiary)}.day-content{flex:1;min-width:0}.day-date{font-size:var(--text-base);color:var(--color-text);font-weight:600}.day-summary{align-items:center;gap:var(--space-3);font-size:var(--text-sm);color:var(--color-text-secondary);margin-top:var(--space-1);display:flex}.day-arrow{color:var(--color-text-tertiary);flex-shrink:0}.slider{appearance:none;border-radius:var(--radius-full);background:var(--color-bg-subtle);outline:none;width:100%;height:.5rem}.slider::-webkit-slider-thumb{appearance:none;background:var(--color-primary);cursor:pointer;width:1.5rem;height:1.5rem;box-shadow:var(--shadow-md);transition:transform var(--transition-fast);border-radius:50%}.slider::-webkit-slider-thumb:hover{transform:scale(1.1)}.slider::-moz-range-thumb{background:var(--color-primary);cursor:pointer;width:1.5rem;height:1.5rem;box-shadow:var(--shadow-md);border:none;border-radius:50%}.toast{bottom:calc(var(--nav-height) + var(--space-6));background:var(--color-bg-inverse);color:var(--color-text-inverse);padding:var(--space-3)var(--space-5);border-radius:var(--radius-full);font-size:var(--text-sm);box-shadow:var(--shadow-lg);z-index:300;animation:toastIn var(--transition-base);font-weight:500;position:fixed;left:50%;transform:translate(-50%)}@keyframes toastIn{0%{opacity:0;transform:translate(-50%)translateY(10px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.spinner{border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;width:2rem;height:2rem;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.spinner-sm{border-width:2px;width:1.25rem;height:1.25rem}.protocol-steps{gap:var(--space-3);flex-direction:column;display:flex}.protocol-step{align-items:flex-start;gap:var(--space-4);padding:var(--space-4);background:var(--color-bg-elevated);border-radius:var(--radius-lg);border:2px solid var(--color-border);cursor:pointer;transition:all var(--transition-fast);display:flex}.protocol-step:hover{border-color:var(--color-primary-muted)}.protocol-step--completed{background:var(--color-success-subtle);border-color:var(--color-success-muted)}.protocol-number{border-radius:var(--radius-full);width:2rem;height:2rem;font-size:var(--text-sm);background:var(--color-bg-subtle);color:var(--color-text-secondary);transition:all var(--transition-fast);flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:flex}.protocol-step--completed .protocol-number{background:var(--color-success);color:#fff}.protocol-content{flex:1}.protocol-title{font-size:var(--text-base);color:var(--color-text);margin-bottom:var(--space-1);font-weight:600}.protocol-desc{font-size:var(--text-sm);color:var(--color-text-secondary)}.location-grid{gap:var(--space-2);grid-template-columns:repeat(3,1fr);display:grid}.location-btn{align-items:center;gap:var(--space-2);padding:var(--space-4);border:2px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-bg-elevated);cursor:pointer;transition:all var(--transition-fast);flex-direction:column;display:flex}.location-btn:hover{border-color:var(--color-primary-muted)}.location-btn--active{border-color:var(--color-primary);background:var(--color-primary-subtle)}.location-btn svg{width:1.5rem;height:1.5rem;color:var(--color-text-secondary)}.location-btn--active svg{color:var(--color-primary)}.location-btn span{font-size:var(--text-sm);color:var(--color-text);font-weight:500}.mood-grid{gap:var(--space-2);flex-wrap:wrap;display:flex}.mood-btn{align-items:center;gap:var(--space-2);padding:var(--space-2)var(--space-3);border:2px solid var(--color-border);border-radius:var(--radius-full);background:var(--color-bg-elevated);cursor:pointer;font-size:var(--text-sm);transition:all var(--transition-fast);display:flex}.mood-btn:hover{border-color:var(--color-primary-muted)}.mood-btn--active{border-color:var(--color-primary);background:var(--color-primary-subtle)}.event-type-grid{gap:var(--space-3);grid-template-columns:repeat(2,1fr);display:grid}.event-type-btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-4);border:2px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-bg-elevated);cursor:pointer;font-size:var(--text-base);transition:all var(--transition-fast);font-weight:600;display:flex}.event-type-btn:hover{border-color:var(--color-primary-muted)}.event-type-btn--urge.event-type-btn--active{border-color:var(--color-warning);background:var(--color-warning-subtle);color:#92400e}.event-type-btn--relapse.event-type-btn--active{border-color:var(--color-danger);background:var(--color-danger-subtle);color:#991b1b}.text-center{text-align:center}.text-right{text-align:right}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.w-full{width:100%}.min-h-screen{min-height:100vh}.mb-2{margin-bottom:var(--space-2)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.mb-8{margin-bottom:var(--space-8)}.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.p-4{padding:var(--space-4)}.p-6{padding:var(--space-6)}.py-2{padding-top:var(--space-2);padding-bottom:var(--space-2)}.py-4{padding-top:var(--space-4);padding-bottom:var(--space-4)}.px-4{padding-left:var(--space-4);padding-right:var(--space-4)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-xl{border-radius:var(--radius-xl)}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-sm{font-size:var(--text-sm)}.text-base{font-size:var(--text-base)}.text-lg{font-size:var(--text-lg)}.text-xl{font-size:var(--text-xl)}.text-2xl{font-size:var(--text-2xl)}.text-primary{color:var(--color-text)}.text-secondary{color:var(--color-text-secondary)}.text-muted{color:var(--color-text-tertiary)}.text-success{color:var(--color-success)}.text-danger{color:var(--color-danger)}.text-warning{color:var(--color-warning)}.bg-subtle{background:var(--color-bg-subtle)}.bg-elevated{background:var(--color-bg-elevated)}.border{border:1px solid var(--color-border)}.border-subtle{border:1px solid var(--color-border-subtle)}.shadow-sm{box-shadow:var(--shadow-sm)}.shadow-md{box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:var(--shadow-lg)}.transition{transition:all var(--transition-base)}.cursor-pointer{cursor:pointer}.select-none{-webkit-user-select:none;user-select:none}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.opacity-50{opacity:.5}.opacity-0{opacity:0}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.pin-lock-screen{background:var(--color-bg);z-index:1000;padding:var(--space-6);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.pin-lock-content{text-align:center;width:100%;max-width:320px}.pin-lock-icon{border-radius:var(--radius-full);background:linear-gradient(135deg,var(--color-primary)0%,var(--color-primary-hover)100%);width:5rem;height:5rem;margin:0 auto var(--space-6);color:#fff;justify-content:center;align-items:center;display:flex}.pin-lock-title{font-size:var(--text-2xl);color:var(--color-text);margin-bottom:var(--space-2);font-weight:700}.pin-lock-subtitle{font-size:var(--text-sm);color:var(--color-text-secondary);margin-bottom:var(--space-8)}.pin-dots{justify-content:center;gap:var(--space-4);margin-bottom:var(--space-6);display:flex}.pin-dot{border-radius:var(--radius-full);background:var(--color-border);width:1rem;height:1rem;transition:all var(--transition-fast);font-size:var(--text-xs);color:var(--color-text);justify-content:center;align-items:center;font-weight:700;display:flex}.pin-dot--filled{background:var(--color-primary);transform:scale(1.2)}.pin-dot--error{background:var(--color-danger);animation:.4s shake}@keyframes shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-8px)}40%,80%{transform:translate(8px)}}.pin-error{font-size:var(--text-sm);color:var(--color-danger);margin-bottom:var(--space-4);animation:fadeIn var(--transition-fast)}.pin-toggle-visibility{align-items:center;gap:var(--space-2);padding:var(--space-2)var(--space-3);font-size:var(--text-sm);color:var(--color-text-secondary);cursor:pointer;margin-bottom:var(--space-6);background:0 0;border:none;display:inline-flex}.pin-toggle-visibility:hover{color:var(--color-text)}.pin-keypad{gap:var(--space-3);grid-template-columns:repeat(3,1fr);max-width:280px;margin:0 auto;display:grid}.pin-key{aspect-ratio:1;border-radius:var(--radius-full);background:var(--color-bg-elevated);border:1px solid var(--color-border);font-size:var(--text-2xl);color:var(--color-text);cursor:pointer;transition:all var(--transition-fast);justify-content:center;align-items:center;font-weight:600;display:flex}.pin-key:hover:not(:disabled){background:var(--color-bg-subtle);border-color:var(--color-primary);transform:scale(1.05)}.pin-key:active:not(:disabled){background:var(--color-primary-subtle);transform:scale(.95)}.pin-key:disabled{opacity:.5;cursor:not-allowed}.pin-key--back{color:var(--color-text-secondary);font-size:var(--text-lg)}.pin-key-empty{visibility:hidden}.lang-selector{gap:var(--space-2);display:flex}.lang-btn{padding:var(--space-2)var(--space-3);font-size:var(--text-sm);border:2px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-elevated);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);font-weight:500}.lang-btn:hover{border-color:var(--color-primary-muted)}.lang-btn--active{border-color:var(--color-primary);background:var(--color-primary-subtle);color:var(--color-primary)}[dir=rtl] .page{direction:rtl}[dir=rtl] .habit-item,[dir=rtl] .session-card,[dir=rtl] .day-card,[dir=rtl] .settings-item,[dir=rtl] .section-header{flex-direction:row-reverse}[dir=rtl] .bottom-nav{direction:ltr}@property --tw-font-weight{syntax:"*";inherits:false}
