@import "https://fonts.googleapis.com/css2?family=Fredoka:wght@400;500;600;700&family=Outfit:wght@400;500;600;700;800&family=Space+Mono:wght@400;700&family=Noto+Sans+KR:wght@400;500;600;700;800;900&display=swap";
.install-app-fab{background:var(--orange);color:#fff;cursor:pointer;z-index:9997;border:none;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;transition:all .3s;animation:.4s ease-out fadeInScale;display:flex;position:fixed;bottom:24px;right:24px;box-shadow:0 4px 12px #ff9e444d}@keyframes fadeInScale{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.install-app-fab:hover{background:#ff8a30;transform:scale(1.1);box-shadow:0 6px 20px #ff9e4466}.install-app-fab:active{transform:scale(.95)}.install-app-fab svg{width:24px;height:24px}@media (max-width:639px){.install-app-fab{width:48px;height:48px;bottom:20px;right:20px}.install-app-fab svg{width:20px;height:20px}}
@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-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-font-weight:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:root,:host{--font-sans:"Outfit","Noto Sans KR",-apple-system,sans-serif;--font-serif:"Fredoka","Noto Sans KR","Comic Sans MS",cursive;--font-mono:"Space Mono","Noto Sans KR","Courier New",monospace;--color-red-400:#ff6568;--color-red-600:#e40014;--color-orange-500:#fe6e00;--color-green-400:#05df72;--color-green-600:#00a544;--color-gray-300:#d1d5dc;--color-gray-400:#99a1af;--color-gray-600:#4a5565;--color-white:#fff;--spacing:.25rem;--text-xs:.75rem;--text-xs--line-height:calc(1/.75);--text-sm:.875rem;--text-sm--line-height:calc(1.25/.875);--font-weight-medium:500;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4,0,.2,1);--default-font-family:"Outfit","Noto Sans KR",-apple-system,sans-serif;--default-mono-font-family:"Space Mono","Noto Sans KR","Courier New",monospace}@supports (color:lab(0% 0 0)){:root,:host{--color-red-400:lab(63.7053% 60.745 31.3109);--color-red-600:lab(48.4493% 77.4328 61.5452);--color-orange-500:lab(64.272% 57.1788 90.3583);--color-green-400:lab(78.503% -64.9265 39.7492);--color-green-600:lab(59.0978% -58.6621 41.2579);--color-gray-300:lab(85.1236% -.612259 -3.7138);--color-gray-400:lab(65.9269% -.832707 -8.17473);--color-gray-600:lab(35.6337% -1.58697 -10.8425)}}}@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;-webkit-text-decoration:inherit;-webkit-text-decoration: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{.visible{visibility:visible}.sr-only{clip-path:inset(50%);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.table{display:table}.h-4{height:calc(var(--spacing)*4)}.h-6{height:calc(var(--spacing)*6)}.w-4{width:calc(var(--spacing)*4)}.w-11{width:calc(var(--spacing)*11)}.grow{flex-grow:1}.translate-x-1{--tw-translate-x:calc(var(--spacing)*1);translate:var(--tw-translate-x)var(--tw-translate-y)}.translate-x-6{--tw-translate-x:calc(var(--spacing)*6);translate:var(--tw-translate-x)var(--tw-translate-y)}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.resize{resize:both}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-1{gap:calc(var(--spacing)*1)}.gap-2{gap:calc(var(--spacing)*2)}.rounded{border-radius:.25rem}.rounded-full{border-radius:3.40282e38px}.border{border-style:var(--tw-border-style);border-width:1px}.bg-gray-300{background-color:var(--color-gray-300)}.bg-orange-500{background-color:var(--color-orange-500)}.bg-white{background-color:var(--color-white)}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.text-gray-600{color:var(--color-gray-600)}.text-green-600{color:var(--color-green-600)}.text-red-600{color:var(--color-red-600)}.lowercase{text-transform:lowercase}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.opacity-50{opacity:.5}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a),0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.filter{filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-transform{transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.focus\:ring-2:focus{--tw-ring-shadow:var(--tw-ring-inset,)0 0 0 calc(2px + var(--tw-ring-offset-width))var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.focus\:ring-orange-500:focus{--tw-ring-color:var(--color-orange-500)}.focus\:ring-offset-2:focus{--tw-ring-offset-width:2px;--tw-ring-offset-shadow:var(--tw-ring-inset,)0 0 0 var(--tw-ring-offset-width)var(--tw-ring-offset-color)}.focus\:outline-none:focus{--tw-outline-style:none;outline-style:none}@media (prefers-color-scheme:dark){.dark\:bg-gray-600{background-color:var(--color-gray-600)}.dark\:text-gray-400{color:var(--color-gray-400)}.dark\:text-green-400{color:var(--color-green-400)}.dark\:text-red-400{color:var(--color-red-400)}}}:root{--background:#fff;--foreground:#2d3142;--lemon:#f4d35e;--lemon-dark:#e8c04d;--orange:#ff9e44;--orange-light:#ffcf9d;--paper:#fffdf7;--cream:#fff9e6;--peach:#ffe4cc;--border:#ffd699;--dark-text:#2d3142}@media (prefers-color-scheme:dark){:root{--background:#2d3142;--foreground:#fffdf7}}*{box-sizing:border-box;margin:0;padding:0}@keyframes grain{0%,to{transform:translate(0)}10%{transform:translate(-5%,-10%)}20%{transform:translate(-15%,5%)}30%{transform:translate(7%,-25%)}40%{transform:translate(-5%,25%)}50%{transform:translate(-15%,10%)}60%{transform:translate(15%)}70%{transform:translateY(15%)}80%{transform:translate(3%,35%)}90%{transform:translate(-10%,10%)}}body{color:var(--foreground);font-family:var(--font-sans);background:#fff;min-height:100vh;padding:24px;position:relative}body:before{content:"";pointer-events:none;z-index:0;width:100%;height:100%;display:none;position:fixed;top:0;left:0}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.header-top{flex-direction:row;justify-content:center;align-items:center;padding:0 50px;animation:.6s ease-out fadeInUp;display:flex;position:relative}.home-button{background:var(--lemon);width:40px;height:40px;color:var(--dark-text);border:2px solid var(--orange);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;font-size:1.5rem;font-weight:600;text-decoration:none;transition:all .2s;display:inline-flex;position:absolute;left:0;box-shadow:0 2px 6px #0000001a}.home-button:hover{background:var(--orange);transform:translateY(-2px);box-shadow:0 4px 8px #ff9e4440,0 8px 20px #ff9e4433,0 0 0 3px #ff9e441a}.home-button:active{transform:translateY(0);box-shadow:0 2px 4px #0000001a}.header-title-group{text-align:center;flex-direction:column;flex:1;gap:0;min-width:0;animation:.7s ease-out .1s both fadeInUp;display:flex}.header-title-group h1{margin:0;line-height:1.2}.header-subtitle{color:var(--dark-text);font-size:1.05rem;font-weight:700;font-family:var(--font-serif);font-style:normal}.header-actions{flex-direction:column;align-items:stretch;gap:16px;animation:.7s ease-out .2s both fadeInUp;display:flex}.header-profile{background:#fff;border:2px solid #f0f0f0;border-radius:12px;align-items:center;gap:14px;padding:14px 18px;transition:all .3s;display:flex;position:relative;box-shadow:0 2px 8px #0000000a}.header-profile:hover{border-color:var(--lemon);box-shadow:0 4px 12px #f4d35e26}.header-profile:before{display:none}.header-profile-avatar{object-fit:cover;border:3px solid var(--orange);border-radius:50%;width:52px;height:52px;box-shadow:0 4px 12px #ff9e4466}.header-profile-initials{background:var(--lemon);width:52px;height:52px;color:var(--dark-text);border:2px solid var(--orange);font-size:1.3rem;font-weight:800;font-family:var(--font-serif);border-radius:50%;justify-content:center;align-items:center;display:inline-flex;box-shadow:0 2px 6px #0000001a}.header-profile-meta{flex-direction:column;gap:3px;display:flex}.header-profile-name{color:var(--dark-text);font-weight:700;font-family:var(--font-serif);font-size:1.1rem}.header-profile-email{color:var(--orange);font-size:.85rem;font-family:var(--font-serif);font-size:.75rem}.header-nav{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}.header-link{background:var(--lemon);color:var(--dark-text);cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;padding:10px 20px;font-size:.9rem;font-weight:600;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);display:inline-flex;position:relative;box-shadow:0 2px 4px #f4d35e33,0 4px 12px #f4d35e26}.header-link:hover{background:var(--orange);transform:translateY(-3px);box-shadow:0 4px 8px #ff9e4440,0 8px 20px #ff9e4433,0 0 0 4px #ff9e441a}.header-link:active{transform:translateY(-1px);box-shadow:0 2px 4px #ff9e4433,0 4px 12px #ff9e4426}.header-link-button{font:inherit}.container{background:#fff;border:1px solid #f4d35e1a;border-radius:16px;max-width:1200px;margin:0 auto;transition:all .4s cubic-bezier(.4,0,.2,1);animation:.8s cubic-bezier(.34,1.56,.64,1) .3s both fadeInUp;position:relative;overflow:hidden;box-shadow:0 4px 6px #00000008,0 10px 20px #0000000a,0 20px 40px #00000008}.container:hover{transform:translateY(-2px);box-shadow:0 6px 10px #0000000a,0 15px 30px #0000000d,0 25px 50px #0000000a}.container:before{content:"";background:linear-gradient(90deg,var(--lemon),var(--orange));z-index:2;height:4px;position:absolute;top:0;left:0;right:0;box-shadow:0 2px 8px #f4d35e66}.header{color:var(--dark-text);text-align:center;background:#fff;border-bottom:1px solid #f0f0f0;padding:24px 24px 20px;position:relative}.header:after{display:none}.header h1{letter-spacing:-.01em;font-size:2.4rem;font-weight:700;font-family:var(--font-serif);color:var(--dark-text);text-shadow:3px 3px #ff9e4433;margin-bottom:12px}.date{color:var(--dark-text);font-size:1.05rem;font-weight:600;font-family:var(--font-mono);border:2px solid var(--lemon);background:#fff;border-radius:8px;align-items:center;gap:10px;padding:8px 16px;display:inline-flex;box-shadow:0 2px 4px #0000000a}.date:before{content:"📅";font-size:1rem}.date-switcher{flex-wrap:nowrap;justify-content:center;align-items:center;gap:16px;margin-top:20px;display:flex}.date-display{flex-direction:column;align-items:center;gap:8px;display:flex}.date-caption{color:var(--dark-text);font-size:1rem;font-family:var(--font-serif);background:linear-gradient(135deg,#f4d35e2e,#ff9e441f);border:1px solid #f4d35e99;border-radius:12px;flex-wrap:wrap;justify-content:center;align-items:center;gap:8px;padding:8px 14px;font-weight:700;display:flex}.date-nav-button{border:2px solid var(--lemon);width:44px;height:44px;color:var(--dark-text);cursor:pointer;background:#fff;border-radius:50%;font-size:1.4rem;font-weight:700;transition:all .3s;box-shadow:0 2px 4px #0000000a}.date-nav-button:disabled{opacity:.4;cursor:not-allowed;filter:grayscale(.5)}.date-nav-button:not(:disabled):hover{background:var(--lemon);border-color:var(--orange);transform:translateY(-2px);box-shadow:0 4px 8px #f4d35e26}.date-reset{color:var(--orange);cursor:pointer;font-weight:700;font-family:var(--font-serif);text-underline-offset:4px;background:0 0;border:none;padding:0;text-decoration:underline;text-decoration-thickness:2px;transition:all .2s}.date-reset:hover{color:var(--lemon-dark);transform:scale(1.05)}.main-content{padding:20px 24px 28px;animation:.8s ease-out .5s both fadeIn}.chart-legends{flex-wrap:wrap;justify-content:center;gap:16px;padding:12px 0;display:flex;overflow:visible}.legend-item{color:#2d2d35;align-items:center;gap:8px;font-size:14px;display:flex;overflow:visible}.legend-color{border:1px solid #0000001a;border-radius:3px;width:20px;height:12px;display:inline-block}.legend-color-focus{background-color:#ff63474d}.legend-color-sleep{background-color:#1e90ff4d}.legend-label{-webkit-user-select:none;user-select:none;font-weight:500}.legend-info{cursor:pointer;color:#8e8e93;background:0 0;border:none;justify-content:center;align-items:center;width:16px;height:16px;padding:0;transition:color .2s;display:inline-flex;position:relative}.legend-info:hover{color:#5c5c66}.legend-info svg{width:16px;height:16px}.legend-tooltip{color:#fff;white-space:normal;z-index:9999;pointer-events:none;text-align:left;background:#2d2d35;border-radius:8px;width:max-content;max-width:calc(100vw - 40px);padding:8px 12px;font-size:12px;line-height:1.4;animation:.2s tooltipFadeIn;position:absolute;bottom:calc(100% + 8px);left:0;box-shadow:0 4px 12px #00000026}.legend-item:last-child .legend-tooltip{left:auto;right:0}.legend-tooltip:after{content:"";border:6px solid #0000;border-top-color:#2d2d35;position:absolute;top:100%;left:12px}.legend-item:last-child .legend-tooltip:after{left:auto;right:12px}@keyframes tooltipFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@media (max-width:640px){.legend-tooltip{min-width:auto;max-width:calc(100vw - 40px)}}.chart-wrapper{background:#fff;border:1px solid #f4d35e26;border-bottom:none;border-radius:16px 16px 0 0;width:100%;margin-bottom:0;padding:11px 9px 0;transition:all .4s;position:relative;overflow:visible;box-shadow:0 2px 6px #00000005,0 6px 16px #00000008,0 12px 32px #00000005}.chart-wrapper:hover{transform:translateY(-2px);box-shadow:0 4px 10px #f4d35e14,0 10px 24px #f4d35e0f,0 16px 40px #f4d35e0a}.chart-title{font-family:var(--font-serif);color:var(--dark-text);letter-spacing:.02em;z-index:10;border:2px solid var(--lemon);background:#fff;border-radius:8px;padding:6px 20px;font-size:.95rem;font-weight:700;position:absolute;top:12px;left:50%;transform:translate(-50%);box-shadow:0 2px 4px #0000000a}.chart-container{background:#fff;border-radius:12px;width:100%;height:400px}.slider-section{background:#fff;border:1px solid #f4d35e26;border-top:1px dashed #f4d35e59;border-radius:0 0 16px 16px;margin-bottom:20px;padding:12px 20px 18px;animation:.7s ease-out .6s both fadeInUp;position:relative;box-shadow:0 2px 8px #0000000a}.slider-section:before{display:none}.slider-label{color:var(--dark-text);font-weight:700;font-family:var(--font-serif);justify-content:space-between;align-items:center;margin-bottom:16px;font-size:1.1rem;display:flex}.time-display{color:var(--dark-text);letter-spacing:.05em;font-size:1.1rem;font-weight:700;font-family:var(--font-mono);border:2px solid var(--lemon);cursor:pointer;background:#fff;border-radius:8px;padding:8px 18px;transition:all .3s;box-shadow:0 2px 4px #0000000a}.time-display:hover{background:var(--cream);border-color:var(--orange);transform:translateY(-2px);box-shadow:0 4px 8px #ff9e4426}.time-display:active{transform:translateY(0);box-shadow:0 2px 4px #0000000a}.time-input{color:var(--dark-text);letter-spacing:.05em;font-size:1.1rem;font-weight:700;font-family:var(--font-mono);border:2px solid var(--orange);background:#fff;border-radius:8px;outline:none;padding:8px 18px;transition:all .3s;box-shadow:0 0 0 4px #ff9e4433}.slider{-webkit-appearance:none;cursor:pointer;background:linear-gradient(90deg,#f4d35e33 0%,#ff9e4433 100%);border:none;border-radius:10px;outline:none;width:100%;height:8px;transition:all .3s;position:relative;box-shadow:inset 0 1px 3px #00000014}.slider:hover{background:linear-gradient(90deg,#f4d35e4d 0%,#ff9e444d 100%)}.slider::-webkit-slider-thumb{appearance:none;background:linear-gradient(135deg,var(--lemon),var(--orange));cursor:pointer;border:none;border-radius:50%;width:22px;height:22px;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 6px #f4d35e66,0 4px 12px #f4d35e4d,0 0 0 4px #fffc}.slider::-webkit-slider-thumb:hover{transform:scale(1.3);box-shadow:0 3px 8px #ff9e4480,0 6px 16px #ff9e4466,0 0 0 6px #ffffffe6}.slider::-webkit-slider-thumb:active{transform:scale(1.2)}.slider::-moz-range-thumb{background:linear-gradient(135deg,var(--lemon),var(--orange));cursor:pointer;border:4px solid #fff;border-radius:50%;width:22px;height:22px;transition:all .3s;box-shadow:0 2px 6px #f4d35e66,0 4px 12px #f4d35e4d}.dose-controls-row{grid-template-columns:1fr 1fr;gap:20px;margin-bottom:22px;animation:.7s ease-out .7s both fadeInUp;display:grid}.disclaimer-section{color:#dc2626;background:#dc26260d;border-left:3px solid #dc2626;border-radius:6px;align-items:flex-start;gap:8px;margin-top:32px;padding:10px 14px;font-size:.75rem;line-height:1.5;animation:.7s ease-out .8s both fadeInUp;display:flex}.disclaimer-section svg{flex-shrink:0;margin-top:2px}.disclaimer-section span{flex:1}.controls-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:20px;margin-bottom:22px;animation:.7s ease-out .7s both fadeInUp;display:grid}.medication-card{background:#fff;border:1px solid #f4d35e26;border-radius:16px;padding:16px 18px;transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;box-shadow:0 2px 4px #00000005,0 4px 12px #00000008,0 8px 24px #00000005}.medication-card:hover{border-color:var(--lemon);transform:translateY(-4px);box-shadow:0 4px 8px #f4d35e26,0 12px 24px #f4d35e1f,0 20px 40px #f4d35e14}.medication-card:before{content:"";-webkit-mask-composite:xor;opacity:0;pointer-events:none;-webkit-mask-composite:xor;-webkit-mask-source-type:auto,auto;-webkit-mask-composite:xor;-webkit-mask-source-type:auto,auto;background:linear-gradient(135deg,#f4d35e33,#ff9e441a);border-radius:16px;padding:1px;transition:opacity .4s;position:absolute;inset:0;-webkit-mask-image:linear-gradient(#fff 0 0),linear-gradient(#fff 0 0);-webkit-mask-position:0 0,0 0;-webkit-mask-size:auto,auto;-webkit-mask-repeat:repeat,repeat;-webkit-mask-clip:content-box,border-box;-webkit-mask-origin:content-box,border-box;-webkit-mask-composite:xor;mask-composite:exclude;-webkit-mask-source-type:auto,auto;mask-mode:match-source,match-source}.medication-card:hover:before{opacity:1}.med-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.med-info h3{color:var(--dark-text);letter-spacing:-.01em;font-size:1.3rem;font-family:var(--font-serif);margin-bottom:0;font-weight:700}.dosage-text{color:var(--orange);font-size:1rem;font-weight:600;font-family:var(--font-sans);margin-left:6px}.switch{width:56px;height:30px;display:inline-block;position:relative}.switch input{opacity:0;width:0;height:0}.switch-slider{cursor:pointer;background-color:var(--border);border:3px solid var(--orange-light);border-radius:18px;transition:all .3s;position:absolute;inset:0;box-shadow:inset 0 2px 4px #f4d35e4d}.switch-slider:before{content:"";background:#fff;border-radius:50%;width:22px;height:22px;transition:all .3s;position:absolute;bottom:1px;left:3px;box-shadow:0 2px 6px #ff9e444d}input:checked+.switch-slider{background:var(--lemon);border-color:var(--lemon)}input:checked+.switch-slider:before{background:var(--orange);transform:translate(24px)}.med-selector-grid{grid-template-columns:auto 1fr;align-items:start;gap:14px;margin-bottom:14px;display:grid}.selectors{flex-direction:column;gap:10px;display:flex}select{border:2px solid var(--lemon);background:var(--paper);cursor:pointer;font-size:.9rem;font-family:var(--font-serif);color:var(--dark-text);border-radius:10px;flex:1;padding:10px 14px;font-weight:600;transition:all .3s;box-shadow:0 2px 8px #f4d35e26}select:hover{border-color:var(--orange);transform:translateY(-2px);box-shadow:0 6px 16px #ff9e4440}select:focus{border-color:var(--orange);outline:none;box-shadow:0 0 0 4px #ff9e4433}.user-info{gap:10px;margin-bottom:16px;display:flex}.user-info input{border:3px solid var(--lemon);background:var(--paper);font-size:.95rem;font-family:var(--font-mono);color:var(--dark-text);border-radius:12px;flex:1;padding:12px 16px;font-weight:600;transition:all .3s}.user-info input:hover{border-color:var(--orange);transform:translateY(-2px);box-shadow:0 6px 16px #ff9e4426}.user-info input:focus{border-color:var(--orange);outline:none;box-shadow:0 0 0 4px #ff9e4433}.pill-preview{border:3px solid var(--lemon);background:var(--cream);border-radius:12px;justify-content:center;align-items:center;width:120px;height:120px;padding:8px;transition:all .3s;display:flex;overflow:hidden;box-shadow:0 2px 6px #f4d35e33,inset 0 1px 4px #f4d35e26}.pill-preview:hover{border-color:var(--orange);transform:translateY(-2px);box-shadow:0 4px 12px #ff9e4440,inset 0 1px 4px #f4d35e26}.pill-preview img{object-fit:contain;filter:contrast(1.05)saturate(.95);width:100%;height:100%}.pill-preview-placeholder{width:100%;height:100%;color:var(--orange);justify-content:center;align-items:center;display:flex}.pill-preview-placeholder span{opacity:.4;filter:grayscale(.3);font-size:3.5rem}.add-button{background:linear-gradient(135deg,var(--lemon)0%,#f4c84d 100%);width:100%;color:var(--dark-text);cursor:pointer;font-size:.95rem;font-weight:700;font-family:var(--font-sans);text-transform:uppercase;letter-spacing:.05em;border:none;border-radius:10px;padding:14px 20px;transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;box-shadow:0 2px 6px #f4d35e40,0 4px 12px #f4d35e33}.add-button:before{content:"";background:#ffffff4d;border-radius:50%;width:0;height:0;transition:width .6s,height .6s;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.add-button:hover:before{width:300px;height:300px}.add-button:hover:not(:disabled){background:linear-gradient(135deg,var(--orange)0%,#f83 100%);transform:translateY(-3px);box-shadow:0 4px 10px #ff9e444d,0 8px 20px #ff9e4440,0 0 0 4px #ff9e441a}.add-button:active:not(:disabled){transform:translateY(-1px);box-shadow:0 2px 6px #ff9e4440,0 4px 12px #ff9e4433}.add-button:disabled{background:var(--border);color:var(--dark-text);border-color:var(--orange-light);cursor:not-allowed;opacity:.4;box-shadow:none}.dose-history{background:#fff;border:2px solid #f0f0f0;border-radius:12px;padding:24px;animation:.7s ease-out .8s both fadeInUp;box-shadow:0 2px 8px #0000000a}.dose-history h2{color:var(--dark-text);font-size:1.4rem;font-family:var(--font-serif);margin-bottom:20px;padding-bottom:12px;font-weight:700;position:relative}.dose-history h2:after{content:"";background:linear-gradient(90deg,var(--lemon)0%,var(--orange)100%);border-radius:2px;width:80px;height:4px;position:absolute;bottom:0;left:0}.dose-list{list-style:none}.dose-item{background:#fff;border:1px solid #f0f0f0cc;border-radius:12px;justify-content:space-between;align-items:center;margin-bottom:12px;padding:16px 20px;transition:all .4s cubic-bezier(.4,0,.2,1);animation:.5s cubic-bezier(.34,1.56,.64,1) slideIn;display:flex;position:relative;box-shadow:0 2px 4px #00000005,0 4px 8px #00000008}@keyframes slideIn{0%{opacity:0;transform:translate(-30px)scale(.95)}to{opacity:1;transform:translate(0)scale(1)}}.dose-item:hover{border-color:var(--lemon);background:linear-gradient(135deg,#fafafa 0%,#fff 100%);transform:translate(6px);box-shadow:0 4px 8px #f4d35e1a,0 8px 16px #f4d35e14}.side-effect-item:hover{background:linear-gradient(135deg,#f8f5fa 0%,#fff 100%);border-color:#9b59b6;box-shadow:0 4px 8px #9b59b61a,0 8px 16px #9b59b614}.dose-info{font-family:var(--font-serif);color:var(--dark-text);align-items:center;gap:16px;font-weight:600;display:flex}.dose-badge{background:var(--lemon);color:var(--dark-text);letter-spacing:.05em;font-size:.85rem;font-weight:700;font-family:var(--font-mono);border:2px solid var(--lemon);border-radius:6px;padding:6px 14px;box-shadow:0 2px 4px #0000000a}.remove-btn{color:var(--orange);cursor:pointer;background:#fff;border:2px solid #f0f0f0;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:1.2rem;font-weight:700;transition:all .3s;display:flex;box-shadow:0 2px 4px #0000000a}.remove-btn:hover{background:var(--orange);color:#fff;border-color:var(--orange);transform:scale(1.1);box-shadow:0 4px 8px #00000014}.no-doses{text-align:center;color:var(--orange);font-family:var(--font-serif);padding:24px;font-size:1.15rem}.stats-grid{flex-wrap:nowrap;align-items:stretch;gap:16px;margin-bottom:22px;animation:.7s ease-out .9s both fadeInUp;display:flex}.stat-card{min-width:0;color:var(--dark-text);background:#fff;border:1px solid #f0f0f0cc;border-radius:12px;flex-direction:column;flex:1 1 0;align-items:flex-start;gap:8px;padding:12px 14px;transition:all .4s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden;box-shadow:0 2px 4px #00000005,0 4px 8px #00000008}.stat-card:hover{border-color:var(--lemon);transform:translateY(-3px)scale(1.02);box-shadow:0 4px 8px #f4d35e1a,0 8px 16px #f4d35e14,0 12px 32px #f4d35e0f}.stat-card:before{content:"";background:linear-gradient(90deg,var(--lemon),var(--orange));transform-origin:0;height:3px;transition:transform .4s cubic-bezier(.4,0,.2,1);position:absolute;top:0;left:0;right:0;transform:scaleX(0)}.stat-card:hover:before{transform:scaleX(1)}.stat-label{letter-spacing:.12em;text-transform:uppercase;color:var(--dark-text);font-size:.85rem;font-weight:800;line-height:1.2;font-family:var(--font-sans)}.stat-value{color:var(--dark-text);letter-spacing:-.02em;font-size:1.8rem;font-weight:700;font-family:var(--font-mono);align-items:baseline;gap:6px;display:inline-flex}.stat-unit{color:var(--orange);text-transform:uppercase;font-size:.9rem;font-weight:700;font-family:var(--font-sans)}.medication-status{background:#fff;border:1px solid #f0f0f0cc;border-radius:16px;margin-bottom:0;padding:12px 16px;transition:all .4s cubic-bezier(.4,0,.2,1);animation:.7s ease-out .9s both fadeInUp;box-shadow:0 2px 4px #00000005,0 4px 8px #00000008}.medication-status:hover{border-color:var(--lemon);transform:translateY(-2px);box-shadow:0 4px 8px #f4d35e1a,0 8px 16px #f4d35e14}.medication-status-content{justify-content:space-between;align-items:center;gap:16px;display:flex}.medication-status-icon{flex-shrink:0;font-size:2.5rem;line-height:1;animation:.5s ease-out scaleIn}.medication-status-text{color:var(--dark-text);font-size:1.15rem;font-weight:600;line-height:1.4;font-family:var(--font-sans);flex:1;margin:0}.medication-status-value{color:var(--orange);letter-spacing:-.02em;font-size:1.1rem;font-weight:700;font-family:var(--font-mono);flex-shrink:0;align-items:baseline;gap:6px;margin-left:16px;display:inline-flex}.medication-status-unit{color:#9ca3af;font-size:.85rem;font-weight:600;font-family:var(--font-sans)}.medication-status-progress{background-color:#f0f0f3;border-radius:3px;width:100%;height:6px;margin-top:12px;overflow:hidden}.medication-status-progress-bar{border-radius:3px;height:100%;transition:width .4s cubic-bezier(.4,0,.2,1)}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.celebration-overlay{color:#fff;font-size:1.5rem;font-weight:700;font-family:var(--font-sans);z-index:10000;pointer-events:none;opacity:0;background:linear-gradient(135deg,#ffb347 0%,#ffcc80 100%);border-radius:20px;padding:24px 40px;transition:all .3s cubic-bezier(.34,1.56,.64,1);position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)scale(0);box-shadow:0 10px 40px #ffb3474d,0 4px 12px #0000001a}.celebration-overlay-active{opacity:1;transform:translate(-50%,-50%)scale(1)}.celebration-overlay-fade{opacity:0;transform:translate(-50%,-60%)scale(.8)}.chat-toggle{background:linear-gradient(135deg,var(--orange)0%,#f83 100%);color:#fff;cursor:pointer;z-index:50;font-size:1rem;font-weight:700;font-family:var(--font-sans);text-transform:uppercase;letter-spacing:.05em;border:none;border-radius:50px;justify-content:center;align-items:center;gap:10px;padding:18px 28px;transition:all .4s cubic-bezier(.4,0,.2,1);display:inline-flex;position:fixed;bottom:36px;right:36px;box-shadow:0 4px 12px #ff9e444d,0 8px 24px #ff9e4433,0 0 #ff9e4466}@keyframes pulse-glow{0%,to{box-shadow:0 4px 12px #ff9e444d,0 8px 24px #ff9e4433,0 0 #ff9e4473}50%{box-shadow:0 4px 12px #ff9e4480,0 10px 28px #ff9e4466,0 0 0 12px #ff9e441a}}.chat-toggle:hover{background:linear-gradient(135deg,var(--lemon)0%,#f4c84d 100%);color:var(--dark-text);transform:translateY(-4px)scale(1.05);box-shadow:0 6px 16px #f4d35e66,0 12px 32px #f4d35e4d,0 0 #f4d35e00}.chat-toggle:active{transform:translateY(-2px)scale(1.02);box-shadow:0 4px 12px #ff9e444d,0 8px 24px #ff9e4433}.chat-toggle-open{background:linear-gradient(135deg,var(--lemon)0%,#f4c84d 100%);color:var(--dark-text);animation:none}.chat-toggle-nudge{background:linear-gradient(135deg,var(--orange)0%,#f83 100%);color:#fff;animation:2s ease-in-out infinite pulse-glow,.9s ease-in-out 2 chat-wiggle;box-shadow:0 8px 22px #ff9e448c,0 14px 32px #ff9e4466,0 0 0 14px #ff9e4429}@keyframes chat-wiggle{0%,to{transform:rotate(0)}15%{transform:rotate(-.8deg)}30%{transform:rotate(.8deg)}45%{transform:rotate(-.6deg)}60%{transform:rotate(.6deg)}75%{transform:rotate(-.4deg)}}.chat-popover{opacity:0;pointer-events:none;z-index:50;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff;border:1px solid #f4d35e33;border-radius:20px;flex-direction:column;gap:18px;width:420px;max-height:620px;padding:28px;transition:all .4s cubic-bezier(.34,1.56,.64,1);display:flex;position:fixed;bottom:120px;right:36px;transform:translateY(30px)scale(.9);box-shadow:0 8px 16px #0000000a,0 16px 32px #0000000f,0 24px 48px #0000000a,inset 0 0 0 1px #ffffff1a}.chat-popover:before{content:"AI Coach";background:linear-gradient(135deg,var(--orange)0%,#f83 100%);color:#fff;letter-spacing:.05em;font-size:.85rem;font-weight:700;font-family:var(--font-sans);border:none;border-radius:16px;padding:8px 24px;position:absolute;top:-16px;left:50%;transform:translate(-50%);box-shadow:0 4px 12px #ff9e444d,0 8px 20px #ff9e4433}.chat-popover.visible{opacity:1;pointer-events:auto;transform:translateY(0)scale(1)}.chat-popover-header{justify-content:space-between;align-items:flex-start;gap:14px;margin-top:12px;display:flex}.chat-popover-header h2{font-size:1.3rem;font-family:var(--font-serif);color:var(--dark-text);font-weight:700}.chat-popover-header p{color:var(--orange);font-size:.85rem;font-family:var(--font-serif)}.chat-close{cursor:pointer;width:32px;height:32px;color:var(--orange);background:#fff;border:2px solid #f0f0f0;border-radius:50%;font-size:1.2rem;font-weight:700;line-height:1;transition:all .3s;box-shadow:0 2px 4px #0000000a}.chat-close:hover{background:var(--orange);color:#fff;border-color:var(--orange);transform:scale(1.1);box-shadow:0 4px 8px #00000014}.chat-popover-body{scroll-behavior:smooth;flex-direction:column;flex:1;gap:14px;min-height:0;padding-bottom:12px;padding-right:6px;display:flex;overflow-y:auto}.chat-message{word-wrap:break-word;word-break:break-word;max-width:85%;font-size:.95rem;line-height:1.6;font-family:var(--font-sans);white-space:pre-wrap;border-radius:16px;padding:14px 18px;transition:all .3s;animation:.4s cubic-bezier(.34,1.56,.64,1) both slideInMessage;display:block;box-shadow:0 2px 6px #0000000a,0 4px 12px #00000005}@keyframes slideInMessage{0%{opacity:0;transform:translateY(10px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}.chat-message:hover{transform:translateY(-1px);box-shadow:0 3px 8px #0000000f,0 6px 16px #00000008}.chat-message.user{background:linear-gradient(135deg,var(--lemon)0%,#f4c84d 100%);color:var(--dark-text);border:none;border-bottom-right-radius:4px;align-self:flex-end;font-weight:600;box-shadow:0 2px 6px #f4d35e33,0 4px 12px #f4d35e26}.chat-message.user:hover{box-shadow:0 3px 8px #f4d35e40,0 6px 16px #f4d35e33}.chat-message.ai{color:var(--dark-text);background:linear-gradient(135deg,#fafafa 0%,#f5f5f5 100%);border:1px solid #0000000d;border-bottom-left-radius:4px;align-self:flex-start}.chat-message.ai.typing{background:linear-gradient(135deg,#fafafa 0%,#f5f5f5 100%);align-items:center;gap:6px;padding:16px 20px;display:flex}.chat-message.ai.typing span{background:var(--orange);border-radius:50%;width:8px;height:8px;animation:1.4s ease-in-out infinite typing-bounce;display:block}.chat-message.ai.typing span:first-child{animation-delay:0s}.chat-message.ai.typing span:nth-child(2){animation-delay:.2s}.chat-message.ai.typing span:nth-child(3){animation-delay:.4s}.chat-popover-content{flex-direction:column;flex:1;gap:14px;min-height:0;display:flex;overflow:hidden}.chat-input-area{align-items:center;gap:12px;padding-top:6px;display:flex}.chat-input-area input{border:2px solid var(--lemon);background:var(--paper);font-size:.95rem;font-family:var(--font-sans);color:var(--dark-text);box-sizing:border-box;border-radius:12px;flex:1;height:44px;padding:10px 16px;transition:all .3s}.chat-input-area input:focus{border-color:var(--orange);outline:none;box-shadow:0 0 0 4px #ff9e4433}.chat-input-area button{background:var(--lemon);color:var(--dark-text);border:2px solid var(--lemon);cursor:pointer;font-size:1rem;font-weight:700;font-family:var(--font-sans);min-width:unset;box-sizing:border-box;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;padding:0;transition:all .3s;display:inline-flex;box-shadow:0 2px 4px #0000000a}.chat-input-area button:hover{background:var(--orange);border-color:var(--orange);transform:translateY(-2px);box-shadow:0 4px 8px #00000014}@keyframes typing-bounce{0%,80%,to{opacity:.3;transform:translateY(0)scale(1)}40%{opacity:1;transform:translateY(-8px)scale(1.2)}}@keyframes pulse-subtle{0%,to{opacity:1;transform:scale(1)}50%{opacity:.95;transform:scale(1.01)}}.chat-message strong{color:var(--orange);font-weight:700}.chat-message p{margin:8px 0}.chat-message p:first-child{margin-top:0}.chat-message p:last-child{margin-bottom:0}.chat-message ul,.chat-message ol{margin:8px 0;padding-left:24px}.chat-message li{margin:4px 0;line-height:1.6}.chat-message table{border-collapse:collapse;background:#fff;border-radius:8px;width:100%;max-width:100%;margin:12px 0;font-size:.9rem;display:block;overflow-x:auto;box-shadow:0 2px 4px #0000000d}.chat-message thead{background:linear-gradient(135deg,var(--lemon)0%,#f4c84d 100%)}.chat-message th{text-align:left;color:var(--dark-text);border-bottom:2px solid #0000001a;padding:10px 12px;font-weight:700}.chat-message td{border-bottom:1px solid #0000000d;padding:10px 12px}.chat-message tr:last-child td{border-bottom:none}.chat-message tbody tr:hover{background:#f4d35e1a}.chat-message code{color:var(--dark-text);background:#0000000d;border-radius:4px;padding:2px 6px;font-family:Courier New,monospace;font-size:.9em}.chat-message pre{color:#f8f8f8;background:#2d2d2d;border-radius:8px;margin:12px 0;padding:12px;font-family:Courier New,monospace;font-size:.85rem;line-height:1.5;overflow-x:auto}.chat-message pre code{color:inherit;background:0 0;padding:0}.chat-message blockquote{border-left:4px solid var(--lemon);color:#000000b3;margin:12px 0;padding-left:12px;font-style:italic}.chat-message hr{border:none;border-top:2px solid #f4d35e4d;margin:12px 0}@media (max-width:900px){.container{border-radius:8px}.header{padding:18px 16px}.header h1{font-size:2rem}.main-content{padding:16px 14px 22px}.dose-controls-row,.controls-grid{grid-template-columns:1fr;gap:18px}.stats-grid{gap:12px}.stat-card{padding:10px 12px}.stat-label{font-size:.65rem}.stat-value{font-size:1.5rem}.chart-container{height:320px}.chart-title{font-size:.9rem}.date-switcher{gap:12px}.date-nav-button{width:40px;height:40px}.slider-section{margin-bottom:18px;padding:12px 18px 16px}.medication-card{padding:14px 16px}.chat-popover{width:340px;max-height:560px;padding:22px;bottom:100px;right:20px}.chat-toggle{padding:14px 22px;bottom:24px;right:20px}}@media (max-width:640px){body{padding:12px}.header{padding:16px 12px 6px}.header h1{margin-bottom:8px;font-size:1.6rem}.header-subtitle{font-size:.9rem}.header-top{justify-content:center;padding:0 40px;position:relative}.home-button{width:36px;height:36px;font-size:1.3rem;position:absolute;left:0}.header-title-group{flex:1;min-width:0}.header-profile{padding:10px 12px}.header-profile-avatar,.header-profile-initials{width:40px;height:40px}.header-profile-name{font-size:.95rem}.header-profile-email{font-size:.7rem}.main-content{padding:12px 12px 80px}.container{padding-bottom:60px}.chart-wrapper{padding:9px 7px 0}.chart-container{aspect-ratio:1;border-radius:8px;width:100%;max-width:min(100%,100vh - 400px);height:auto}.chart-title{font-size:.75rem}.chart-wrapper:before{padding:4px 14px;font-size:.85rem;top:8px}.legend-item{font-size:12px}.date-switcher{gap:8px;margin-top:16px}.date-nav-button{width:36px;height:36px;font-size:1.2rem}.date{padding:6px 12px;font-size:.95rem}.date:before{font-size:.9rem}.date-caption{padding:6px 12px;font-size:.9rem}.slider-section{margin-bottom:8px;padding:10px 16px 14px}.slider-label{margin-bottom:12px;font-size:1rem}.selectors,.user-info{flex-direction:column}.time-display{padding:6px 14px;font-size:1rem}.stats-grid{grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:16px;display:grid}.stat-card{border-radius:8px;padding:8px 10px}.stat-label{letter-spacing:.1em;font-size:.75rem}.stat-value{font-size:1.5rem}.stat-unit{font-size:.8rem}.medication-card{padding:12px 14px}.med-info h3{font-size:1.1rem}.dosage-text{font-size:.85rem}.switch{width:50px;height:26px}.switch-slider:before{width:20px;height:20px;left:2px}input:checked+.switch-slider:before{transform:translate(22px)}.med-selector-grid{gap:12px}.pill-preview{width:100px;height:100px;padding:6px}.pill-preview-placeholder span{font-size:3rem}select{padding:9px 12px;font-size:.85rem}.add-button{padding:12px 18px;font-size:.9rem}.dose-history{padding:18px 16px}.dose-history h2{margin-bottom:16px;font-size:1.2rem}.dose-item{padding:12px 14px;font-size:.9rem}.dose-badge{padding:5px 12px;font-size:.8rem}.chat-popover{width:auto;max-height:60vh;padding:18px;bottom:76px;left:12px;right:12px}.chat-toggle{justify-content:center;width:auto;min-width:0;padding:14px 20px;font-size:.9rem;bottom:16px;left:auto;right:16px}.chat-input-area{flex-flow:row;align-items:center;gap:8px}.chat-input-area input{width:auto;min-width:0;height:44px}.chat-input-area button{min-width:unset;width:44px;height:44px}}.page-wrapper{background:#fff;border:1px solid #f0f0f0;border-radius:12px;max-width:1000px;margin:0 auto;padding:40px 44px;animation:.8s ease-out both fadeInUp;position:relative;overflow:hidden;box-shadow:0 2px 12px #0000000f}.page-wrapper:before{content:"";background:var(--lemon);z-index:2;height:4px;position:absolute;top:0;left:0;right:0}.page-wrapper:after{display:none}.page-content{z-index:1;flex-direction:column;gap:32px;display:flex;position:relative}.hero-card{background:#fff;border:2px solid #f0f0f0;border-radius:12px;flex-direction:column;gap:24px;padding:28px 32px;animation:.7s ease-out .2s both fadeInUp;display:flex;box-shadow:0 2px 8px #0000000a}.hero-grid{grid-template-columns:1fr;align-items:center;gap:20px;display:grid}@media (min-width:960px){.hero-grid{grid-template-columns:1.1fr .9fr;gap:28px}}.hero-copy{flex-direction:column;gap:18px;display:flex}.hero-visual{flex-direction:column;align-self:stretch;gap:10px;display:flex}.hero-visual-frame{background:linear-gradient(135deg,#fff6eacc,#eae7ffe6);border:2px solid #f0efff;border-radius:16px;padding:12px;position:relative;overflow:hidden;box-shadow:0 14px 40px #4f3d8f1f}.hero-thumbnail{background:#fff;border-radius:10px;width:100%;height:auto;display:block;box-shadow:inset 0 1px #fff9}.hero-visual-caption{color:#333;text-align:center;font-size:.95rem}.hero-actions{flex-wrap:wrap;gap:14px;display:flex}.hero-layout{text-align:center;flex-direction:column;gap:1.5rem;display:flex}.hero-left{flex-direction:column;gap:0;display:flex}.hero-summary{background:#fafafa;border:2px dashed #e0e0e0;border-radius:8px;flex-direction:column;gap:14px;padding:20px 24px;animation:.7s ease-out .3s both fadeInUp;display:flex;box-shadow:inset 0 1px 2px #00000005}.hero-summary p{color:var(--dark-text);line-height:1.7;font-family:var(--font-serif);font-size:1.05rem}.page-heading{color:var(--dark-text);letter-spacing:-.02em;font-size:2.6rem;font-weight:700;font-family:var(--font-serif);text-shadow:4px 4px #ff9e4426;animation:.6s ease-out .1s both fadeInUp}.page-subheading{color:var(--orange);max-width:680px;font-size:1.1rem;line-height:1.7;font-family:var(--font-serif);animation:.7s ease-out .15s both fadeInUp}.button-row{flex-wrap:wrap;gap:14px;display:flex}.steps-section{flex-direction:column;gap:22px;animation:.7s ease-out .4s both fadeInUp;display:flex}.section-title{color:var(--dark-text);font-size:1.7rem;font-weight:700;font-family:var(--font-serif);padding-bottom:12px;position:relative}.section-title:after{content:"";background:linear-gradient(90deg,var(--lemon)0%,var(--orange)100%);border-radius:2px;width:100px;height:4px;position:absolute;bottom:0;left:0}.steps-list{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:22px;list-style:none;display:grid}.step-card{background:#fff;border:2px solid #f0f0f0;border-radius:12px;flex-direction:column;gap:16px;min-height:240px;padding:22px 24px;transition:all .3s cubic-bezier(.4,0,.2,1);animation:.6s ease-out both fadeInUp;display:flex;position:relative;box-shadow:0 2px 8px #0000000a}.step-card:first-child{animation-delay:.5s}.step-card:nth-child(2){animation-delay:.6s}.step-card:nth-child(3){animation-delay:.7s}.step-card:hover{border-color:var(--lemon);transform:translateY(-3px);box-shadow:0 4px 12px #00000014}.step-header{align-items:flex-start;gap:16px;display:flex}.step-header h3{color:var(--dark-text);font-size:1.2rem;font-family:var(--font-serif);margin:0;font-weight:700}.step-header p{color:var(--orange);line-height:1.6;font-family:var(--font-sans);margin-top:8px}.step-number{background:var(--lemon);width:44px;height:44px;color:var(--dark-text);border:2px solid var(--lemon);font-size:1.3rem;font-weight:700;font-family:var(--font-serif);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex;box-shadow:0 2px 4px #0000000a}.step-actions{flex-direction:column;align-items:flex-start;gap:12px;display:flex}.step-helper{color:var(--orange);font-size:.9rem;line-height:1.6;font-family:var(--font-serif)}.pill-button{background:linear-gradient(135deg,var(--lemon)0%,#f4c84d 100%);color:var(--dark-text);cursor:pointer;font-size:1rem;font-weight:700;font-family:var(--font-sans);text-transform:uppercase;letter-spacing:.05em;border:none;border-radius:12px;align-items:center;gap:12px;padding:14px 28px;text-decoration:none;transition:all .4s cubic-bezier(.4,0,.2,1);display:inline-flex;position:relative;overflow:hidden;box-shadow:0 2px 6px #f4d35e40,0 4px 12px #f4d35e33}.pill-button:after{content:"";background:linear-gradient(135deg,#0000 0%,#fff3 100%);width:100%;height:100%;transition:transform .6s;position:absolute;top:0;left:0;transform:translate(-100%)}.pill-button:hover:after{transform:translate(0)}.pill-button svg{width:22px;height:22px;transition:transform .3s}.pill-button:hover svg{transform:translate(3px)}.pill-button:hover{background:linear-gradient(135deg,var(--orange)0%,#f83 100%);transform:translateY(-3px);box-shadow:0 4px 10px #ff9e444d,0 8px 20px #ff9e4440,0 0 0 4px #ff9e441a}.pill-button:active{transform:translateY(-1px);box-shadow:0 2px 6px #ff9e4440,0 4px 12px #ff9e4433}.pill-button:disabled{opacity:.4;cursor:not-allowed;box-shadow:none;transform:none}.ghost-link{color:var(--orange);border:2px solid var(--orange);font-weight:600;font-family:var(--font-sans);background:0 0;border-radius:8px;align-items:center;gap:10px;padding:14px 22px;text-decoration:none;transition:all .3s;display:inline-flex}.ghost-link:hover{background:var(--orange);color:#fff;transform:translateY(-2px);box-shadow:0 4px 8px #00000014}.ghost-link[aria-disabled=true]{pointer-events:none;opacity:.4;color:#999;border-color:#e0e0e0}.info-tag{background:var(--lemon);color:var(--dark-text);border:2px solid var(--lemon);font-size:.85rem;font-weight:700;font-family:var(--font-mono);border-radius:12px;align-items:center;gap:8px;padding:8px 18px;display:inline-flex;box-shadow:0 2px 4px #0000000a}.section-divider{background:repeating-linear-gradient(90deg,var(--lemon)0px,var(--lemon)10px,var(--orange)10px,var(--orange)20px);opacity:.3;border-radius:2px;width:100%;height:4px}.form-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px 24px;animation:.7s ease-out .5s both fadeInUp;display:grid}.form-group{flex-direction:column;gap:10px;display:flex}.form-group label{color:var(--dark-text);font-size:.95rem;font-weight:700;font-family:var(--font-serif)}.form-group label:after{content:attr(data-required)}.form-group label:has(+input[required]):after{content:" *";color:var(--orange);font-weight:700}.form-group label:has(+select[required]):after{content:" *";color:var(--orange);font-weight:700}.form-group label:has(+textarea[required]):after{content:" *";color:var(--orange);font-weight:700}.form-group input,.form-group select,.form-group textarea{font-size:.95rem;font-family:var(--font-sans);resize:vertical;color:var(--dark-text);background:#fff;border:2px solid #f0f0f0cc;border-radius:12px;padding:14px 18px;transition:all .4s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 4px #00000005,0 4px 8px #00000005}.form-group input:hover,.form-group select:hover,.form-group textarea:hover{border-color:var(--lemon);transform:translateY(-2px);box-shadow:0 4px 8px #f4d35e1a,0 8px 16px #f4d35e14}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--orange);background:linear-gradient(135deg,#fff 0%,#fffdf7 100%);outline:none;transform:translateY(-2px);box-shadow:0 4px 12px #ff9e4426,0 8px 24px #ff9e441a,0 0 0 4px #ff9e441a}.form-actions{flex-wrap:wrap;gap:14px;margin-top:12px;animation:.7s ease-out .6s both fadeInUp;display:flex}.summary-card{background:#fff;border:2px solid #f0f0f0;border-radius:12px;flex-direction:column;gap:14px;padding:24px 28px;animation:.7s ease-out .4s both fadeInUp;display:flex;box-shadow:0 2px 8px #0000000a}.error-card{border-left:4px solid var(--orange);color:var(--dark-text);font-size:.95rem;line-height:1.6;font-family:var(--font-sans);background:#fff3e0;border-radius:8px;margin-top:24px;padding:16px 22px;box-shadow:0 2px 4px #0000000a}.profile-chip{background:#fafafa;border:2px solid #f0f0f0;border-radius:12px;align-items:center;gap:14px;margin-top:14px;padding:14px 20px;display:flex;box-shadow:0 2px 4px #0000000a}.profile-avatar{object-fit:cover;border:3px solid var(--orange);border-radius:50%;width:56px;height:56px;box-shadow:0 4px 12px #ff9e4466}.profile-initials{background:var(--lemon);width:56px;height:56px;color:var(--dark-text);border:2px solid var(--orange);font-size:1.4rem;font-weight:700;font-family:var(--font-serif);border-radius:50%;justify-content:center;align-items:center;display:inline-flex}.profile-name{color:var(--dark-text);font-weight:700;font-family:var(--font-serif);font-size:1.1rem}.profile-email{color:var(--orange);font-size:.8rem;font-family:var(--font-mono)}.profile-info{flex-direction:column;flex:1;gap:3px;display:flex}.profile-logout{color:var(--orange);border:1px solid var(--orange);white-space:nowrap;background:0 0;border-radius:6px;padding:6px 12px;font-size:.75rem;font-weight:600;transition:all .2s}.profile-logout:hover{background:var(--orange);color:#fff}.summary-card h2{color:var(--dark-text);font-size:1.4rem;font-family:var(--font-serif);margin:0;font-weight:700}.summary-list{gap:12px;margin:0;padding:0;list-style:none;display:grid}.summary-item{color:var(--dark-text);font-size:.95rem;font-family:var(--font-sans);justify-content:space-between;gap:20px;display:flex}.summary-item span:first-child{color:var(--orange);min-width:180px;font-weight:700;font-family:var(--font-serif)}.supporting-list{gap:14px;margin:0;padding:0;list-style:none;display:grid}.supporting-list li{color:var(--dark-text);font-family:var(--font-sans);align-items:flex-start;gap:14px;line-height:1.6;display:flex}.icon-circle{background:var(--lemon);border:2px solid var(--lemon);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.3rem;display:inline-flex;box-shadow:0 2px 4px #0000000a}.supporting-list svg{width:20px;height:20px;color:var(--orange);flex-shrink:0}@media (min-width:768px){.header-top,.header-actions{flex-direction:row;justify-content:space-between;align-items:center}.header-profile{min-width:0}.header-nav{justify-content:flex-end}.page-heading{font-size:3rem}.hero-layout{text-align:left;flex-direction:row;align-items:flex-start;gap:2rem}.hero-left{flex:1}.hero-summary{flex:none;max-width:360px}}@media (max-width:640px){body{padding:12px}.page-wrapper{border-radius:8px;padding:24px 18px}.hero-card{gap:18px;padding:20px 18px}.hero-grid{gap:16px}.hero-visual-frame{padding:10px}.hero-visual-caption{font-size:.9rem}.summary-item{flex-direction:column;gap:6px}.page-heading{font-size:1.8rem}.page-subheading{font-size:1rem}.section-title{font-size:1.4rem}.step-card{min-height:200px;padding:18px 16px}.step-number{width:38px;height:38px;font-size:1.1rem}.step-header h3{font-size:1.1rem}.step-header p{font-size:.9rem}.pill-button{padding:12px 20px;font-size:.9rem}.ghost-link{padding:12px 18px;font-size:.9rem}.profile-chip{flex-wrap:wrap;gap:10px;padding:12px 16px}.profile-avatar,.profile-initials{width:44px;height:44px;font-size:1.1rem}.profile-name{font-size:1rem}.profile-email{font-size:.75rem}.profile-logout{margin-left:auto;padding:5px 10px;font-size:.7rem}.hero-actions{gap:10px}.hero-summary{gap:12px;padding:16px 18px}.hero-summary p{font-size:.95rem}.info-tag{gap:6px;padding:6px 14px;font-size:.8rem}.step-helper{font-size:.85rem}}@media (max-width:480px){body{padding:10px}.header h1{font-size:1.4rem}.header-subtitle{font-size:.85rem}.date-switcher{flex-direction:row;gap:6px}.date-nav-button{width:32px;height:32px;font-size:1rem}.date{padding:5px 10px;font-size:.75rem}.date:before{font-size:.8rem}.date-caption{font-size:.7rem}.stats-grid{gap:8px}.stat-card{padding:6px 8px}.stat-label{font-size:.55rem}.stat-value{font-size:1.1rem}.stat-unit{font-size:.6rem}.medication-status{margin-bottom:0;padding:10px 12px}.medication-status-content{gap:10px}.medication-status-icon{font-size:1.8rem}.medication-status-text{font-size:.9rem}.medication-status-value{margin-left:8px;font-size:1.1rem}.medication-status-unit{font-size:.65rem}.medication-status-progress{height:5px;margin-top:10px}.celebration-overlay{border-radius:16px;padding:16px 28px;font-size:1.1rem}.chart-container{height:240px}.chart-wrapper:before{padding:3px 10px;font-size:.75rem}.med-selector-grid{grid-template-columns:auto 1fr;align-items:center;gap:12px}.pill-preview{width:120px;height:80px;padding:6px}.selectors{gap:8px;max-width:180px}select{padding:8px 10px;font-size:.85rem}.page-heading{font-size:1.6rem}.page-wrapper{padding:20px 14px}.profile-chip{gap:8px;padding:10px 12px}.profile-avatar,.profile-initials{width:40px;height:40px;font-size:1rem}.profile-name{font-size:.95rem}.profile-email{font-size:.7rem}.profile-logout{padding:4px 8px;font-size:.65rem}.hero-actions{gap:8px}.hero-summary{gap:10px;padding:14px 16px}.hero-summary p{font-size:.9rem}.info-tag{gap:5px;padding:5px 12px;font-size:.75rem}.step-helper{font-size:.8rem}}.progress-container{flex-direction:column;gap:16px;margin:32px 0;animation:.7s ease-out .3s both fadeInUp;display:flex}.progress-steps{z-index:2;justify-content:space-between;align-items:center;display:flex;position:relative}.progress-step{flex-direction:column;flex:1;align-items:center;gap:10px;display:flex;position:relative}.progress-step-circle{width:56px;height:56px;color:var(--orange);font-size:1.3rem;font-weight:700;font-family:var(--font-serif);z-index:2;background:#fff;border:2px solid #e0e0e0;border-radius:50%;justify-content:center;align-items:center;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:relative;box-shadow:0 2px 4px #0000000a}.progress-step.active .progress-step-circle{background:var(--lemon);border-color:var(--lemon);color:var(--dark-text);transform:scale(1.1);box-shadow:0 4px 8px #f4d35e33}.progress-step.completed .progress-step-circle{background:var(--orange);border-color:var(--orange);color:#fff;box-shadow:0 2px 4px #0000000a}.progress-step-label{color:var(--orange);font-size:.9rem;font-weight:600;font-family:var(--font-sans);text-align:center;transition:all .3s}.progress-step.active .progress-step-label{color:var(--dark-text);font-weight:700}.progress-step.completed .progress-step-label{color:var(--dark-text)}.progress-bar{background:#f0f0f0;border:2px solid #e0e0e0;border-radius:6px;width:100%;height:10px;overflow:hidden;box-shadow:inset 0 1px 2px #0000000a}.progress-bar-fill{background:var(--lemon);border-radius:3px;height:100%;transition:width .5s cubic-bezier(.4,0,.2,1);box-shadow:0 0 4px #f4d35e4d}.survey-step{flex-direction:column;gap:24px;animation:.5s cubic-bezier(.4,0,.2,1) slideInFromRight;display:flex}@keyframes slideInFromRight{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}.step-heading{color:var(--dark-text);font-size:2rem;font-weight:700;font-family:var(--font-serif);text-shadow:3px 3px #ff9e4426;margin:0}.step-description{color:var(--orange);font-size:1.05rem;font-family:var(--font-serif);margin:0;line-height:1.6}.summary-preview{background:#fafafa;border:2px dashed #e0e0e0;border-radius:8px;margin-top:16px;padding:24px 28px;animation:.5s ease-out .2s both fadeIn}.summary-preview h3{color:var(--dark-text);font-size:1.3rem;font-family:var(--font-serif);margin:0 0 16px;font-weight:700}.pill-button.secondary{color:var(--orange);border-color:var(--orange);background:#fff}.pill-button.secondary:hover{background:var(--orange);color:#fff;border-color:var(--orange)}.optimization-screen{z-index:9999;background:#fff;justify-content:center;align-items:center;width:100%;height:100vh;animation:.4s ease-out fadeIn;display:flex;position:fixed;top:0;left:0}.optimization-content{text-align:center;background:#fff;border:2px solid #f0f0f0;border-radius:12px;flex-direction:column;align-items:center;gap:32px;max-width:500px;padding:48px;animation:.5s cubic-bezier(.4,0,.2,1) .2s both scaleIn;display:flex;box-shadow:0 8px 24px #00000014}.optimization-spinner{justify-content:center;align-items:center;width:120px;height:120px;display:flex;position:relative}.spinner-ring{border:4px solid #0000;border-radius:50%;width:100%;height:100%;animation:2s cubic-bezier(.5,0,.5,1) infinite spin;position:absolute}.spinner-ring:first-child{border-top-color:var(--lemon);animation-duration:1.5s}.spinner-ring:nth-child(2){border-right-color:var(--orange);animation-duration:2s;animation-delay:.2s}.spinner-ring:nth-child(3){border-bottom-color:var(--lemon);animation-duration:2.5s;animation-delay:.4s}@keyframes spin{to{transform:rotate(360deg)}}.optimization-heading{color:var(--dark-text);font-size:2.2rem;font-weight:700;font-family:var(--font-serif);letter-spacing:-.01em;text-shadow:3px 3px #ff9e4426;margin:0}.optimization-message{color:var(--orange);font-size:1.2rem;font-family:var(--font-serif);min-height:32px;margin:0;line-height:1.6;animation:.5s ease-out fadeInText}@keyframes fadeInText{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.optimization-progress{justify-content:center;gap:12px;display:flex}.optimization-dots{align-items:center;gap:12px;display:flex}.optimization-dots .dot{background:var(--lemon);border:2px solid var(--lemon);border-radius:50%;width:14px;height:14px;animation:1.5s ease-in-out infinite pulse}.optimization-dots .dot:first-child{animation-delay:0s}.optimization-dots .dot:nth-child(2){animation-delay:.3s}.optimization-dots .dot:nth-child(3){animation-delay:.6s}@keyframes pulse{50%{opacity:.5}}@media (max-width:640px){.progress-step-circle{width:48px;height:48px;font-size:1.1rem}.progress-step-label{font-size:.8rem}.step-heading{font-size:1.6rem}.optimization-content{max-width:90%;padding:32px 24px}.optimization-heading{font-size:1.8rem}.optimization-message{font-size:1rem}.optimization-spinner{width:100px;height:100px}}.landing-nav-right{align-items:center;gap:16px;display:flex}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.landing-notification-bell{border:1px solid var(--border);width:36px;height:36px;color:var(--dark-text);cursor:pointer;background:#fff;border-radius:999px;justify-content:center;align-items:center;transition:all .2s;display:inline-flex}.landing-notification-bell.is-on{background:var(--orange);border-color:var(--orange);color:#fff}.landing-notification-bell:hover:not(:disabled){border-color:var(--orange);transform:translateY(-1px)}.landing-notification-bell:disabled{opacity:.6;cursor:not-allowed;transform:none}.language-selector{z-index:100;position:relative}.language-selector-button{border:1px solid var(--border);font-family:var(--font-sans);color:var(--dark-text);cursor:pointer;background:0 0;border-radius:8px;align-items:center;gap:6px;padding:6px 12px;font-size:.875rem;font-weight:500;transition:all .2s;display:flex}.language-selector-button:hover{background:var(--cream);border-color:var(--orange)}.language-selector-button:disabled{opacity:.6;cursor:not-allowed}.language-selector-current{font-weight:600}.language-selector-backdrop{z-index:99;cursor:default;background:0 0;position:fixed;inset:0}.language-selector-menu{background:var(--paper);border:2px solid var(--border);z-index:1001;border-radius:12px;min-width:160px;animation:.2s slideDown;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden;box-shadow:0 8px 24px #0000001f}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.language-selector-option{width:100%;font-family:var(--font-sans);color:var(--dark-text);text-align:left;cursor:pointer;background:0 0;border:none;justify-content:space-between;align-items:center;padding:12px 16px;font-size:.95rem;font-weight:500;transition:background .2s;display:flex}.language-selector-option:hover{background:var(--peach)}.language-selector-option-active{background:var(--orange-light);color:var(--dark-text);font-weight:600}.language-selector-option-active:hover{background:var(--orange-light)}.language-selector-option:disabled{opacity:.6;cursor:not-allowed}@media (max-width:640px){.landing-nav-right{gap:12px}.language-selector-button{padding:6px 10px;font-size:.8125rem}.language-selector-current{display:none}}.analytics-consent-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9998;background:#2d3142b3;animation:.3s ease-out fadeIn;position:fixed;inset:0}@keyframes modalSlideUp{0%{opacity:0;transform:translate(-50%,-40%)}to{opacity:1;transform:translate(-50%,-50%)}}.analytics-consent-banner{border:3px solid var(--orange);z-index:9999;background:linear-gradient(135deg,#fffdf7 0%,#fff9e6 100%);border-radius:16px;width:90%;max-width:600px;padding:32px;animation:.4s ease-out modalSlideUp;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 20px 60px #2d31424d}.analytics-consent-content{text-align:center;flex-direction:column;align-items:center;gap:24px;display:flex}.analytics-consent-text{flex-direction:column;gap:12px;display:flex}.analytics-consent-text strong{color:var(--dark-text);font-size:1.3rem;font-weight:700;font-family:var(--font-serif)}.analytics-consent-text p{color:#5c5c66;margin:0;font-size:1rem;line-height:1.6}.analytics-consent-actions{justify-content:center;gap:12px;width:100%;display:flex}.analytics-consent-button{font-family:var(--font-serif);cursor:pointer;border:2px solid #0000;border-radius:10px;padding:14px 32px;font-size:1.1rem;font-weight:600;transition:all .2s}.analytics-consent-button-accept{background:var(--orange);color:#fff;border-color:var(--orange);min-width:200px}.analytics-consent-button-accept:hover{background:#ff8a30;border-color:#ff8a30;transform:translateY(-2px);box-shadow:0 6px 20px #ff9e4466}@media (max-width:639px){.analytics-consent-banner{width:85%;padding:24px}.analytics-consent-text strong{font-size:1.15rem}.analytics-consent-text p{font-size:.95rem}.analytics-consent-button{padding:12px 24px;font-size:1rem}.analytics-consent-button-accept{min-width:160px}}@media (max-width:480px){.chat-popover{width:auto;max-height:500px;padding:20px;bottom:90px;left:12px;right:12px}.chat-toggle{padding:14px 20px;font-size:.9rem;bottom:20px;right:20px}.chat-message{max-width:90%;padding:12px 14px;font-size:.9rem}.chat-input-area{flex-direction:row;align-items:center;gap:8px}.chat-input-area input{flex:1;height:44px}.chat-input-area button{width:44px;height:44px;min-width:unset;flex-shrink:0}}@media (max-width:768px) and (min-width:481px){.chat-popover{width:360px;max-height:550px;bottom:100px;right:20px}.chat-toggle{bottom:24px;right:24px}}.sos-toggle{color:#fff;cursor:pointer;z-index:49;font-size:1.1rem;font-weight:700;font-family:var(--font-sans);text-transform:uppercase;letter-spacing:.08em;background:linear-gradient(135deg,#e74c3c 0%,#c0392b 100%);border:none;border-radius:50px;justify-content:center;align-items:center;gap:8px;min-width:80px;padding:16px 24px;transition:all .4s cubic-bezier(.4,0,.2,1);display:inline-flex;position:fixed;bottom:120px;right:36px;box-shadow:0 4px 12px #e74c3c66,0 8px 24px #e74c3c4d}.sos-icon{letter-spacing:.1em;font-size:1.2rem;font-weight:900}.sos-toggle:hover{background:linear-gradient(135deg,#c0392b 0%,#a93226 100%);transform:translateY(-4px)scale(1.08);box-shadow:0 6px 16px #e74c3c80,0 12px 32px #e74c3c66}.sos-toggle:active{transform:translateY(-2px)scale(1.04)}.sos-toggle-open{background:linear-gradient(135deg,#9b59b6 0%,#8e44ad 100%);animation:none}.sos-popover{opacity:0;pointer-events:none;z-index:49;background:#fff;border:2px solid #9b59b64d;border-radius:20px;flex-direction:column;gap:0;width:420px;max-height:520px;padding:0;transition:all .4s cubic-bezier(.34,1.56,.64,1);display:flex;position:fixed;bottom:200px;right:36px;transform:translateY(30px)scale(.9);box-shadow:0 8px 16px #0000000f,0 16px 32px #00000014,0 24px 48px #0000000f}.sos-popover.visible{opacity:1;pointer-events:all;transform:translateY(0)scale(1)}.sos-popover-header{background:linear-gradient(#9b59b60d,#0000);border-bottom:1px solid #9b59b626;justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.sos-popover-title{font-family:var(--font-serif);color:#8e44ad;margin:0;font-size:1.3rem;font-weight:700}.sos-close-button{color:#999;cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;padding:0;font-size:2rem;line-height:1;transition:all .2s;display:flex}.sos-close-button:hover{color:#8e44ad;background:#9b59b61a}.sos-popover-content{flex-direction:column;gap:16px;padding:24px;display:flex}.sos-info{background:#9b59b614;border-left:4px solid #9b59b6;border-radius:12px;gap:16px;padding:12px 16px;display:flex}.sos-info p{color:var(--dark-text);font-size:.95rem;font-family:var(--font-sans);margin:0}.sos-info strong{color:#8e44ad;font-weight:600}.sos-time,.sos-date{flex:1}.sos-textarea{width:100%;min-height:140px;font-family:var(--font-sans);resize:vertical;color:var(--dark-text);background:#fff;border:2px solid #9b59b633;border-radius:12px;padding:14px 16px;font-size:.95rem;line-height:1.6;transition:all .3s}.sos-textarea:focus{border-color:#9b59b6;outline:none;box-shadow:0 0 0 3px #9b59b61a}.sos-textarea::placeholder{color:#999}.sos-textarea:disabled{cursor:not-allowed;opacity:.7;background:#f5f5f5}.sos-actions{justify-content:flex-end;gap:12px;display:flex}.sos-cancel-button,.sos-save-button{font-size:.95rem;font-weight:600;font-family:var(--font-sans);cursor:pointer;border:none;border-radius:10px;padding:12px 24px;transition:all .3s}.sos-cancel-button{color:#666;background:0 0;border:1px solid #ddd}.sos-cancel-button:hover:not(:disabled){background:#f5f5f5;border-color:#ccc}.sos-save-button{color:#fff;background:linear-gradient(135deg,#9b59b6 0%,#8e44ad 100%);box-shadow:0 2px 8px #9b59b64d}.sos-save-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #9b59b666}.sos-save-button:disabled,.sos-cancel-button:disabled{opacity:.5;cursor:not-allowed}@media (max-width:480px){.sos-toggle{padding:14px 20px;font-size:1rem;bottom:100px;right:20px}.sos-popover{width:auto;max-height:450px;bottom:160px;left:20px;right:20px}}@media (max-width:768px) and (min-width:481px){.sos-toggle{bottom:110px;right:24px}.sos-popover{width:380px;bottom:180px;right:24px}}.slider.side-effect-mode{background:linear-gradient(90deg,#9b59b626 0%,#8e44ad26 100%)}.slider.side-effect-mode:hover{background:linear-gradient(90deg,#9b59b64d 0%,#8e44ad4d 100%)}.slider.side-effect-mode::-webkit-slider-thumb{background:linear-gradient(135deg,#9b59b6 0%,#8e44ad 100%);box-shadow:0 2px 6px #9b59b666,0 0 0 2px #9b59b61a}.slider.side-effect-mode::-webkit-slider-thumb:hover{transform:scale(1.3);box-shadow:0 3px 8px #9b59b680,0 0 0 3px #9b59b626}.slider.side-effect-mode::-moz-range-thumb{background:linear-gradient(135deg,#9b59b6 0%,#8e44ad 100%);box-shadow:0 2px 6px #9b59b666,0 0 0 2px #9b59b61a}.slider.side-effect-mode::-moz-range-thumb:hover{transform:scale(1.3);box-shadow:0 3px 8px #9b59b680,0 0 0 3px #9b59b626}.add-button.side-effect-mode{color:#fff;background:linear-gradient(135deg,#9b59b6 0%,#8e44ad 100%);border-color:#8e44ad}.add-button.side-effect-mode:hover:not(:disabled){background:linear-gradient(135deg,#8e44ad 0%,#7d3c98 100%);transform:translateY(-3px);box-shadow:0 4px 12px #9b59b666,0 1px 3px #9b59b633}.add-button.side-effect-mode:active:not(:disabled){transform:translateY(-1px);box-shadow:0 2px 6px #9b59b640,0 1px 2px #9b59b626}.add-button.side-effect-mode:disabled{color:#7d3c98;opacity:.6;background:#d1c4e9;border-color:#b39ddb}.medication-card.side-effect-mode{border-color:#9b59b640}.medication-card.side-effect-mode:hover{box-shadow:0 4px 8px #9b59b626,0 12px 24px #9b59b61f,0 20px 40px #9b59b614}.medication-card.side-effect-mode:before{background:linear-gradient(135deg,#9b59b6cc 0%,#8e44adcc 100%)}.medication-card.side-effect-mode .pill-preview{border:2px solid #9b59b6;border-radius:12px;padding:8px}.medication-card.side-effect-mode select{border-color:#9b59b6}.medication-card.side-effect-mode select:focus{border-color:#8e44ad;box-shadow:0 0 0 3px #9b59b61a}.medication-card.side-effect-mode .switch-slider{background-color:#9b59b6}.medication-card.side-effect-mode .switch input:checked+.switch-slider{background-color:#8e44ad}.medication-card.side-effect-mode .switch input:checked+.switch-slider:before{background:#fff;box-shadow:0 2px 6px #9b59b64d}.slider-section.side-effect-mode{border-color:#9b59b640}.slider-section.side-effect-mode .time-display{color:#8e44ad;border-color:#9b59b6}.slider-section.side-effect-mode .time-display:hover{background-color:#9b59b60d;border-color:#8e44ad}.dose-badge.side-effect-badge{color:#fff;background:linear-gradient(135deg,#9b59b6 0%,#8e44ad 100%);border-color:#8e44ad}.landing-wrapper{background:#fff;min-height:100vh;margin:0;padding:0}.landing-container{max-width:1200px;margin:0 auto;padding:0 40px}.landing-nav{z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:2px solid var(--lemon);background:#fffffff2;position:sticky;top:0}.landing-nav-content{justify-content:space-between;align-items:center;height:64px;display:flex}.landing-logo{color:var(--dark-text);font-size:1.125rem;font-weight:700;font-family:var(--font-sans);letter-spacing:-.01em}.landing-user-menu{align-items:center;gap:16px;display:flex}.landing-user-avatar-wrapper{align-items:center;display:flex}.landing-user-avatar{object-fit:cover;border-radius:50%;width:32px;height:32px}.landing-user-initials{background:var(--orange);color:#fff;text-transform:uppercase;width:32px;height:32px;font-size:.75rem;font-weight:600;font-family:var(--font-sans);border-radius:50%;justify-content:center;align-items:center;display:flex}.landing-nav-signout,.landing-nav-signin{color:var(--orange);cursor:pointer;font-size:.875rem;font-weight:500;font-family:var(--font-sans);background:0 0;border:none;border-radius:6px;padding:8px 16px;transition:all .2s}.landing-nav-signout:hover{background:var(--cream);color:var(--dark-text)}.landing-nav-signin{background:var(--orange);color:#fff}.landing-nav-signin:hover{background:#f83;transform:translateY(-1px)}.landing-hero{background:#fff;padding:120px 0 80px;position:relative}.landing-hero:before{content:"";background:linear-gradient(90deg,var(--lemon)0%,var(--orange)100%);z-index:1;height:4px;position:absolute;top:0;left:0;right:0}.landing-hero-content{text-align:center;flex-direction:column;align-items:center;max-width:860px;margin:0 auto;display:flex}.landing-hero-title{color:var(--dark-text);font-size:4rem;font-weight:700;font-family:var(--font-serif);letter-spacing:-.03em;margin:0 0 24px;line-height:1.1}.landing-hero-subtitle{color:#666;font-size:1.25rem;font-family:var(--font-sans);max-width:700px;margin:0 0 40px;line-height:1.6}.landing-hero-actions{flex-wrap:wrap;justify-content:center;gap:16px;display:flex}.landing-btn{font-size:1rem;font-weight:600;font-family:var(--font-sans);cursor:pointer;background:0 0;border:2px solid #0000;border-radius:10px;justify-content:center;align-items:center;padding:14px 28px;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);display:inline-flex}.landing-btn-primary{background:linear-gradient(135deg,var(--orange)0%,#f83 100%);color:#fff;border-color:var(--orange);box-shadow:0 2px 8px #ff9e4440}.landing-btn-primary:hover{background:linear-gradient(135deg,#f83 0%,#f72 100%);transform:translateY(-2px);box-shadow:0 4px 12px #ff9e444d,0 8px 20px #ff9e4433}.landing-btn-secondary{color:var(--orange);border-color:var(--border);background:#fff}.landing-btn-secondary:hover{background:var(--cream);border-color:var(--orange);transform:translateY(-2px);box-shadow:0 4px 12px #f4d35e33}.landing-preview{background:var(--paper);padding:80px 0 100px}.landing-preview-wrapper{border:2px solid var(--border);background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 4px 12px #f4d35e26,0 12px 32px #ff9e441a}.landing-preview-image{width:100%;height:auto;display:block}.landing-features{background:var(--paper);padding:100px 0 120px}.landing-section-title{color:var(--dark-text);font-size:2.5rem;font-weight:700;font-family:var(--font-serif);letter-spacing:-.02em;text-align:center;margin:0 0 60px;line-height:1.2}.landing-features-grid{grid-template-columns:repeat(3,1fr);gap:32px;max-width:1200px;margin:0 auto;display:grid}.landing-feature-card{background:#fff;border:1px solid #f4d35e4d;border-radius:16px;flex-direction:column;gap:20px;padding:36px 28px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:relative;box-shadow:0 2px 4px #00000005,0 4px 8px #00000005}.landing-feature-card:hover{border-color:var(--lemon);transform:translateY(-4px);box-shadow:0 4px 12px #f4d35e33,0 12px 24px #ff9e4426}.landing-feature-icon{background:var(--cream);border:1px solid var(--border);width:56px;height:56px;color:var(--orange);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;transition:all .3s;display:flex}.landing-feature-card:hover .landing-feature-icon{background:linear-gradient(135deg,var(--orange)0%,#f83 100%);border-color:var(--orange);color:#fff;transform:scale(1.05);box-shadow:0 4px 12px #ff9e444d}.landing-feature-title{color:var(--dark-text);font-size:1.25rem;font-weight:600;font-family:var(--font-sans);margin:0;line-height:1.3}.landing-feature-description{color:#666;font-size:1rem;font-family:var(--font-sans);margin:0;line-height:1.7}.landing-cta{background:#fff;padding:100px 0}.landing-cta-content{text-align:center;background:var(--cream);border:2px solid var(--border);border-radius:16px;flex-direction:column;align-items:center;max-width:700px;margin:0 auto;padding:60px 48px;display:flex;box-shadow:0 4px 12px #f4d35e26,0 12px 24px #ff9e4414}.landing-cta-title{color:var(--dark-text);font-size:2.25rem;font-weight:700;font-family:var(--font-serif);letter-spacing:-.02em;margin:0 0 16px;line-height:1.2}.landing-cta-subtitle{color:#666;font-size:1.0625rem;font-family:var(--font-sans);margin:0 0 32px;line-height:1.6}.landing-footer{background:var(--paper);border-top:2px solid var(--lemon);padding:40px 0}.landing-footer-text{text-align:center;color:#888;font-size:.875rem;font-family:var(--font-sans);margin:0;line-height:1.5}@media (max-width:1024px){.landing-features-grid{grid-template-columns:1fr;gap:24px;max-width:600px}}@media (max-width:768px){.landing-container{padding:0 24px}.landing-hero{padding:80px 0 60px}.landing-hero-title{font-size:2.75rem}.landing-hero-subtitle{font-size:1.125rem}.landing-preview{padding:60px 0 80px}.landing-features{padding:80px 0}.landing-features-grid{gap:20px}.landing-feature-card{padding:28px 24px}.landing-cta{padding:80px 0}.landing-section-title,.landing-cta-title{font-size:2rem}.landing-hero-actions{flex-direction:column;width:100%}.landing-btn{width:100%}}@media (max-width:480px){.landing-container{padding:0 20px}.landing-hero-title{font-size:2.25rem}.landing-hero-subtitle{font-size:1rem}.landing-section-title,.landing-cta-title{font-size:1.75rem}.landing-hero{padding:60px 0 40px}.landing-preview{padding:40px 0 60px}.landing-features,.landing-how-it-works,.landing-cta{padding:60px 0}.landing-logo{font-size:1rem}.landing-nav-content{height:56px}}@property --tw-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}
