.sg-shell{min-height:100%;display:flex;justify-content:center;background:var(--sg-bg)}.sg-shell__col{width:100%;max-width:var(--sg-maxw);padding:24px 20px 20px;display:flex;flex-direction:column;min-height:100vh}.sg-shell__content{flex:1;display:flex;flex-direction:column}.sg-shell__footer{display:flex;flex-direction:column;gap:12px;padding-top:12px}.sg-btn{width:100%;height:48px;border-radius:var(--sg-radius);font-weight:600;font-size:17px;transition:background .15s,opacity .15s}.sg-btn--primary{background:var(--sg-primary);color:#fff}.sg-btn--primary:active:not(:disabled){background:var(--sg-primary-press)}.sg-btn--secondary{background:transparent;color:var(--sg-text);font-weight:600}.sg-btn:disabled{opacity:.4;cursor:default}.sg-welcome{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:40px;text-align:center}.sg-welcome__hero{display:flex;justify-content:center}.sg-welcome__hero-img{width:100%;max-width:340px;height:auto;display:block}.sg-welcome__title{font-size:28px;font-weight:600;line-height:1.25}.sg-welcome__terms{font-size:12px;color:var(--sg-text-muted);text-align:center}.sg-field{display:flex;flex-direction:column;gap:6px;width:100%}.sg-field__label{font-size:14px;color:var(--sg-text-muted)}.sg-field__input{height:52px;padding:0 16px;border:1.5px solid var(--sg-border);border-radius:var(--sg-radius);background:var(--sg-card);color:var(--sg-text)}.sg-field__input:focus{outline:none;border-color:var(--sg-primary)}.sg-field--error .sg-field__input{border-color:#c0392b}.sg-field__msg{font-size:13px;color:var(--sg-text-muted)}.sg-field__msg--error{color:#c0392b}.sg-login{flex:1;display:flex;flex-direction:column;justify-content:center;gap:16px}.sg-login__title{font-size:27px;font-weight:600}.sg-login__sub{color:var(--sg-text-muted);margin-bottom:6px}.sg-login__alt{text-align:center;color:var(--sg-primary);font-weight:600;font-size:14px}.sg-progress{height:10px;background:var(--sg-track);border-radius:999px;overflow:hidden;flex:1}.sg-progress__fill{height:100%;background:var(--sg-primary);border-radius:999px;transition:width .25s ease}.sg-select{display:flex;align-items:center;gap:14px;width:100%;padding:16px 18px;background:var(--sg-card);border:1.5px solid var(--sg-border);border-radius:var(--sg-radius-lg);cursor:pointer}.sg-select--on{border-color:var(--sg-primary);box-shadow:0 0 0 1px var(--sg-primary)}.sg-select__leading{width:44px;height:44px;flex:none;display:grid;place-items:center}.sg-select__body{flex:1}.sg-select__title{font-weight:600;font-size:17px}.sg-select__subtitle{font-size:14px;color:var(--sg-text-muted)}.sg-select__dot{width:22px;height:22px;border:2px solid var(--sg-border);flex:none}.sg-select__dot--radio{border-radius:999px}.sg-select__dot--checkbox{border-radius:6px}.sg-select--on .sg-select__dot{border-color:var(--sg-primary);background:var(--sg-primary);box-shadow:inset 0 0 0 3px var(--sg-card)}.sg-ob__top{display:flex;align-items:center;gap:12px;margin-bottom:28px}.sg-ob__back{font-size:22px;line-height:1;color:var(--sg-text);padding:4px}.sg-ob__count{font-size:14px;font-weight:600;color:var(--sg-text-muted)}.sg-ob__body{flex:1;display:flex;flex-direction:column;gap:20px}.sg-ob__title{font-size:24px;font-weight:600;text-align:center}.sg-ob__siggy{position:relative;display:flex;flex-direction:column;align-items:center;gap:16px;margin-top:24px}.sg-ob__siggy:before{content:"";position:absolute;top:-14px;width:210px;height:210px;border-radius:50%;background:radial-gradient(circle,#f4b7404d,#fffaf300 68%);z-index:0}.sg-ob__siggy>svg{position:relative;z-index:1}.sg-ob__bubble{position:relative;z-index:1;background:var(--sg-peach);border-radius:var(--sg-radius-lg);padding:16px;text-align:center}.sg-ob__list{display:flex;flex-direction:column;gap:12px}.sg-ob__flag{font-size:26px}.sg-ob__props{display:flex;flex-direction:column;gap:14px;margin-top:8px}.sg-ob__prop{display:flex;align-items:center;gap:14px;background:var(--sg-card);border:1px solid var(--sg-border);border-radius:var(--sg-radius-lg);padding:16px 18px}.sg-ob__prop-tile{width:48px;height:48px;flex:none;border-radius:12px;display:grid;place-items:center}.sg-ob__prop-tile--a{background:#eb683724;color:var(--sg-primary)}.sg-ob__prop-tile--b{background:#f4b74038;color:#c78a10}.sg-ob__prop-text{display:flex;flex-direction:column;gap:2px}.sg-ob__prop-text strong{font-size:17px;font-weight:600}.sg-ob__prop-text span{color:var(--sg-text-muted);font-size:14px}.sg-ob__pw{display:flex;flex-direction:column;gap:8px}.sg-ob__pwtoggle{align-self:flex-start;color:var(--sg-primary);font-size:14px;font-weight:600}.sg-loading{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;background:var(--sg-bg)}.sg-loading__mark{animation:sg-pulse 1.3s ease-in-out infinite}.sg-loading__label{color:var(--sg-text-muted);font-weight:600}@keyframes sg-pulse{0%,to{transform:scale(.94);opacity:.7}50%{transform:scale(1.04);opacity:1}}@media (prefers-reduced-motion: reduce){.sg-loading__mark{animation:none}}.sg-pw{display:flex;flex-direction:column;gap:20px;padding-bottom:8px}.sg-pw>*{animation:sg-rise .5s cubic-bezier(.2,.7,.2,1) both}.sg-pw>*:nth-child(1){animation-delay:.02s}.sg-pw>*:nth-child(2){animation-delay:.07s}.sg-pw>*:nth-child(3){animation-delay:.12s}.sg-pw>*:nth-child(4){animation-delay:.17s}.sg-pw>*:nth-child(5){animation-delay:.22s}.sg-pw>*:nth-child(6){animation-delay:.27s}.sg-pw>*:nth-child(7){animation-delay:.32s}.sg-pw>*:nth-child(8){animation-delay:.37s}.sg-pw>*:nth-child(9){animation-delay:.42s}@keyframes sg-rise{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}@media (prefers-reduced-motion: reduce){.sg-pw>*{animation:none}.sg-pw__hero :first-child~*{animation:none}}.sg-pw__hero{position:relative;display:grid;place-items:center;min-height:150px;margin-top:4px}.sg-pw__hero:before{content:"";position:absolute;width:210px;height:210px;border-radius:50%;background:radial-gradient(circle,#f4b74061,#fffaf300 68%)}.sg-pw__hero>svg:last-child{position:relative}.sg-pw__spark{position:absolute;color:var(--sg-amber);animation:sg-twinkle 2.4s ease-in-out infinite}.sg-pw__spark--1{top:14%;left:30%;animation-delay:0s}.sg-pw__spark--2{top:24%;right:30%;animation-delay:.5s}.sg-pw__spark--3{bottom:24%;right:26%;color:var(--sg-primary);animation-delay:1s}@keyframes sg-twinkle{0%,to{opacity:.35;transform:scale(.8)}50%{opacity:1;transform:scale(1.15)}}.sg-pw__title{font-size:27px;font-weight:600;line-height:1.22;text-align:center}.sg-pw__sub{text-align:center;color:var(--sg-text-muted);max-width:34ch;margin:0 auto}.sg-pw__rating{display:flex;align-items:center;gap:16px;background:var(--sg-cream-warm);border:1px solid rgba(201,124,0,.12);border-radius:var(--sg-radius-lg);padding:16px 18px;box-shadow:0 6px 18px -12px #c97c0066}.sg-pw__rating-num{font-size:36px;font-weight:600;line-height:1}.sg-pw__rating-meta{display:flex;flex-direction:column;gap:5px}.sg-pw__stars{display:flex;gap:3px;color:var(--sg-amber)}.sg-pw__rating-label{font-size:13px;color:var(--sg-text-muted)}.sg-pw__h2{font-size:20px;font-weight:600;margin-top:6px}.sg-pw__timeline{display:flex;flex-direction:column}.sg-pw__step{position:relative;display:flex;gap:16px;padding-bottom:20px}.sg-pw__step:not(:last-child):before{content:"";position:absolute;left:21px;top:44px;bottom:0;width:2px;background:var(--sg-border)}.sg-pw__node{position:relative;z-index:1;width:44px;height:44px;flex:none;border-radius:50%;display:grid;place-items:center}.sg-pw__step--today .sg-pw__node{background:#eb683724;color:var(--sg-primary)}.sg-pw__step--reminder .sg-pw__node{background:#f4b74038;color:#c78a10}.sg-pw__step--ends .sg-pw__node{background:#c97c0029;color:var(--sg-gold)}.sg-pw__step-body{display:flex;flex-direction:column;gap:3px;padding-top:2px}.sg-pw__step-body strong{font-weight:600;font-size:16px}.sg-pw__step-body span{color:var(--sg-text-muted);font-size:14px;line-height:1.4}.sg-pw__benefits{display:flex;flex-direction:column;gap:14px}.sg-pw__benefit{display:flex;gap:14px;align-items:center;background:var(--sg-card);border:1px solid var(--sg-border);border-radius:var(--sg-radius-lg);padding:14px 16px}.sg-pw__tile{width:46px;height:46px;flex:none;border-radius:12px;display:grid;place-items:center}.sg-pw__tile--a{background:#eb683724;color:var(--sg-primary)}.sg-pw__tile--b{background:#f4b74038;color:#c78a10}.sg-pw__tile--c{background:var(--sg-lavender);color:#6e62f7}.sg-pw__benefit-body{display:flex;flex-direction:column;gap:2px}.sg-pw__benefit-body strong{font-weight:600;font-size:16px}.sg-pw__benefit-body span{color:var(--sg-text-muted);font-size:14px;line-height:1.4}.sg-pw__reassure{text-align:center;font-size:13px;color:var(--sg-text-muted);margin-top:2px}.sg-nav{position:sticky;bottom:0;display:flex;background:var(--sg-card);border-top:1px solid var(--sg-border)}.sg-nav__item{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:10px 0 12px;color:var(--sg-text-muted);font-size:12px;font-weight:600}.sg-nav__item.is-active{color:var(--sg-primary)}.sg-dash{min-height:100vh;display:flex;flex-direction:column}.sg-dash__scroll{flex:1;width:100%;max-width:var(--sg-maxw);margin:0 auto;padding:16px 18px 24px}.sg-dash__stats{display:flex;justify-content:flex-end;gap:16px;margin-bottom:12px}.sg-dash__stat{display:inline-flex;align-items:center;gap:5px;font-weight:600;color:var(--sg-gold)}.sg-dash__unit{display:flex;align-items:center;justify-content:space-between;gap:12px;background:linear-gradient(120deg,var(--sg-amber-light),var(--sg-cream-warm));border-radius:var(--sg-radius-lg);padding:16px 18px}.sg-dash__unit-badge{background:var(--sg-gold);color:#fff;font-size:11px;font-weight:700;padding:2px 7px;border-radius:5px}.sg-dash__unit-count{font-size:13px;color:var(--sg-text-muted)}.sg-dash__unit-title{font-size:20px;font-weight:600;margin-top:6px}.sg-dash__unit-mano{background:#fff;border-radius:50%;padding:8px;display:grid;place-items:center}.sg-dash__chapters{display:flex;flex-direction:column;gap:16px;margin-top:16px}.sg-dash__link{display:block}.sg-dash__card{background:var(--sg-card);border:1.5px solid var(--sg-border);border-radius:var(--sg-radius-lg);padding:16px 18px}.sg-dash__card.is-open{border-color:var(--sg-gold)}.sg-dash__card.is-locked{opacity:.6}.sg-dash__chip{font-size:11px;font-weight:700;color:var(--sg-gold);background:var(--sg-cream-warm);padding:2px 7px;border-radius:5px}.sg-dash__card-head h3{font-size:19px;font-weight:600;margin-top:8px}.sg-dash__card-meta{font-size:13px;color:var(--sg-text-muted);margin-top:10px}.sg-dash__promo{display:flex;flex-direction:column;align-items:center;gap:6px;text-align:center;background:var(--sg-peach);border-radius:var(--sg-radius-lg);padding:18px;margin-top:16px}.sg-dash__promo-btn{margin-top:6px;background:var(--sg-primary);color:#fff;font-weight:600;padding:10px 18px;border-radius:var(--sg-radius)}.sg-media{position:relative;width:100%;aspect-ratio:4 / 3;border-radius:var(--sg-radius-lg);background:linear-gradient(160deg,#fff 0%,var(--sg-cream-warm) 100%);border:1px solid var(--sg-border);display:grid;place-items:center;overflow:hidden}.sg-media__art{width:55%;height:auto}.sg-media__caption{position:absolute;bottom:10px;left:50%;transform:translate(-50%);background:#292f32b8;color:#fff;font-weight:600;font-size:15px;padding:4px 12px;border-radius:999px}.sg-ex{display:flex;flex-direction:column;gap:18px}.sg-ex__title{font-size:18px;font-weight:600;text-align:center}.sg-ex__sentence{text-align:center;font-size:20px;font-weight:600}.sg-ex__blank{color:var(--sg-primary);border-bottom:2px solid var(--sg-primary);padding:0 6px}.sg-ex__options{display:flex;flex-direction:column;gap:12px}.sg-ex__opt{position:relative;width:100%;text-align:center;padding:16px;border-radius:var(--sg-radius-lg);background:var(--sg-card);border:1.5px solid var(--sg-border);font-weight:600;font-size:16px;color:var(--sg-text)}.sg-ex__opt.is-selected{border-color:var(--sg-primary);box-shadow:0 0 0 1px var(--sg-primary)}.sg-ex__opt.is-correct{background:#dcebc2;border-color:#7fb24a}.sg-ex__opt.is-wrong{background:#f8c9bd;border-color:#e0785e}.sg-ex__opt-num{position:absolute;right:10px;bottom:6px;font-size:12px;color:var(--sg-text-muted)}.sg-fb{display:flex;align-items:center;justify-content:center;gap:8px;font-weight:600;padding:14px;border-radius:var(--sg-radius)}.sg-fb--ok{background:#dcebc2;color:#2f6b16}.sg-fb--no{background:#f8c9bd;color:#9a2a10}.sg-fb__icon{display:grid;place-items:center;width:22px;height:22px;border-radius:50%;color:#fff}.sg-fb--ok .sg-fb__icon{background:#3f7d1f}.sg-fb--no .sg-fb__icon{background:#a3260f}.sg-done{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;text-align:center}.sg-done__stars{display:flex;gap:10px}.sg-done__stars .is-on{color:var(--sg-amber)}.sg-done__stars .is-off{color:var(--sg-border)}.sg-done__title{font-size:26px;font-weight:600}.sg-done__xp{font-weight:600;color:var(--sg-primary);font-size:18px}.sg-lp__top{display:flex;align-items:center;gap:14px;margin-bottom:24px}.sg-lp__menu{font-size:22px;line-height:1;color:var(--sg-text);padding:2px 6px}.sg-lp__body{flex:1}.sg-lp__sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#292f3259;display:flex;align-items:flex-end;justify-content:center}.sg-lp__sheet{width:100%;max-width:var(--sg-maxw);background:var(--sg-bg);border-radius:18px 18px 0 0;padding:20px;display:flex;flex-direction:column;gap:10px}.sg-prac{min-height:100vh;display:flex;flex-direction:column}.sg-prac__scroll{flex:1;width:100%;max-width:var(--sg-maxw);margin:0 auto;padding:16px 18px;display:flex;flex-direction:column}.sg-prac__top{display:flex;align-items:center;gap:14px;margin-bottom:20px}.sg-prac__close{font-size:26px;line-height:1;color:var(--sg-text);padding:0 6px}.sg-prac__card{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px}.sg-prac__card .sg-media{max-width:320px}.sg-prac__free{font-size:12px;font-weight:600;color:var(--sg-text-muted);background:var(--sg-peach);border-radius:999px;padding:4px 12px}.sg-prac__q{font-size:20px;font-weight:600;text-align:center}.sg-prac__a{font-size:18px;font-weight:600;color:var(--sg-primary);text-align:center}.sg-prac__actions{width:100%;max-width:var(--sg-maxw);margin:0 auto;padding:12px 18px;display:flex;flex-direction:column;gap:10px}.sg-prac__done{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;text-align:center;padding:20px}.sg-prac__done-title{font-size:26px;font-weight:600}.sg-prac__done-sub{color:var(--sg-text-muted)}.sg-prac__done-actions{width:100%;max-width:320px;display:flex;flex-direction:column;gap:10px;margin-top:8px}.sg-dict{min-height:100vh;display:flex;flex-direction:column}.sg-dict__scroll{flex:1;width:100%;max-width:var(--sg-maxw);margin:0 auto;padding:16px 18px 24px;overflow-y:auto}.sg-dict__stats{display:flex;justify-content:flex-end;gap:16px;margin-bottom:12px}.sg-dict__stat{display:inline-flex;align-items:center;gap:5px;font-weight:600;color:var(--sg-gold)}.sg-dict__chips{display:flex;gap:8px;overflow-x:auto;padding:14px 2px 8px;scrollbar-width:none}.sg-dict__chips::-webkit-scrollbar{display:none}.sg-dict__chip{flex:0 0 auto;padding:8px 14px;border-radius:999px;border:1.5px solid var(--sg-border);background:var(--sg-card);color:var(--sg-text);font-weight:600;font-size:14px;white-space:nowrap}.sg-dict__chip.is-active{background:var(--sg-amber-light);border-color:var(--sg-gold);color:var(--sg-gold)}.sg-dict__count{color:var(--sg-text-muted);font-size:13px;margin:4px 0 12px}.sg-dict__list{display:flex;flex-direction:column;gap:10px}.sg-dict__card{display:flex;align-items:center;gap:12px;padding:8px 10px;border:1px solid var(--sg-border);border-radius:var(--sg-radius);background:var(--sg-card);cursor:pointer}.sg-dict__thumb{width:56px;flex-shrink:0}.sg-dict__gloss{font-weight:600;font-size:16px}.sg-dict__empty{color:var(--sg-text-muted);text-align:center;padding:24px 0}.sg-acct{min-height:100vh;display:flex;flex-direction:column}.sg-acct__scroll{flex:1;width:100%;max-width:var(--sg-maxw);margin:0 auto;padding:24px 18px}.sg-acct__header{text-align:center}.sg-acct__name{font-size:26px;font-weight:700}.sg-acct__email{font-size:14px;color:var(--sg-text-muted);margin-top:4px}.sg-acct__flame{display:flex;justify-content:center;margin:8px 0 4px}.sg-acct__streak{background:var(--sg-peach);border-radius:var(--sg-radius-lg);padding:18px 16px 20px;margin-top:8px}.sg-acct__streak-title{text-align:center;font-size:17px;font-weight:700;margin-bottom:16px}.sg-acct__days{display:flex;justify-content:space-between;gap:4px;list-style:none}.sg-acct__day{display:flex;flex-direction:column;align-items:center;gap:6px;flex:1}.sg-acct__day-dot{width:28px;height:28px;border-radius:999px;border:1.5px solid var(--sg-border);background:transparent}.sg-acct__day-label{font-size:12px;font-weight:600;color:var(--sg-text-muted)}.sg-acct__day.is-today .sg-acct__day-dot{border:1.5px dashed var(--sg-primary)}.sg-acct__day.is-today .sg-acct__day-label{color:var(--sg-primary)}.sg-acct__cta{display:block;width:100%;height:48px;margin-top:20px;background:var(--sg-primary);color:#fff;font-weight:600;font-size:17px;text-align:center;line-height:48px;border-radius:var(--sg-radius)}.sg-acct__cta:active{background:var(--sg-primary-press)}.sg-acct__section{margin-top:24px}.sg-acct__section-title{font-size:15px;font-weight:700;margin-bottom:10px}.sg-acct__rows{background:var(--sg-card);border:1.5px solid var(--sg-border);border-radius:var(--sg-radius-lg);overflow:hidden}.sg-acct__row{width:100%;display:flex;align-items:center;gap:12px;padding:15px 16px;background:transparent;text-align:left;border-bottom:1px solid var(--sg-border)}.sg-acct__row:last-child{border-bottom:none}.sg-acct__row-icon{display:grid;place-items:center;color:var(--sg-text);flex:none}.sg-acct__row-label{flex:1;font-size:16px;font-weight:500}.sg-acct__row-chevron{display:grid;place-items:center;width:30px;height:30px;flex:none;background:var(--sg-peach);color:var(--sg-primary);border-radius:999px}.sg-acct__logout{width:100%;height:48px;margin-top:20px;background:transparent;color:var(--sg-primary);font-weight:600;font-size:16px;border:1.5px solid var(--sg-border);border-radius:var(--sg-radius)}.sg-acct__row:disabled{opacity:.55}.sg-acct__toast{position:fixed;left:50%;bottom:84px;transform:translate(-50%);max-width:calc(var(--sg-maxw) - 32px);width:max-content;padding:12px 18px;background:var(--sg-text);color:#fff;font-size:14px;font-weight:600;text-align:center;border-radius:999px;box-shadow:0 8px 24px #0000002e;z-index:60}.sg-acct__sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:flex-end;justify-content:center;z-index:70}.sg-acct__sheet{width:100%;max-width:var(--sg-maxw);background:var(--sg-card);border-radius:var(--sg-radius-lg) var(--sg-radius-lg) 0 0;padding:22px 18px calc(22px + env(safe-area-inset-bottom));box-shadow:0 -8px 32px #00000029}.sg-acct__sheet-title{font-size:18px;font-weight:700;margin-bottom:16px}.sg-acct__sheet>*+*{margin-top:14px}.sg-acct__langs{display:flex;flex-direction:column;gap:10px}.sg-acct__lang{display:flex;align-items:center;gap:12px;width:100%;padding:14px 16px;background:var(--sg-bg);border:1.5px solid var(--sg-border);border-radius:var(--sg-radius);text-align:left;font-size:15px}.sg-acct__lang.is-current{border-color:var(--sg-primary);background:var(--sg-peach)}.sg-acct__lang:disabled{opacity:.6}.sg-acct__lang-flag{font-size:22px;flex:none}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}button{font:inherit;cursor:pointer;border:none;background:none}input{font:inherit}ul,ol{list-style:none}a{color:inherit;text-decoration:none}@font-face{font-family:Open Runde;src:url(/src/assets/fonts/OpenRunde-Regular.woff2) format("woff2");font-weight:400;font-display:swap}@font-face{font-family:Open Runde;src:url(/src/assets/fonts/OpenRunde-Semibold.woff2) format("woff2");font-weight:600;font-display:swap}:root{--sg-bg: #FFFAF3;--sg-cream-warm: #FEEFD6;--sg-text: #292F32;--sg-text-muted: #505659;--sg-primary: #EB6837;--sg-primary-press: #d65c2f;--sg-gold: #C97C00;--sg-amber: #F4B740;--sg-amber-light: #FFDD9F;--sg-peach: #FBE6C8;--sg-lavender: #EEECFF;--sg-card: #ffffff;--sg-border: #eadfce;--sg-track: #F4E2C5;--sg-radius: 12px;--sg-radius-lg: 16px;--sg-maxw: 600px;--sg-font: "Open Runde", "Nunito", system-ui, -apple-system, sans-serif}body{background:var(--sg-bg);color:var(--sg-text);font-family:var(--sg-font);-webkit-font-smoothing:antialiased}
