@import "https://fonts.googleapis.com/css2?family=Onest:wght@300;400;500;600;700;800&display=swap";@layer components;@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-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-leading:initial;--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-outline-style:solid;--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: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;--color-red-50:oklch(97.1% .013 17.38);--color-red-200:oklch(88.5% .062 18.334);--color-red-600:oklch(57.7% .245 27.325);--color-red-700:oklch(50.5% .213 27.518);--color-amber-50:oklch(98.7% .022 95.277);--color-amber-100:oklch(96.2% .059 95.617);--color-amber-300:oklch(87.9% .169 91.605);--color-amber-900:oklch(41.4% .112 45.904);--color-green-50:oklch(98.2% .018 155.826);--color-green-200:oklch(92.5% .084 155.995);--color-green-600:oklch(62.7% .194 149.214);--color-green-700:oklch(52.7% .154 150.069);--color-blue-50:oklch(97% .014 254.604);--color-blue-400:oklch(70.7% .165 254.624);--color-blue-500:oklch(62.3% .214 259.815);--color-blue-600:oklch(54.6% .245 262.881);--color-blue-700:oklch(48.8% .243 264.376);--color-gray-50:oklch(98.5% .002 247.839);--color-gray-100:oklch(96.7% .003 264.542);--color-gray-200:oklch(92.8% .006 264.531);--color-gray-400:oklch(70.7% .022 261.325);--color-gray-500:oklch(55.1% .027 264.364);--color-gray-600:oklch(44.6% .03 256.802);--color-gray-700:oklch(37.3% .034 259.733);--color-gray-900:oklch(21% .034 264.665);--color-white:#fff;--spacing:.25rem;--container-sm:24rem;--container-6xl:72rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--text-base:1rem;--text-base--line-height:calc(1.5 / 1);--text-lg:1.125rem;--text-lg--line-height:calc(1.75 / 1.125);--text-xl:1.25rem;--text-xl--line-height:calc(1.75 / 1.25);--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--leading-relaxed:1.625;--radius-sm:.25rem;--radius-lg:.5rem;--radius-xl:.75rem;--radius-2xl:1rem;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--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;-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 utilities{.sticky{position:sticky}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.top-0{top:calc(var(--spacing) * 0)}.top-20{top:calc(var(--spacing) * 20)}.z-10{z-index:10}.mx-auto{margin-inline:auto}.mt-0\.5{margin-top:calc(var(--spacing) * .5)}.mt-1{margin-top:calc(var(--spacing) * 1)}.mt-2{margin-top:calc(var(--spacing) * 2)}.mt-4{margin-top:calc(var(--spacing) * 4)}.mt-10{margin-top:calc(var(--spacing) * 10)}.mt-16{margin-top:calc(var(--spacing) * 16)}.mt-20{margin-top:calc(var(--spacing) * 20)}.mb-4{margin-bottom:calc(var(--spacing) * 4)}.ml-2{margin-left:calc(var(--spacing) * 2)}.\!block{display:block!important}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.h-7{height:calc(var(--spacing) * 7)}.h-10{height:calc(var(--spacing) * 10)}.h-12{height:calc(var(--spacing) * 12)}.h-14{height:calc(var(--spacing) * 14)}.min-h-screen{min-height:100vh}.w-7{width:calc(var(--spacing) * 7)}.w-12{width:calc(var(--spacing) * 12)}.w-\[8\.4rem\]{width:8.4rem}.w-full{width:100%}.max-w-6xl{max-width:var(--container-6xl)}.max-w-sm{max-width:var(--container-sm)}.min-w-0{min-width:calc(var(--spacing) * 0)}.flex-1{flex:1}.flex-shrink-0{flex-shrink:0}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.resize-none{resize:none}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.flex-col{flex-direction:column}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-1{gap:calc(var(--spacing) * 1)}.gap-1\.5{gap:calc(var(--spacing) * 1.5)}.gap-2{gap:calc(var(--spacing) * 2)}.gap-3{gap:calc(var(--spacing) * 3)}.gap-4{gap:calc(var(--spacing) * 4)}.gap-6{gap:calc(var(--spacing) * 6)}.rounded-2xl{border-radius:var(--radius-2xl)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-xl{border-radius:var(--radius-xl)}.border{border-style:var(--tw-border-style);border-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-amber-300{border-color:var(--color-amber-300)}.border-blue-400{border-color:var(--color-blue-400)}.border-gray-200{border-color:var(--color-gray-200)}.border-green-200{border-color:var(--color-green-200)}.border-red-200{border-color:var(--color-red-200)}.bg-amber-50{background-color:var(--color-amber-50)}.bg-blue-50{background-color:var(--color-blue-50)}.bg-blue-600{background-color:var(--color-blue-600)}.bg-gray-50{background-color:var(--color-gray-50)}.bg-green-50{background-color:var(--color-green-50)}.bg-green-600{background-color:var(--color-green-600)}.bg-red-50{background-color:var(--color-red-50)}.bg-white{background-color:var(--color-white)}.p-1{padding:calc(var(--spacing) * 1)}.p-2{padding:calc(var(--spacing) * 2)}.p-3{padding:calc(var(--spacing) * 3)}.p-4{padding:calc(var(--spacing) * 4)}.p-8{padding:calc(var(--spacing) * 8)}.px-2{padding-inline:calc(var(--spacing) * 2)}.px-3{padding-inline:calc(var(--spacing) * 3)}.px-4{padding-inline:calc(var(--spacing) * 4)}.py-1\.5{padding-block:calc(var(--spacing) * 1.5)}.py-2{padding-block:calc(var(--spacing) * 2)}.py-2\.5{padding-block:calc(var(--spacing) * 2.5)}.py-3{padding-block:calc(var(--spacing) * 3)}.py-6{padding-block:calc(var(--spacing) * 6)}.py-12{padding-block:calc(var(--spacing) * 12)}.text-center{text-align:center}.text-left{text-align:left}.font-mono{font-family:var(--font-mono)}.font-sans{font-family:var(--font-sans)}.text-base{font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height))}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.leading-relaxed{--tw-leading:var(--leading-relaxed);line-height:var(--leading-relaxed)}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.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)}.whitespace-pre-wrap{white-space:pre-wrap}.text-amber-900{color:var(--color-amber-900)}.text-blue-700{color:var(--color-blue-700)}.text-gray-400{color:var(--color-gray-400)}.text-gray-500{color:var(--color-gray-500)}.text-gray-600{color:var(--color-gray-600)}.text-gray-700{color:var(--color-gray-700)}.text-gray-900{color:var(--color-gray-900)}.text-green-700{color:var(--color-green-700)}.text-red-600{color:var(--color-red-600)}.text-red-700{color:var(--color-red-700)}.text-white{color:var(--color-white)}.shadow-sm{--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)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.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-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))}@media (hover:hover){.hover\:bg-amber-100:hover{background-color:var(--color-amber-100)}.hover\:bg-blue-700:hover{background-color:var(--color-blue-700)}.hover\:bg-gray-50:hover{background-color:var(--color-gray-50)}.hover\:bg-gray-100:hover{background-color:var(--color-gray-100)}.hover\:bg-green-700:hover{background-color:var(--color-green-700)}.hover\:text-gray-700:hover{color:var(--color-gray-700)}.hover\:text-gray-900:hover{color:var(--color-gray-900)}}.focus\:border-blue-400:focus{border-color:var(--color-blue-400)}.focus\:border-blue-500:focus{border-color:var(--color-blue-500)}.focus\:bg-white:focus{background-color:var(--color-white)}.focus\:ring-1:focus{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + 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-blue-500:focus{--tw-ring-color:var(--color-blue-500)}.focus\:outline-none:focus{--tw-outline-style:none;outline-style:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}@media (width>=40rem){.sm\:inline{display:inline}.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:px-6{padding-inline:calc(var(--spacing) * 6)}}@media (width>=48rem){.md\:flex{display:flex}.md\:hidden{display:none}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-\[13rem_1fr\]{grid-template-columns:13rem 1fr}}}:root{--bg:#f5f4f0;--surface:#fff;--surface2:#f0efe9;--primary:#1b4f72;--primary-light:#2e86c1;--accent:#27ae60;--accent2:#e8a020;--text:#1a1a1a;--text2:#5a5a5a;--text3:#9a9a9a;--border:#e5e4e0;--danger:#c0392b;--radius:16px;--radius-sm:10px;--shadow:0 2px 12px #00000014}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body{background:var(--bg);min-height:100%;color:var(--text);-webkit-font-smoothing:antialiased;margin:0;padding:0;font-family:Onest,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}body{justify-content:center;align-items:flex-start;min-height:100svh;display:flex}button,input,textarea{font:inherit}button{color:inherit}#root{justify-content:center;width:100%;min-height:100svh;display:flex}.phone-shell{background:var(--bg);flex-direction:column;width:100%;max-width:420px;min-height:100svh;animation:.22s fadeIn;display:flex;position:relative;overflow:hidden}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.header{background:var(--surface);border-bottom:1px solid var(--border);z-index:10;padding:28px 20px 12px;position:sticky;top:0}.header-row{justify-content:space-between;align-items:center;gap:12px;display:flex}.header-title{color:var(--text);-webkit-user-select:none;user-select:none;font-size:17px;font-weight:600;line-height:1.25}.header-meta{color:var(--text3);flex-shrink:0;font-size:13px}.header-spacer{flex-shrink:0;width:60px;min-height:1px}.header-back{color:var(--primary-light);cursor:pointer;background:0 0;border:0;flex-shrink:0;align-items:center;gap:6px;padding:4px 0;font-size:15px;font-weight:500;line-height:1.2;display:flex}.header-back svg{width:18px;height:18px}.scroll-area{-webkit-overflow-scrolling:touch;flex:1;padding:16px 16px 100px;overflow-y:auto}.bottom-nav{background:var(--surface);border-top:1px solid var(--border);z-index:100;justify-content:center;gap:4px;width:100%;max-width:420px;padding:8px 8px 20px;display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%)}.nav-item{cursor:pointer;background:0 0;border:0;border-radius:10px;flex-direction:column;align-items:center;gap:3px;padding:4px 10px;transition:transform .15s,background .15s;display:flex}.nav-item:active{transform:scale(.96)}.nav-item svg{width:24px;height:24px}.nav-item span{color:var(--text3);font-size:10px;font-weight:500}.nav-item.active span{color:var(--primary)}.nav-item.active svg path,.nav-item.active svg circle,.nav-item.active svg rect{fill:var(--primary)}.nav-item svg path,.nav-item svg circle,.nav-item svg rect{fill:var(--text3);transition:fill .15s}.card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:12px;padding:16px}.card-sm{background:var(--surface);border-radius:var(--radius-sm);margin-bottom:10px;padding:14px}.hero-card{background:linear-gradient(135deg, var(--primary) 0%, var(--primary-light) 100%);border-radius:var(--radius);color:#fff;margin-bottom:16px;padding:14px 16px;position:relative;overflow:hidden}.hero-card:after,.hero-card:before{content:"";background:#ffffff14;border-radius:50%;position:absolute}.hero-card:after{width:120px;height:120px;top:-20px;right:-20px}.hero-card:before{background:#ffffff0f;width:80px;height:80px;bottom:-30px;right:30px}.hero-main-row{align-items:center;gap:8px;margin-bottom:10px;display:flex}.hero-name{font-size:15px;font-weight:600}.hero-badge{background:#ffffff2e;border-radius:20px;align-items:center;gap:4px;padding:3px 8px;font-size:11px;display:inline-flex}.hero-points{margin-left:auto;font-size:26px;font-weight:700;line-height:1}.hero-progress-bar{background:#ffffff40;border-radius:3px;height:5px;margin-bottom:5px;overflow:hidden}.hero-progress-fill{background:#ffffffe6;border-radius:3px;height:100%;transition:width .4s}.hero-next{opacity:.7;font-size:11px}.section-label{color:var(--text3);text-transform:uppercase;letter-spacing:.08em;margin:20px 0 10px;font-size:12px;font-weight:600}.actions-grid{grid-template-columns:1fr 1fr;gap:10px;margin-bottom:12px;display:grid}.action-btn{background:var(--surface);border-radius:var(--radius);cursor:pointer;box-shadow:var(--shadow);text-align:left;border:none;flex-direction:column;align-items:flex-start;gap:8px;min-height:116px;padding:16px 14px;transition:transform .12s,box-shadow .12s;display:flex}.action-btn:active{transform:scale(.97);box-shadow:0 1px 6px #00000014}.action-btn .icon{border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.action-btn .icon svg{width:20px;height:20px}.action-btn .icon svg path,.action-btn .icon svg rect,.action-btn .icon svg circle{fill:#fff}.action-btn span{color:var(--text);font-size:13px;font-weight:500;line-height:1.3}.icon-blue{background:var(--primary)}.icon-green{background:var(--accent)}.icon-orange{background:var(--accent2)}.icon-teal{background:#16a085}.activity-list{padding:4px 16px}.activity-item{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:12px 0;display:flex}.activity-item:last-child{border-bottom:none}.activity-dot{background:var(--surface2);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:16px;display:flex}.activity-text{flex:1;min-width:0}.activity-name{font-size:13px;font-weight:500}.activity-time{color:var(--text3);margin-top:2px;font-size:11px}.activity-pts{color:var(--accent);font-size:13px;font-weight:600}.event-list{flex-direction:column;gap:10px;display:flex}.event-row{align-items:center;gap:10px;display:flex}.event-date{background:var(--surface2);text-align:center;border-radius:8px;min-width:46px;padding:6px 10px}.event-date-day{color:var(--primary);font-size:18px;font-weight:700}.event-date-month{color:var(--text3);font-size:10px}.event-title{font-size:14px;font-weight:600}.event-subtitle{color:var(--text3);font-size:12px}.material-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);cursor:pointer;text-align:left;border:0;flex-direction:column;gap:8px;width:100%;margin-bottom:12px;padding:16px;transition:transform .12s;display:flex}.material-card:active{transform:scale(.98)}.material-tag{border-radius:20px;align-items:center;gap:4px;width:fit-content;padding:3px 8px;font-size:11px;font-weight:600;display:inline-flex}.tag-pdf{color:#c0392b;background:#fde8e8}.tag-video{color:var(--primary);background:#e8f4fd}.tag-text{color:var(--accent);background:#e8f8ee}.material-title{font-size:15px;font-weight:600;line-height:1.35}.material-desc{color:var(--text2);font-size:13px;line-height:1.45}.material-footer{justify-content:space-between;align-items:center;gap:10px;display:flex}.material-pts{color:var(--accent);font-size:12px;font-weight:600}.material-date,.material-viewed{color:var(--text3);font-size:11px}.material-viewed{align-items:center;gap:4px;display:flex}.material-hero{border-radius:var(--radius);color:#fff;background:linear-gradient(135deg,#1b4f72,#2980b9);margin-bottom:16px;padding:24px 20px}.material-hero-tag{opacity:.75;text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px;font-size:11px}.material-hero-title{font-size:19px;font-weight:700;line-height:1.35}.material-body{color:var(--text2);margin-bottom:20px;font-size:14px;line-height:1.65}.filter-tabs{scrollbar-width:none;gap:8px;margin-bottom:16px;padding-bottom:4px;display:flex;overflow-x:auto}.filter-tabs::-webkit-scrollbar{display:none}.filter-tab{white-space:nowrap;cursor:pointer;border:1.5px solid var(--border);background:var(--surface);color:var(--text2);border-radius:20px;flex-shrink:0;padding:7px 14px;font-size:13px;font-weight:500;transition:all .15s}.filter-tab.active{background:var(--primary);color:#fff;border-color:var(--primary)}.quiz-progress{background:var(--border);border-radius:2px;height:4px;margin:0 16px 20px;overflow:hidden}.quiz-progress-fill{background:var(--primary);border-radius:2px;height:100%;transition:width .4s}.quiz-step{color:var(--text3);margin-bottom:6px;font-size:12px}.quiz-question{margin-bottom:24px;font-size:18px;font-weight:600;line-height:1.4}.quiz-options{flex-direction:column;gap:10px;display:flex}.quiz-option{background:var(--surface);border-radius:var(--radius-sm);border:2px solid var(--border);cursor:pointer;text-align:left;color:var(--text);width:100%;padding:14px 16px;font-size:15px;transition:all .15s}.quiz-option:active,.quiz-option.selected{border-color:var(--primary);background:#ebf5fb}.scale-wrap{margin-bottom:20px}.scale-row{flex-wrap:wrap;justify-content:center;gap:6px;display:flex}.scale-btn{border:2px solid var(--border);background:var(--surface);cursor:pointer;width:48px;height:48px;color:var(--text);border-radius:50%;justify-content:center;align-items:center;font-size:16px;font-weight:600;transition:all .15s;display:flex}.scale-btn:active,.scale-btn.selected{border-color:var(--primary);background:var(--primary);color:#fff}.scale-labels{color:var(--text3);justify-content:space-between;margin-top:6px;padding:0 4px;font-size:11px;display:flex}.open-text-wrap{flex-direction:column;gap:6px;display:flex}.quiz-textarea{border:2px solid var(--border);border-radius:var(--radius-sm);resize:none;width:100%;height:100px;color:var(--text);background:var(--surface);outline:none;padding:14px;font-size:15px}.quiz-textarea:focus{border-color:var(--primary)}.textarea-counter{color:var(--text3);text-align:right;font-size:11px}.codeword-icon{background:linear-gradient(135deg, var(--primary), var(--primary-light));border-radius:20px;justify-content:center;align-items:center;width:72px;height:72px;margin:0 auto 20px;display:flex}.codeword-icon svg{width:36px;height:36px}.codeword-icon svg path{fill:#fff}.codeword-title{text-align:center;margin-bottom:6px;font-size:20px;font-weight:700}.codeword-subtitle{color:var(--text2);text-align:center;margin-bottom:28px;font-size:14px;line-height:1.45}.input-wrap{margin-bottom:16px}.input-label{color:var(--text3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px;font-size:12px;font-weight:600}.code-input{border:2px solid var(--border);border-radius:var(--radius-sm);text-align:center;letter-spacing:.15em;text-transform:uppercase;width:100%;color:var(--text);background:var(--surface);outline:none;padding:16px;font-size:22px;font-weight:700;transition:border-color .15s}.code-input:focus{border-color:var(--primary)}.code-input.error{border-color:var(--danger);animation:.3s shake}.code-input.success{border-color:var(--accent)}.input-error{color:var(--danger);margin-top:6px;font-size:12px}.codeword-content{padding-top:32px}.btn{border-radius:var(--radius-sm);cursor:pointer;border:none;width:auto;min-height:52px;padding:16px;font-size:16px;font-weight:600;transition:all .15s}.btn:active:not(:disabled){transform:scale(.98)}.btn:disabled{cursor:not-allowed;transform:none}.btn-primary{background:var(--primary);color:#fff}.btn-primary:disabled{background:var(--border);color:var(--text3)}.btn-outline{color:var(--primary);border:2px solid var(--primary);background:0 0}.btn-success{background:var(--accent);color:#fff}.btn-ghost{color:var(--primary);background:0 0}.success-wrap{text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:calc(100svh - 116px);padding:40px 24px;display:flex}.success-circle{background:linear-gradient(135deg, var(--accent), #2ecc71);border-radius:50%;justify-content:center;align-items:center;width:88px;height:88px;margin-bottom:24px;animation:.35s cubic-bezier(.34,1.56,.64,1) popIn;display:flex}@keyframes popIn{0%{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}.success-circle svg{width:40px;height:40px}.success-circle svg path{fill:#fff}.success-pts{color:var(--accent);font-size:48px;font-weight:700;animation:.35s cubic-bezier(.34,1.56,.64,1) .1s backwards popIn}.success-pts-label{color:var(--text3);margin-bottom:12px;font-size:14px}.success-title{margin-bottom:8px;font-size:22px;font-weight:700}.success-sub{color:var(--text2);margin-bottom:32px;font-size:14px;line-height:1.5}.level-badge{border-radius:var(--radius);color:#fff;background:linear-gradient(135deg,#1b4f72,#2e86c1);align-items:center;gap:12px;margin-bottom:16px;padding:16px;display:flex}.level-icon{font-size:32px}.level-name{font-size:17px;font-weight:700}.level-sub{opacity:.75;font-size:12px}.progress-bar-wrap{margin-bottom:16px}.progress-label{color:var(--text3);justify-content:space-between;margin-bottom:6px;font-size:12px;display:flex}.progress-bar{background:var(--surface2);border-radius:4px;height:8px;overflow:hidden}.progress-fill{background:linear-gradient(90deg, var(--primary), var(--primary-light));border-radius:4px;height:100%}.stat-row{gap:10px;margin-bottom:16px;display:flex}.stat-box{background:var(--surface);border-radius:var(--radius-sm);text-align:center;box-shadow:var(--shadow);flex:1;padding:14px 8px}.stat-box .val{color:var(--primary);font-size:24px;font-weight:700}.stat-box .lbl{color:var(--text3);margin-top:2px;font-size:11px}.achievement-grid{flex-wrap:wrap;gap:10px;display:flex}.achievement{text-align:center;flex:1;min-width:70px}.achievement.locked{opacity:.3}.achievement-icon{font-size:28px}.achievement-label{color:var(--text2);margin-top:4px;font-size:11px}.lb-item{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:12px 0;display:flex}.lb-item:last-child{border-bottom:none}.lb-rank{width:28px;color:var(--text3);text-align:center;flex-shrink:0;font-size:14px;font-weight:700}.lb-rank.gold{color:#f1c40f}.lb-rank.silver{color:#95a5a6}.lb-rank.bronze{color:#ca6f1e}.lb-avatar{background:var(--surface2);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:16px;display:flex}.lb-info{flex:1;min-width:0}.lb-name{font-size:14px;font-weight:600}.lb-city{color:var(--text3);font-size:11px}.lb-pts{color:var(--primary);font-size:15px;font-weight:700}.lb-me{border-radius:var(--radius-sm);border:2px solid var(--primary-light);background:#ebf5fb;margin:-12px 0 0;padding:12px}.lb-me .lb-item{border-bottom:none;padding:0}.leaderboard-gap{text-align:center;color:var(--text3);margin:8px 0 4px;font-size:12px}.leaderboard-you{color:var(--primary-light);margin-bottom:8px;font-size:11px;font-weight:600}.current-rank{color:var(--primary);font-weight:800}.onboard-screen{text-align:center;background:#fff;flex-direction:column;justify-content:flex-end;align-items:center;min-height:100svh;padding:40px 24px;display:flex}.onboard-visual{flex:1;justify-content:center;align-items:center;width:100%;display:flex}.onboard-circle{background:linear-gradient(135deg, var(--primary), var(--primary-light));border-radius:50%;justify-content:center;align-items:center;width:180px;height:180px;display:flex;position:relative}.onboard-circle:before{content:"";border:2px dashed #1b4f7233;border-radius:50%;position:absolute;inset:-20px}.onboard-circle span{font-size:64px}.onboard-brand{color:var(--primary-light);letter-spacing:.08em;margin-bottom:8px;font-size:13px;font-weight:600}.onboard-title{margin-bottom:12px;font-size:26px;font-weight:700;line-height:1.25}.onboard-sub{color:var(--text2);margin-bottom:32px;font-size:15px;line-height:1.55}.onboard-meta{color:var(--text3);margin-top:12px;font-size:12px;line-height:1.5}.pwa-banner{background:var(--surface);border-radius:var(--radius);border:1.5px solid var(--border);align-items:center;gap:12px;margin-bottom:12px;padding:14px 16px;display:flex}.pwa-icon{flex-shrink:0;font-size:28px}.pwa-text{color:var(--text2);flex:1;font-size:13px;line-height:1.4}.pwa-text strong{color:var(--text);font-size:14px;display:block}.pwa-close{color:var(--text3);cursor:pointer;background:0 0;border:0;flex-shrink:0;padding:4px;font-size:18px}.chip-list{flex-wrap:wrap;margin-bottom:16px;display:flex}.chip{background:var(--surface2);color:var(--text2);border-radius:20px;align-items:center;gap:4px;margin-bottom:6px;margin-right:6px;padding:4px 10px;font-size:12px;font-weight:500;display:inline-flex}.disclaimer{background:var(--surface2);border-radius:var(--radius-sm);color:var(--text3);margin-top:12px;padding:12px 14px;font-size:11px;line-height:1.55}.confirm-content{padding-top:24px}.confirm-intro{text-align:center;margin-bottom:28px}.confirm-icon{margin-bottom:12px;font-size:40px}.confirm-title{margin-bottom:8px;font-size:18px;font-weight:700}.confirm-subtitle{color:var(--text2);font-size:14px;line-height:1.5}.quiz-content{flex-direction:column;justify-content:space-between;gap:24px;padding-top:8px;display:flex}.quiz-actions{flex-direction:column;gap:10px;display:flex}.center-state{text-align:center;min-height:320px;color:var(--text3);flex:1;justify-content:center;align-items:center;font-size:14px;display:flex}.error-text{color:var(--danger)}.about-text{color:var(--text2);flex-direction:column;gap:16px;font-size:14px;line-height:1.65;display:flex}.surface-note{background:var(--surface2);border-radius:var(--radius-sm);padding:14px}.mt-8{margin-top:8px}.mt-10{margin-top:10px}.mt-16{margin-top:16px}.mt-20{margin-top:20px}.mb-12{margin-bottom:12px}.w-full{width:100%}.action-btn-icon{font-size:24px;line-height:1}.action-btn-pts{color:var(--accent);margin-top:auto;font-size:11px;font-weight:600}.action-btn--done{opacity:.55}.schedule-list{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:12px;overflow:hidden}.schedule-item{border:none;border-bottom:1px solid var(--border);text-align:left;cursor:pointer;background:0 0;align-items:center;gap:14px;width:100%;padding:14px 16px;transition:background .12s;display:flex}.schedule-item:last-child{border-bottom:none}.schedule-item:active{background:var(--surface2)}.schedule-item--done .schedule-title{color:var(--text3)}.schedule-time{color:var(--primary);letter-spacing:-.01em;flex-shrink:0;min-width:46px;font-size:15px;font-weight:700}.schedule-body{flex:1;min-width:0}.schedule-title{color:var(--text);font-size:14px;font-weight:600;line-height:1.3}.schedule-desc{color:var(--text3);white-space:nowrap;text-overflow:ellipsis;margin-top:3px;font-size:12px;line-height:1.4;overflow:hidden}.schedule-pts{color:var(--accent);white-space:nowrap;flex-shrink:0;font-size:12px;font-weight:600}.schedule-item--done .schedule-pts{color:var(--text3)}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-8px)}40%{transform:translate(8px)}60%{transform:translate(-6px)}80%{transform:translate(6px)}}@media (width>=680px){body{padding:24px 0}.phone-shell{border-radius:24px;min-height:min(100svh,900px);box-shadow:0 24px 70px #1b4f7224}.bottom-nav{border-radius:0 0 24px 24px}}@media (width<=360px){.header{padding-left:16px;padding-right:16px}.nav-item{padding-left:6px;padding-right:6px}.action-btn{min-height:124px}}.ev-list{flex-direction:column;gap:10px;display:flex}.ev-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);padding:14px 16px}.ev-card--active{border-color:var(--primary);background:linear-gradient(135deg, var(--primary), white)}@supports (color:color-mix(in lab, red, red)){.ev-card--active{background:linear-gradient(135deg, color-mix(in srgb, var(--primary) 6%, white), white)}}.ev-card-top{justify-content:space-between;align-items:center;gap:8px;margin-bottom:4px;display:flex}.ev-date{color:var(--text3);font-size:12px;font-weight:500}.ev-status{border-radius:20px;padding:2px 8px;font-size:11px;font-weight:600}.ev-status--active{color:#15803d;background:#dcfce7}.ev-status--past{color:#94a3b8;background:#f1f5f9}.ev-status--upcoming{color:#3b82f6;background:#eff6ff}.ev-name{color:var(--text);margin-bottom:4px;font-size:15px;font-weight:600}.ev-location{color:var(--text3);font-size:12px}.schedule-date-badge{color:var(--text3);text-transform:uppercase;letter-spacing:.04em;margin-bottom:16px;font-size:13px;font-weight:600}.schedule-full-list{flex-direction:column;gap:0;display:flex}.schedule-full-item{text-align:left;cursor:pointer;background:0 0;border:none;grid-template-columns:46px 24px 1fr;align-items:stretch;gap:0 10px;width:100%;padding:0 0 20px;display:grid}.schedule-full-item:disabled{cursor:default}.sfi-time{color:var(--primary);text-align:right;padding-top:2px;font-size:13px;font-weight:700;line-height:1.2}.sfi-line{flex-direction:column;align-items:center;gap:0;display:flex}.sfi-dot{background:var(--primary);z-index:1;border-radius:50%;flex-shrink:0;width:10px;height:10px;margin-top:4px;position:relative}.schedule-full-item--done .sfi-dot{background:var(--success,#27ae60)}.schedule-full-item--passive .sfi-dot{background:var(--text3)}.sfi-line:after{content:"";background:var(--border);flex:1;width:2px;margin-top:4px}.schedule-full-item:last-child .sfi-line:after{display:none}.sfi-body{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:4px;padding:12px 14px;transition:background .12s}.schedule-full-item:not(:disabled):active .sfi-body{background:var(--surface2)}.sfi-type{text-transform:uppercase;letter-spacing:.05em;color:var(--primary);margin-bottom:3px;font-size:11px;font-weight:600}.schedule-full-item--passive .sfi-type{color:var(--text3)}.sfi-title{color:var(--text);margin-bottom:5px;font-size:14px;font-weight:600;line-height:1.35}.sfi-desc{color:var(--text3);margin-bottom:8px;font-size:12px;line-height:1.45}.sfi-footer{align-items:center;gap:6px;display:flex}.sfi-icon{font-size:14px;line-height:1}.sfi-pts{color:var(--accent);font-size:12px;font-weight:600}.sfi-pts--done{color:var(--success,#27ae60)}.schedule-full-item--done .sfi-body{opacity:.7}.task-list{flex-direction:column;gap:10px;margin-bottom:12px;display:flex}.task-item{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);text-align:left;cursor:pointer;border:none;align-items:center;gap:12px;width:100%;padding:11px 14px;transition:background .12s;display:flex}.task-item:active{background:var(--surface2)}.task-item--done{opacity:.6}.task-icon{flex-shrink:0;font-size:20px;line-height:1}.task-body{flex:1;min-width:0}.task-title{color:var(--text);font-size:14px;font-weight:600;line-height:1.3}.task-desc{color:var(--text3);margin-top:3px;font-size:12px;line-height:1.4}.task-window{color:var(--primary);margin-top:5px;font-size:11px;font-weight:600}.task-pts{color:var(--accent);white-space:nowrap;flex-shrink:0;align-self:center;font-size:13px;font-weight:700}.task-pts--done{color:var(--success,#27ae60)}.task-cards{flex-direction:column;gap:14px;display:flex}.task-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px}.task-card--done{opacity:.65}.task-card-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.task-card-badge{text-transform:uppercase;letter-spacing:.05em;color:var(--primary);background:var(--primary);font-size:11px;font-weight:700}@supports (color:color-mix(in lab, red, red)){.task-card-badge{background:color-mix(in srgb, var(--primary) 10%, transparent)}}.task-card-badge{border-radius:20px;padding:3px 8px}.task-card-window{color:var(--text3);font-size:11px;font-weight:500}.task-card-main{align-items:center;gap:12px;margin-bottom:8px;display:flex}.task-card-icon{flex-shrink:0;font-size:32px;line-height:1}.task-card-title{color:var(--text);font-size:16px;font-weight:600;line-height:1.3}.task-card-desc{color:var(--text3);margin-bottom:14px;font-size:13px;line-height:1.5}.task-card-footer{border-top:1px solid var(--border);justify-content:space-between;align-items:center;margin-top:14px;padding-top:12px;display:flex}.task-card-pts{color:var(--accent);font-size:14px;font-weight:700}.task-card-done{color:var(--success,#27ae60);font-size:13px;font-weight:600}.task-card-btn{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:20px;padding:7px 18px;font-size:13px;font-weight:600;transition:opacity .15s}.task-card-btn:active{opacity:.8}.section-label{justify-content:space-between;align-items:center;display:flex}.section-label-link{color:var(--primary-light);cursor:pointer;text-transform:none;letter-spacing:0;background:0 0;border:none;padding:0;font-size:12px;font-weight:600}.agenda-list{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:4px;overflow:hidden}.agenda-item{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:9px 14px;display:flex}.agenda-item:last-child{border-bottom:none}.agenda-item--btn{text-align:left;cursor:pointer;width:100%;line-height:inherit;appearance:none;background:0 0;border:none;padding:9px 14px;transition:background .12s}.agenda-item--btn .agenda-time{justify-content:center;align-items:center;width:24px;min-width:24px;height:18px;font-size:13px;line-height:1;display:flex;overflow:hidden}.agenda-item--btn:active{background:var(--surface2)}.agenda-item--done{opacity:.55}.agenda-time{color:var(--primary);text-align:center;flex-shrink:0;min-width:28px;font-size:12px;font-weight:700}.agenda-title{color:var(--text);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:13px;line-height:1.3;overflow:hidden}.agenda-pts{color:var(--accent);flex-shrink:0;font-size:12px;font-weight:600}.review-notice{background:var(--accent)}@supports (color:color-mix(in lab, red, red)){.review-notice{background:color-mix(in srgb, var(--accent) 10%, transparent)}}.review-notice{color:var(--accent);border-radius:var(--radius-sm);margin-bottom:20px;padding:10px 14px;font-size:13px;font-weight:500}.review-question{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:12px;padding:16px}.review-question-num{color:var(--text3);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px;font-size:11px;font-weight:600}.review-question-text{color:var(--text);margin-bottom:12px;font-size:14px;font-weight:600;line-height:1.4}.review-options{flex-direction:column;gap:6px;display:flex}.review-option{color:var(--text3);border-radius:var(--radius-sm);background:var(--surface2);padding:8px 12px;font-size:13px}.review-option--selected{background:var(--primary)}@supports (color:color-mix(in lab, red, red)){.review-option--selected{background:color-mix(in srgb, var(--primary) 12%, transparent)}}.review-option--selected{color:var(--primary);font-weight:600}.review-scale{color:var(--text);padding:8px 0;font-size:14px}.review-text{color:var(--text2);background:var(--surface2);border-radius:var(--radius-sm);padding:8px 12px;font-size:13px;font-style:italic;line-height:1.5}@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-leading{syntax:"*";inherits:false}@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-outline-style{syntax:"*";inherits:false;initial-value:solid}@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}
