:root{--bg:#0a0a0a;--bg-elev:#0e0e10;--bg-card:#0c0c0e;--border:#ffffff14;--border-strong:#ffffff24;--text:#ededef;--text-dim:#9a9aa2;--text-faint:#6b6b73;--accent:#a78bfa;--accent-soft:#a78bfa24;--accent-line:#a78bfa59;--radius:14px;--radius-lg:22px;--container:1120px;--font:"Inter", ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, sans-serif;--logo:"Olde English", serif;--mono:"JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace}@font-face{font-family:Olde English;src:url(/fonts/olde-english-regular.ttf)format("truetype");font-weight:400;font-style:normal;font-display:swap}*{box-sizing:border-box}html,body{background:var(--bg);color:var(--text);margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;font-feature-settings:"cv11","ss01","ss03";letter-spacing:-.005em;font-size:16px;line-height:1.55;overflow-x:hidden}a{color:inherit;text-decoration:none}button{font-family:inherit}::selection{background:var(--accent-soft);color:#fff}.bg-grid{z-index:0;pointer-events:none;background:radial-gradient(1200px 700px at 50% -100px,#a78bfa14,#0000 60%),radial-gradient(800px 500px at 85% 15%,#a78bfa0a,#0000 70%);position:fixed;inset:0}.bg-grid:after{content:"";background-image:linear-gradient(90deg,#ffffff06 1px,#0000 1px),linear-gradient(#ffffff06 1px,#0000 1px);background-size:56px 56px;position:absolute;inset:0;-webkit-mask-image:radial-gradient(at 50% 20%,#000 20%,#0000 70%);mask-image:radial-gradient(at 50% 20%,#000 20%,#0000 70%)}.shell{z-index:1;position:relative}.container{max-width:var(--container);margin:0 auto;padding:0 24px}.nav{z-index:50;-webkit-backdrop-filter:blur(14px)saturate(160%);background:#0a0a0aa6;border-bottom:1px solid #0000;transition:border-color .3s,background .3s;position:sticky;top:0}.nav.is-scrolled{border-bottom-color:var(--border);background:#0a0a0ac7}.nav.is-menu-open{border-bottom-color:var(--border);background:#0a0a0aeb}.nav-inner{justify-content:space-between;align-items:center;height:64px;display:flex}.brand{letter-spacing:-.01em;z-index:2;align-items:center;font-weight:600;display:flex;position:relative}.brand-text{font-family:var(--logo);letter-spacing:.01em;color:var(--text);font-size:28px;font-weight:400;line-height:1}.nav-links{z-index:2;align-items:center;gap:26px;display:flex;position:relative}.nav-links a{color:var(--text-dim);font-size:13px;transition:color .2s}.nav-links a:hover{color:var(--text)}.nav-links a.nav-cta,.nav-links a.nav-cta:hover{color:#0a0a0a;background:#fff;border:1px solid #ffffff3d;font-weight:600;box-shadow:inset 0 1px #ffffff14}.nav-cta{border-radius:8px;padding:8px 14px;font-size:13px;transition:transform .2s,background .2s,box-shadow .2s}.nav-cta:hover{background:#f0f0f0;transform:translateY(-1px);box-shadow:0 8px 24px #00000047}.nav-menu-btn{border:1px solid var(--border);width:38px;height:38px;color:var(--text);cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:manipulation;background:#ffffff0d;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;padding:0;transition:background .2s,border-color .2s,color .2s;display:none}.nav-menu-btn:hover,.nav-menu-btn[aria-expanded=true]{border-color:var(--border-strong);color:var(--text);background:#ffffff1a}.nav-mobile-menu{z-index:1;pointer-events:none;opacity:0;transition:opacity .2s,transform .2s;display:none;position:absolute;top:calc(100% + 8px);left:clamp(12px,4vw,20px);right:clamp(12px,4vw,20px);transform:translateY(-8px)}.nav-mobile-menu.is-open{pointer-events:auto;opacity:1;display:block;transform:translateY(0)}.nav-mobile-menu-inner{border:1px solid var(--border);-webkit-backdrop-filter:blur(14px)saturate(160%);background:#0a0a0af5;border-radius:12px;flex-direction:column;gap:clamp(2px,1vw,6px);max-width:none;margin:0;padding:clamp(8px,2vw,12px) clamp(18px,5.5vw,28px) clamp(12px,3vw,16px);display:flex;box-shadow:0 16px 40px #00000059}.nav-mobile-link{color:var(--text);-webkit-tap-highlight-color:#a78bfa33;touch-action:manipulation;cursor:pointer;border-bottom:1px solid #ffffff0f;border-radius:8px;padding:clamp(12px,3.2vw,15px) clamp(4px,1.5vw,8px);font-size:clamp(14px,3.6vw,16px);font-weight:500;line-height:1.3;transition:color .2s,background .2s;display:block}.nav-mobile-link:last-child{border-bottom:0}.nav-mobile-link:hover{background:#ffffff0a}.nav-mobile-link:active{color:var(--accent);background:#a78bfa14}@media (width<=720px){.nav .container{padding-inline:clamp(16px,5vw,24px)}.nav-links .nav-link{display:none}.nav-menu-btn{display:inline-flex}.nav-links{flex-shrink:0;gap:clamp(6px,2vw,10px);min-width:0}.brand-text{font-size:clamp(22px,6vw,28px)}.nav-cta{white-space:nowrap;padding:8px clamp(8px,2.5vw,12px);font-size:clamp(11px,3vw,12px)}.nav-cta svg{margin-right:4px!important}.nav-menu-btn{width:clamp(36px,10vw,38px);height:clamp(36px,10vw,38px)}}@media (width<=420px){.nav-mobile-menu{left:clamp(10px,3.5vw,16px);right:clamp(10px,3.5vw,16px)}.nav-mobile-menu-inner{padding-inline:clamp(16px,6vw,22px)}}@media (width>=721px){.nav-mobile-menu{display:none!important}}.reveal{opacity:0;transition:opacity .7s,transform .7s;transform:translateY(8px)}.reveal.in{opacity:1;transform:translateY(0)}.reveal[data-delay="1"]{transition-delay:60ms}.reveal[data-delay="2"]{transition-delay:.12s}.reveal[data-delay="3"]{transition-delay:.18s}.reveal[data-delay="4"]{transition-delay:.24s}.reveal[data-delay="5"]{transition-delay:.3s}.hero{padding:90px 0 100px;position:relative;overflow:hidden}.hero-bgname{box-sizing:border-box;pointer-events:none;z-index:0;width:100%;font-family:var(--font);letter-spacing:-.04em;text-align:center;white-space:nowrap;color:#0000;-webkit-text-stroke:1px #ffffff24;background:linear-gradient(#ffffff2e 0%,#ffffff0f 55%,#0000 100%);-webkit-user-select:none;user-select:none;-webkit-background-clip:text;background-clip:text;padding:0 24px;font-size:clamp(34px,7.4vw,132px);font-weight:700;line-height:.9;position:absolute;top:8px;left:0;right:0}.hero .container{z-index:1;position:relative}.hero.center .hero-bgname{top:0}@media (width<=720px){.hero{padding:68px 0 80px}.hero-bgname{letter-spacing:-.035em;padding:0 16px;font-size:clamp(22px,8.8vw,52px);top:14px}.h-display{margin-top:clamp(52px,14vw,84px);margin-bottom:24px}}@media (width<=480px){.hero{padding:60px 0 72px}.hero-bgname{letter-spacing:-.03em;top:10px}.h-display{margin-top:clamp(48px,13vw,64px)}}.hero-avail-fixed{z-index:60;color:var(--text);-webkit-backdrop-filter:blur(20px)saturate(180%);backdrop-filter:blur(20px)saturate(180%);white-space:nowrap;background:#ffffff0f;border:1px solid #ffffff1f;border-radius:999px;align-items:center;gap:10px;max-width:calc(100vw - 24px);padding:10px 18px;font-size:12.5px;display:inline-flex;position:fixed;bottom:24px;left:50%;transform:translate(-50%);box-shadow:inset 0 1px #ffffff14,inset 0 -1px #0003,0 12px 40px #00000073,0 0 24px #a78bfa2e}.hero-avail-fixed .dot{background:#4ade80;border-radius:50%;flex-shrink:0;width:7px;height:7px;animation:2.4s ease-in-out infinite pulse;box-shadow:0 0 0 3px #4ade802e}.hero-scroll{z-index:59;color:var(--text-faint);letter-spacing:.16em;text-transform:uppercase;font-size:10px;font-family:var(--mono);opacity:.85;flex-direction:column;align-items:center;gap:6px;transition:color .25s,opacity .4s,transform .4s;display:flex;position:fixed;bottom:78px;left:50%;transform:translate(-50%)}.hero-scroll:hover{color:var(--text)}.hero-scroll-mouse{border:1.2px solid;border-radius:12px;place-items:start center;width:18px;height:28px;padding-top:5px;display:grid}.hero-scroll-wheel{background:currentColor;border-radius:1px;width:2px;height:5px;animation:1.6s ease-in-out infinite scrollwheel}body.is-scrolled .hero-scroll{opacity:0;pointer-events:none;transform:translate(-50%)translateY(8px)}@keyframes pulse{0%,to{box-shadow:0 0 0 3px #4ade802e}50%{box-shadow:0 0 0 6px #4ade8000}}@keyframes scrollwheel{0%{opacity:0;transform:translateY(-2px)}40%{opacity:1}to{opacity:0;transform:translateY(8px)}}@media (width<=720px){.hero-avail-fixed{padding:8px 14px;font-size:11.5px;bottom:16px}.hero-scroll{font-size:9px;bottom:62px}.hero-scroll-mouse{width:16px;height:24px}}.h-display{letter-spacing:-.035em;max-width:880px;margin:clamp(72px,8vw + 36px,160px) 0 clamp(20px,3vw,32px);font-size:clamp(32px,4.6vw,52px);font-weight:600;line-height:1.05}.role-list{flex-direction:column;margin:0;padding:0;list-style:none;display:flex}.role-list li{cursor:default;padding:4px 0;position:relative}.role-list li span{color:var(--text);transition:color .35s,transform .35s,letter-spacing .35s,font-size .35s,opacity .35s;display:inline-block}.role-list li.is-primary span{color:var(--text);font-weight:600}.role-list li.is-primary:before{content:"";background:var(--accent);opacity:1;border-radius:50%;width:8px;height:8px;position:absolute;top:50%;left:-18px;transform:translateY(-50%);box-shadow:0 0 0 4px #a78bfa2e}.role-list li.is-supporting span{color:#ffffff52;letter-spacing:.005em;font-size:.74em;font-weight:400}.role-list li.is-supporting:hover span{color:var(--text);transform:translate(8px)}.role-list li:before{content:"";background:var(--accent);opacity:0;border-radius:50%;width:8px;height:8px;transition:opacity .3s,transform .3s;position:absolute;top:50%;left:-18px;transform:translateY(-50%)scale(.4)}.role-list li:after{content:"";background:linear-gradient(to right, var(--accent), transparent);transform-origin:0;opacity:0;width:100%;height:1px;transition:transform .5s cubic-bezier(.2,.7,.2,1),opacity .3s;position:absolute;bottom:2px;left:0;transform:scaleX(0)}.role-list:hover li.is-primary span{color:var(--text-faint)}.role-list li.is-primary:hover span{color:var(--text);transform:translate(8px)}.role-list li:hover:before{opacity:1;transform:translateY(-50%)scale(1)}.role-list li:hover:after{opacity:.6;transform:scaleX(1)}@media (width<=720px){.role-list li:before{width:6px;height:6px;left:-14px}}.hero-actions{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.btn{border:1px solid var(--border);color:var(--text);cursor:pointer;background:0 0;border-radius:10px;align-items:center;gap:8px;padding:11px 18px;font-size:14px;font-weight:500;transition:all .2s;display:inline-flex}.btn:hover{border-color:var(--border-strong);background:#ffffff08}.btn-primary{color:#0a0a0a;background:#fff;border-color:#fff}.btn-primary:hover{background:#ececec;transform:translateY(-1px)}.btn-ghost{color:var(--text-dim);border:none;padding-left:8px}.btn-ghost:hover{color:var(--text);background:0 0}.hero.center{text-align:center}.hero.center .hero-actions{justify-content:center}.hero-split{grid-template-columns:1.2fr 1fr;align-items:center;gap:60px;display:grid}@media (width<=860px){.hero-split{grid-template-columns:1fr}}.hero-glyph{aspect-ratio:1;border:1px solid var(--border);border-radius:var(--radius-lg);background:radial-gradient(500px 300px at 70% 10%,#a78bfa2e,#0000 60%),linear-gradient(#0d0d10,#0a0a0a);place-items:center;display:grid;position:relative;overflow:hidden}.hero-glyph:before{content:"";background-image:linear-gradient(90deg,#ffffff09 1px,#0000 1px),linear-gradient(#ffffff09 1px,#0000 1px);background-size:28px 28px;position:absolute;inset:0;-webkit-mask-image:radial-gradient(#000 40%,#0000 80%);mask-image:radial-gradient(#000 40%,#0000 80%)}.hero-glyph svg{position:relative}section.band{padding:100px 0;position:relative}.eyebrow{letter-spacing:.08em;text-transform:uppercase;color:var(--text-faint);align-items:center;gap:8px;margin-bottom:14px;font-size:12px;font-weight:500;display:inline-flex}.eyebrow:before{content:"";background:var(--accent);border-radius:50%;width:6px;height:6px}.section-title{letter-spacing:-.028em;max-width:660px;margin:0 0 14px;font-size:clamp(28px,4vw,40px);font-weight:600;line-height:1.1}.section-lede{color:var(--text-dim);max-width:560px;margin:0 0 54px;font-size:16px}.skills-primary-label{font-family:var(--mono);letter-spacing:.16em;text-transform:uppercase;color:var(--text);align-items:center;gap:10px;margin-top:36px;margin-bottom:14px;font-size:11px;display:flex}.dot-accent{background:var(--accent);border-radius:50%;width:6px;height:6px;box-shadow:0 0 0 3px #a78bfa2e}.skills-secondary-label{font-family:var(--mono);letter-spacing:.16em;text-transform:uppercase;color:var(--text-faint);margin-top:40px;margin-bottom:12px;font-size:11px}.skills-secondary{flex-wrap:wrap;gap:8px;display:flex}.skill-chip{cursor:default;background:#ffffff04;border:1px solid #ffffff0f;border-radius:10px;outline:none;min-width:0;padding:12px 16px;transition:all .25s;position:relative}.skill-chip-name{color:var(--text-faint);font-size:13px;font-weight:500;transition:color .25s}.skill-chip-meta{color:#ffffff40;font-size:11px;font-family:var(--mono);margin-top:2px;transition:color .25s}.skill-chip-detail{color:var(--text-dim);opacity:0;max-height:0;margin-top:0;font-size:12px;line-height:1.5;transition:max-height .3s,opacity .25s,margin-top .25s;overflow:hidden}.skill-chip:hover,.skill-chip:focus-visible{border-color:var(--accent-line);background:#ffffff0a;transform:translateY(-1px)}.skill-chip:hover .skill-chip-name,.skill-chip:focus-visible .skill-chip-name{color:var(--text)}.skill-chip:hover .skill-chip-meta,.skill-chip:focus-visible .skill-chip-meta{color:var(--accent)}.skill-chip:hover .skill-chip-detail,.skill-chip:focus-visible .skill-chip-detail{opacity:1;max-height:80px;margin-top:8px}.skill-detail{color:var(--text-dim);margin-top:12px;font-size:13px;line-height:1.55}.skill-tag-row{flex-wrap:wrap;gap:6px;margin-top:16px;display:flex}.skills-primary-grid{grid-template-columns:repeat(2,1fr);gap:14px;display:grid}@media (width<=720px){.skills-primary-grid{grid-template-columns:1fr}}.skill-primary-card{border:1px solid var(--border);border-radius:var(--radius);background:#ffffff03;flex-direction:column;gap:0;padding:28px;transition:border-color .25s,background .25s;display:flex}.skill-primary-card:hover{border-color:var(--accent-line);background:#ffffff06}.skill-name{letter-spacing:-.01em;font-size:17px;font-weight:600}.skill-meta{color:var(--text-faint);font-size:12px;font-family:var(--mono);margin-top:4px;margin-bottom:16px}.skill-bar-wrap{align-items:center;gap:10px;display:flex}.skill-bar{background:#ffffff0f;border-radius:3px;flex:1;height:5px;overflow:hidden}.skill-bar span{background:linear-gradient(to right, var(--accent), #c4b5fd);transform-origin:0;height:100%;transition:transform 1.1s cubic-bezier(.2,.7,.2,1);display:block;transform:scaleX(0)}.skills-primary-grid.in .skill-primary-card .skill-bar span{transform:scaleX(var(--lvl,.8))}.skill-bar-pct{font-size:12px;font-family:var(--mono);color:var(--accent);text-align:right;flex-shrink:0;min-width:30px}.skills-categories{grid-template-columns:repeat(2,1fr);gap:14px;display:grid}@media (width<=720px){.skills-categories{grid-template-columns:1fr}}.skill-category{border:1px solid var(--border);border-radius:var(--radius);background:#ffffff03;flex-direction:column;gap:10px;padding:24px;display:flex}.skill-category-label{font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--accent);font-size:11px;font-weight:500}.skill-category-detail{color:var(--text-dim);margin:0;font-size:13px;line-height:1.55}.skill-pill-row{flex-wrap:wrap;gap:6px;margin-top:4px;display:flex}.services-primary-label{font-family:var(--mono);letter-spacing:.16em;text-transform:uppercase;color:var(--text);align-items:center;gap:10px;margin-top:36px;margin-bottom:14px;font-size:11px;display:flex}.services-secondary-label{font-family:var(--mono);letter-spacing:.16em;text-transform:uppercase;color:var(--text-faint);margin-top:36px;margin-bottom:14px;font-size:11px}.services-secondary{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}.service-mini{cursor:default;background:#ffffff03;border:1px solid #ffffff0f;border-radius:12px;outline:none;gap:14px;padding:18px 20px;transition:all .25s;display:flex}.service-mini-icon{width:32px;height:32px;color:var(--text-faint);background:#ffffff0a;border:1px solid #ffffff0f;border-radius:8px;flex-shrink:0;place-items:center;transition:all .25s;display:grid}.service-mini-body{flex:1;min-width:0}.service-mini h4{color:var(--text-faint);margin:0 0 4px;font-size:14px;font-weight:500;transition:color .25s}.service-mini p{color:#ffffff59;margin:0;font-size:12.5px;line-height:1.55;transition:color .25s}.service-mini-tags{opacity:0;flex-wrap:wrap;gap:5px;max-height:0;margin-top:0;transition:max-height .3s,opacity .25s,margin-top .25s;display:flex;overflow:hidden}.service-mini:hover,.service-mini:focus-visible{border-color:var(--accent-line);background:#ffffff09;transform:translateY(-1px)}.service-mini:hover h4,.service-mini:focus-visible h4{color:var(--text)}.service-mini:hover p,.service-mini:focus-visible p{color:var(--text-dim)}.service-mini:hover .service-mini-icon,.service-mini:focus-visible .service-mini-icon{color:var(--accent);border-color:var(--accent-line);background:var(--accent-soft)}.service-mini:hover .service-mini-tags,.service-mini:focus-visible .service-mini-tags{opacity:1;max-height:60px;margin-top:10px}.service-tags{flex-wrap:wrap;gap:5px;margin-top:12px;display:flex}.service-tag{font-size:10.5px;font-family:var(--mono);border:1px solid var(--border);color:var(--text-faint);border-radius:4px;padding:3px 8px}.service.is-primary .service-tag{color:var(--text-dim);border-color:var(--accent-line)}.services-grid{border:1px solid var(--border);border-radius:var(--radius-lg);grid-template-columns:repeat(2,1fr);gap:0;display:grid;overflow:hidden}.service{border-right:1px solid var(--border);border-bottom:1px solid var(--border);padding:32px 28px;transition:background .3s;position:relative}.service:nth-child(2n){border-right:none}.service:nth-last-child(-n+2){border-bottom:none}.service:hover{background:#ffffff04}.service-icon{background:var(--accent-soft);border:1px solid var(--accent-line);width:38px;height:38px;color:var(--accent);border-radius:10px;place-items:center;margin-bottom:20px;display:grid}.service h3{letter-spacing:-.01em;margin:0 0 8px;font-size:17px;font-weight:500}.service p{color:var(--text-dim);margin:0;font-size:14px;line-height:1.6}.service-arrow{color:var(--text-faint);opacity:0;transition:all .25s;position:absolute;top:32px;right:28px;transform:translate(-4px,4px)}.service:hover .service-arrow{opacity:1;color:var(--accent);transform:translate(0)}@media (width<=720px){.services-grid{grid-template-columns:1fr}.service{border-right:none}.service:nth-child(2n){border-bottom:1px solid var(--border)}.service:last-child{border-bottom:none}.services-secondary{grid-template-columns:1fr}}.projects-list{flex-direction:column;gap:20px;display:flex}.project-card{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-card);cursor:pointer;transition:border-color .3s,transform .3s;position:relative;overflow:hidden}.project-card:hover{border-color:var(--border-strong)}.project-grid{grid-template-columns:1.15fr 1fr;align-items:stretch;min-height:340px;display:grid}.project-copy{flex-direction:column;justify-content:space-between;gap:24px;padding:40px;display:flex}.project-kicker{font-family:var(--mono);color:var(--text-faint);letter-spacing:.04em;font-size:11px}.project-title{letter-spacing:-.022em;margin:10px 0;font-size:26px;font-weight:600;line-height:1.15}.project-desc{color:var(--text-dim);margin:0 0 20px;font-size:15px;line-height:1.6}.tag-row{flex-wrap:wrap;gap:6px;display:flex}.tag{font-size:11px;font-family:var(--mono);color:var(--text-dim);border:1px solid var(--border);background:#ffffff05;border-radius:6px;padding:4px 9px}.project-open{color:var(--accent);align-items:center;gap:8px;font-size:13px;font-weight:500;display:inline-flex}.project-visual{border-left:1px solid var(--border);background:linear-gradient(#0f0f12,#0a0a0c);place-items:center;padding:40px 20px;display:grid;position:relative;overflow:hidden}.project-visual:before{content:"";background-image:radial-gradient(400px 260px at 70% 30%,#a78bfa1a,#0000 70%);position:absolute;inset:0}.project-visual-inner{position:relative}@media (width<=860px){.project-grid{grid-template-columns:1fr}.project-visual{border-left:none;border-top:1px solid var(--border);min-height:380px}.project-copy{padding:28px}}.modal-backdrop{z-index:100;-webkit-backdrop-filter:blur(8px);opacity:0;pointer-events:none;background:#060608b8;transition:opacity .3s;position:fixed;inset:0}.modal-backdrop.open{opacity:1;pointer-events:auto}.modal{z-index:101;opacity:0;pointer-events:none;transition:opacity .35s;position:fixed;inset:0;overflow-y:auto}.modal.open{opacity:1;pointer-events:auto}.modal-shell{background:var(--bg-elev);border:1px solid var(--border);border-radius:22px;max-width:1100px;margin:36px auto;transition:transform .4s cubic-bezier(.2,.7,.2,1);overflow:hidden;transform:translateY(14px)}.modal.open .modal-shell{transform:translateY(0)}.modal-hd{border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:2;background:#0e0e10e6;justify-content:space-between;align-items:center;padding:18px 22px;display:flex;position:sticky;top:0}.modal-hd-title{color:var(--text-dim);font-size:14px;font-weight:500;font-family:var(--mono)}.modal-close{border:1px solid var(--border);width:34px;height:34px;color:var(--text-dim);cursor:pointer;background:0 0;border-radius:8px;place-items:center;transition:all .2s;display:grid}.modal-close:hover{color:var(--text);border-color:var(--border-strong);background:#ffffff0a}.modal-hero-actions{flex-direction:column;gap:12px;margin-top:24px;display:flex}.modal-hero-links,.app-download-row{flex-wrap:wrap;gap:12px;display:flex}.app-download-dialog-backdrop{z-index:1200;background:#0000009e;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.app-download-dialog{border:1px solid var(--border-strong);background:#141414;border-radius:16px;width:min(420px,100%);padding:22px 20px 18px;box-shadow:0 24px 60px #00000073}.app-download-dialog h4{letter-spacing:-.02em;margin:0 0 10px;font-size:17px;font-weight:600}.app-download-dialog p{color:var(--text-dim);margin:0 0 18px;font-size:14px;line-height:1.65}.app-download-dialog .btn{justify-content:center;width:100%}.modal-hero{border-bottom:1px solid var(--border);padding:56px 48px 40px}.modal-title{letter-spacing:-.03em;margin:12px 0 16px;font-size:clamp(30px,4vw,44px);font-weight:600;line-height:1.1}.modal-lede{color:var(--text-dim);max-width:640px;margin:0 0 22px;font-size:17px}.modal-body{grid-template-columns:1.1fr 1fr;gap:0;display:grid}@media (width<=900px){.modal-body{grid-template-columns:1fr}}.modal-col{border-right:1px solid var(--border);padding:48px}.modal-col:last-child{border-right:none}@media (width<=900px){.modal-col{border-right:none;border-bottom:1px solid var(--border)}.modal-col:last-child{border-bottom:none}}.modal-sub{text-transform:uppercase;letter-spacing:.1em;color:var(--text-faint);margin:0 0 16px;font-size:11px;font-weight:500}.feature-item{border-bottom:1px solid var(--border);gap:12px;padding:14px 0;display:flex}.feature-item:last-child{border-bottom:none}.feature-dot{border:1px solid var(--accent-line);background:var(--accent-soft);width:18px;height:18px;color:var(--accent);border-radius:50%;flex:none;place-items:center;margin-top:2px;display:grid}.feature-text strong{margin-bottom:2px;font-size:14px;font-weight:500;display:block}.feature-text span{color:var(--text-dim);font-size:13px}.stack-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:flex-start;gap:28px;padding:14px 0;font-size:13px;display:flex}.stack-row:last-child{border-bottom:none}.stack-row span:first-child{color:var(--text-dim);flex:none;min-width:72px}.stack-row span:last-child{font-family:var(--mono);text-align:right;margin-left:auto;line-height:1.55}.backend-case{border-top:1px solid var(--border);background:radial-gradient(520px 260px at 20% 0,#e8a04c14,#0000 72%),#ffffff02;padding:48px}.backend-case-head{max-width:720px;margin-bottom:24px}.backend-case-head h3{letter-spacing:-.035em;margin:10px 0;font-size:clamp(24px,2.6vw,32px);font-weight:600;line-height:1.12}.backend-case-head p{color:var(--text-dim);margin:0;font-size:14px;line-height:1.7}.backend-flow{grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:18px;display:grid}.backend-flow div{border:1px solid var(--border);background:#ffffff05;border-radius:14px;padding:14px 12px}.backend-flow span{color:#e8a04c;font-family:var(--mono);margin-bottom:6px;font-size:10px;display:block}.backend-flow strong{font-size:13px;font-weight:500}.backend-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.backend-card{border:1px solid var(--border);background:#ffffff04;border-radius:16px;padding:18px}.backend-card strong{margin-bottom:7px;font-size:14px;font-weight:600;display:block}.backend-card p{color:var(--text-dim);margin:0 0 12px;font-size:13px;line-height:1.6}.backend-card span{color:#e8a04c;font-family:var(--mono);font-size:10px;line-height:1.5;display:block}@media (width<=800px){.backend-case{padding:34px 24px}.backend-flow,.backend-grid{grid-template-columns:1fr}}.demo-wrap{border-top:1px solid var(--border);background:radial-gradient(500px 300px at 50% 0,#a78bfa14,#0000 70%),#0a0a0c;place-items:center;padding:60px 24px;display:grid;position:relative}.demo-wrap:before{content:"";pointer-events:none;background-image:linear-gradient(90deg,#ffffff06 1px,#0000 1px),linear-gradient(#ffffff06 1px,#0000 1px);background-size:40px 40px;position:absolute;inset:0;-webkit-mask-image:radial-gradient(at 50% 30%,#000 25%,#0000 75%);mask-image:radial-gradient(at 50% 30%,#000 25%,#0000 75%)}.demo-caption{text-align:center;color:var(--text-faint);font-size:12px;font-family:var(--mono);margin-top:24px;position:relative}.demo-caption kbd{font-family:var(--mono);border:1px solid var(--border);color:var(--text-dim);background:#ffffff08;border-radius:4px;padding:2px 6px;font-size:11px}.phone{background:#121215;border:1px solid #1f1f23;border-radius:40px;width:280px;height:580px;padding:10px;position:relative;box-shadow:inset 0 0 0 1px #ffffff0a,0 30px 80px -20px #0009,0 0 0 6px #0b0b0d}.phone-inner{background:#0d0d10;border-radius:32px;flex-direction:column;width:100%;height:100%;display:flex;position:relative;overflow:hidden}.phone-punch{z-index:10;background:#000;border-radius:50%;width:10px;height:10px;position:absolute;top:14px;left:50%;transform:translate(-50%);box-shadow:inset 0 0 0 1px #1a1a1d}.phone-statusbar{height:36px;color:var(--text);font-variant-numeric:tabular-nums;justify-content:space-between;align-items:center;padding:10px 22px 0;font-size:11px;font-weight:500;display:flex}.phone-statusbar .right{align-items:center;gap:5px;display:flex}.phone-navbar{justify-content:center;align-items:center;height:18px;display:flex}.phone-navbar:after{content:"";background:#ffffff59;border-radius:3px;width:110px;height:4px}.phone-scroll{flex-direction:column;flex:1;display:flex;overflow:hidden}.mini-phone{background:#111114;border:1px solid #1c1c20;border-radius:32px;width:220px;height:430px;padding:6px;box-shadow:inset 0 0 0 1px #ffffff0a,0 20px 50px -15px #0009}.mini-phone-inner{background:#0e0e12;border-radius:26px;flex-direction:column;width:100%;height:100%;display:flex;position:relative;overflow:hidden}.mini-phone-inner>*{border-radius:inherit;box-sizing:border-box;width:100%;height:100%;overflow:hidden}.td-body{flex-direction:column;flex:1;padding:22px 20px 14px;display:flex;overflow:hidden}.td-header{margin-bottom:18px}.td-date{color:var(--text-faint);font-size:11px;font-family:var(--mono);letter-spacing:.04em}.td-greeting{letter-spacing:-.02em;margin-top:4px;font-size:22px;font-weight:600;line-height:1.15}.td-greeting em{color:var(--accent);font-style:normal}.td-stats{grid-template-columns:1fr 1fr;gap:8px;margin-bottom:16px;display:grid}.td-stat{border:1px solid var(--border);border-radius:12px;padding:10px 12px}.td-stat .big{letter-spacing:-.02em;font-size:20px;font-weight:600}.td-stat .big em{color:var(--accent);font-style:normal}.td-stat .lbl{color:var(--text-faint);margin-top:2px;font-size:10px}.td-stat.row{justify-content:space-between;align-items:center;gap:8px;display:flex}.td-filters{gap:6px;margin-bottom:12px;display:flex}.td-filter{border:1px solid var(--border);color:var(--text-dim);cursor:pointer;background:0 0;border-radius:999px;padding:5px 10px;font-size:11px;transition:all .2s}.td-filter.active{background:var(--accent);color:#0a0a0a;border-color:var(--accent);font-weight:500}.td-list{scrollbar-width:thin;flex-direction:column;flex:1;gap:6px;margin:0 -4px 0 0;padding-right:4px;display:flex;overflow-y:auto}.td-list::-webkit-scrollbar{width:4px}.td-list::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:2px}.td-task{border:1px solid var(--border);background:#ffffff04;border-radius:12px;align-items:flex-start;gap:10px;padding:12px;transition:all .35s;display:flex;position:relative;overflow:hidden}.td-task.done{opacity:.55}.td-task.done .td-label{color:var(--text-faint);text-decoration:line-through}.td-task.leaving{opacity:0;border-width:0;max-height:0;padding:0 12px;transform:translate(40px)}.td-task.entering{opacity:0;transform:translateY(-8px)}.td-check{border:1.5px solid var(--text-faint);cursor:pointer;background:0 0;border-radius:50%;flex:none;place-items:center;width:20px;height:20px;margin-top:1px;transition:all .2s;display:grid}.td-check.on{background:var(--accent);border-color:var(--accent)}.td-check.on svg{opacity:1;transform:scale(1)}.td-check svg{opacity:0;color:#0a0a0a;transition:all .2s;transform:scale(.5)}.td-label{color:var(--text);font-size:13px;font-weight:500;line-height:1.4}.td-meta{color:var(--text-faint);align-items:center;gap:8px;margin-top:4px;font-size:10px;display:flex}.td-tag{background:var(--accent-soft);color:var(--accent);font-family:var(--mono);border-radius:4px;padding:1px 6px;font-size:9px}.td-tag.blue{color:#93c5fd;background:#60a5fa24}.td-tag.green{color:#86efac;background:#4ade8024}.td-tag.rose{color:#fda4af;background:#fb718524}.td-add{border:1px dashed var(--border-strong);border-radius:12px;align-items:center;gap:8px;margin-top:10px;padding:10px 12px;transition:all .2s;display:flex}.td-add:focus-within{border-style:solid;border-color:var(--accent-line);background:#a78bfa0d}.td-add input{color:var(--text);background:0 0;border:none;outline:none;flex:1;padding:2px 0;font-family:inherit;font-size:13px}.td-add input::placeholder{color:var(--text-faint)}.td-add button{background:var(--accent);color:#0a0a0a;cursor:pointer;border:none;border-radius:8px;place-items:center;width:26px;height:26px;font-weight:700;transition:transform .15s;display:grid}.td-add button:hover{transform:scale(1.08)}.td-add svg{color:var(--text-faint);flex-shrink:0}@keyframes sparkle{0%{opacity:0;transform:scale(0)}40%{opacity:1;transform:scale(1.2)}to{opacity:0;transform:scale(1.5)}}.td-sparkle{background:var(--accent);pointer-events:none;border-radius:50%;width:4px;height:4px;animation:.6s ease-out forwards sparkle;position:absolute}.ring-svg{width:34px;height:34px;transform:rotate(-90deg)}.ring-bg{stroke:#ffffff14;fill:none;stroke-width:3px}.ring-fg{stroke:var(--accent);fill:none;stroke-width:3px;stroke-linecap:round;transition:stroke-dashoffset .6s}.fd-body{--fd-bg:#0e0e10;--fd-card:#16161a;--fd-card-strong:#1e1e24;--fd-border:#ffffff14;--fd-amber:#e8a04c;--fd-amber-soft:#e8a04c26;--fd-green:#5bc97d;--fd-red:#e5645b;color:#f5f5f7;background:var(--fd-bg);min-height:0;font-family:var(--sans);flex-direction:column;flex:1;gap:6px;padding:10px 10px 6px;display:flex;position:relative;overflow:hidden}.fd-aurora{pointer-events:none;opacity:.52;background-image:linear-gradient(90deg,#ffffff06 1px,#0000 1px),linear-gradient(#ffffff05 1px,#0000 1px);background-size:22px 22px;position:absolute;inset:0;-webkit-mask-image:radial-gradient(circle at 50% 15%,#000,#0000 70%);mask-image:radial-gradient(circle at 50% 15%,#000,#0000 70%)}.fd-top,.fd-tabs,.fd-panel{z-index:1;position:relative}.fd-top{justify-content:space-between;align-items:flex-start;gap:10px;display:flex}.fd-kicker,.fd-small{font-family:var(--mono);text-transform:uppercase;letter-spacing:.12em;color:#f4efe77a;font-size:8px}.fd-title{letter-spacing:-.035em;margin-top:2px;font-size:17px;font-weight:700;line-height:1.08}.fd-live{color:var(--fd-green);font-size:8px;font-family:var(--mono);white-space:nowrap;background:#73d99f14;border:1px solid #73d99f3d;border-radius:999px;align-items:center;gap:5px;padding:5px 7px;display:inline-flex}.fd-live span{background:currentColor;border-radius:50%;width:5px;height:5px;box-shadow:0 0 10px #73d99fd9}.fd-tabs{border:1px solid var(--fd-border);background:#ffffff06;border-radius:13px;grid-template-columns:repeat(4,1fr);gap:5px;padding:3px;display:grid}.fd-tabs button{color:#f4efe78a;cursor:pointer;background:0 0;border:none;border-radius:9px;padding:7px 0;font-size:9px;transition:all .2s}.fd-tabs button.active{background:var(--fd-amber);color:#17100a;font-weight:700}.fd-panel{flex-direction:column;flex:1;gap:8px;min-height:0;display:flex;overflow:hidden}.fd-plan-hero,.fd-practice-card,.fd-coach-card,.fd-profile-card,.fd-note,.fd-session-grid>div{border:1px solid var(--fd-border);background:var(--fd-card);box-shadow:0 18px 34px #0000003d}.fd-plan-hero{background:linear-gradient(135deg, #e8a04c38, #ffffff06), var(--fd-card);border-radius:17px;justify-content:space-between;align-items:flex-end;gap:12px;min-height:94px;padding:13px;display:flex}.fd-plan-hero strong,.fd-practice-head strong,.fd-coach-card strong,.fd-profile-card strong{letter-spacing:-.02em;margin-top:3px;font-size:14px;display:block}.fd-plan-hero span,.fd-profile-card span{color:#f4efe794;margin-top:4px;font-size:10px;line-height:1.4;display:block}.fd-plan-hero button{color:#17100a;background:var(--fd-amber);cursor:pointer;border:none;border-radius:12px;padding:10px 12px;font-size:11px;font-weight:800}.fd-plan-list{flex-direction:column;gap:6px;display:flex}.fd-plan-row{border:1px solid var(--fd-border);background:#ffffff06;border-radius:13px;grid-template-columns:32px 1fr auto;align-items:center;gap:9px;min-height:48px;padding:8px 9px;display:grid}.fd-plan-row.done{opacity:.72}.fd-plan-time{background:var(--fd-amber-soft);width:28px;height:28px;color:var(--fd-amber);font-family:var(--mono);border-radius:9px;place-items:center;font-size:10px;font-weight:700;display:grid}.fd-plan-row strong{font-size:11px;line-height:1.15;display:block}.fd-plan-row span{color:#f4efe775;margin-top:3px;font-size:9px;display:block}.fd-plan-check{color:#f4efe78c;font-size:8px;font-family:var(--mono);border:1px solid #ffffff14;border-radius:999px;padding:4px 7px}.fd-plan-row.done .fd-plan-check{color:#111;background:var(--fd-green);border-color:var(--fd-green)}.fd-pipeline{grid-template-columns:repeat(4,1fr);gap:5px;margin-top:auto;display:grid}.fd-pipe-step{text-align:center;color:#f4efe79e;min-width:0;font-size:8px;font-family:var(--mono);background:#e8a04c12;border:1px solid #e8a04c29;border-radius:11px;padding:7px 4px}.fd-pipe-step span{color:var(--fd-amber);margin-bottom:1px;font-size:10px;display:block}.fd-practice-card{border-radius:17px;flex-direction:column;gap:11px;padding:12px;display:flex}.fd-practice-head{justify-content:space-between;align-items:flex-start;gap:10px;display:flex}.fd-bpm{color:var(--fd-amber);background:var(--fd-amber-soft);font-family:var(--mono);border-radius:10px;padding:6px 8px;font-size:9px}.fd-chord-flow{grid-template-columns:repeat(4,1fr);gap:6px;display:grid}.fd-chord-flow div{border:1px solid var(--fd-border);color:#f4efe773;background:#ffffff06;border-radius:12px;place-items:center;height:38px;font-size:14px;font-weight:700;transition:all .2s;display:grid}.fd-chord-flow div.active{color:var(--fd-amber);background:var(--fd-amber-soft);border-color:#e8a04c8c;box-shadow:0 0 18px #e8a04c1f}.fd-strum-board{grid-template-columns:16px 1fr;align-items:stretch;gap:7px;display:grid}.fd-string-labels{color:#f4efe76b;height:132px;font-family:var(--mono);flex-direction:column;justify-content:space-between;padding:14px 0 12px;font-size:8px;font-weight:700;display:flex}.fd-string-field{background:radial-gradient(160px 70px at 50% 18%,#e8a04c12,#0000 72%),linear-gradient(#ffffff05,#00000029),#111215;border:1px solid #ffffff12;border-radius:12px;height:132px;position:relative;overflow:hidden}.fd-string-line{background:linear-gradient(90deg,#0000,#f4efe747,#0000);height:1px;position:absolute;left:7px;right:7px}.fd-string-line:first-child{opacity:.9;height:2px;top:16px}.fd-string-line:nth-child(2){opacity:.82;height:2px;top:36px}.fd-string-line:nth-child(3){opacity:.76;height:1.5px;top:56px}.fd-string-line:nth-child(4){opacity:.68;top:76px}.fd-string-line:nth-child(5){opacity:.62;top:96px}.fd-string-line:nth-child(6){opacity:.58;top:116px}.fd-slot-grid{grid-template-columns:repeat(16,minmax(0,1fr));display:grid;position:absolute;inset:0 6px}.fd-slot{justify-content:center;min-width:0;transition:background .18s;display:flex;position:relative}.fd-slot:before{content:"";background:#ffffff0b;width:1px;position:absolute;top:9px;bottom:9px;left:0}.fd-slot:nth-child(4n+1):before{background:#e8a04c2e}.fd-slot span{color:#f4efe76b;font-family:var(--mono);font-size:8px;position:absolute;top:3px}.fd-slot b{color:#1b1209;background:radial-gradient(circle at 35% 28%, #f7c078, var(--fd-amber) 72%);opacity:0;border-radius:50%;place-items:center;width:22px;height:22px;font-size:16px;font-weight:900;line-height:1;display:grid;position:absolute;left:50%;transform:translate(-50%,-50%);box-shadow:0 0 0 2px #e8a04c1f,0 8px 12px #00000047}.fd-slot.hit b{opacity:1}.fd-slot.bass b{top:34%}.fd-slot.top b{top:74%}.fd-slot.active{background:linear-gradient(#0000,#e8a04c14)}.fd-slot.active b{transform:translate(-50%,-50%)scale(1.18);box-shadow:0 0 0 4px #e8a04c29,0 0 16px #e8a04c61}.fd-playhead{background:var(--fd-amber);border-radius:999px;width:2px;transition:left .22s linear;position:absolute;top:10px;bottom:8px;transform:translate(-1px);box-shadow:0 0 14px #e8a04c80}.fd-playhead:after{content:"";background:var(--fd-amber);border-radius:50%;width:8px;height:8px;position:absolute;top:-3px;left:50%;transform:translate(-50%)}.fd-meter-row{color:#f4efe785;font-size:9px;font-family:var(--mono);grid-template-columns:1fr auto auto;align-items:center;gap:8px;display:grid}.fd-meter-row div{align-items:center;gap:4px;display:flex}.fd-meter-row strong{color:var(--fd-green)}.fd-controls{justify-content:center;align-items:center;gap:11px;margin-top:auto;padding-top:2px;display:flex}.fd-round,.fd-play,.fd-chip-btn{border:1px solid var(--fd-border);cursor:pointer;color:#f4efe7}.fd-round{background:#ffffff09;border-radius:12px;width:38px;height:38px}.fd-play{background:var(--fd-amber);color:#17100a;border:none;border-radius:50%;place-items:center;width:52px;height:52px;display:grid;box-shadow:0 16px 28px #e8a04c3d}.fd-chip-btn{min-width:76px;height:38px;color:var(--fd-amber);background:#ffffff09;border-radius:999px;font-size:10px;font-weight:700}.fd-coach-card{background:radial-gradient(120px 120px at 0 0, #e8a04c2e, transparent 72%), var(--fd-card);border-radius:17px;grid-template-columns:34px 1fr;gap:10px;padding:13px;display:grid}.fd-coach-icon{width:34px;height:34px;color:var(--fd-amber);background:var(--fd-amber-soft);border-radius:12px;place-items:center;display:grid}.fd-coach-card p{color:#f4efe7ab;margin:7px 0 0;font-size:11px;line-height:1.55}.fd-note-stack{flex-direction:column;gap:7px;display:flex}.fd-note{color:#f4efe794;border-radius:13px;padding:10px 11px;font-size:10px;line-height:1.45}.fd-session-grid{grid-template-columns:repeat(3,1fr);gap:7px;margin-top:auto;display:grid}.fd-session-grid>div{text-align:center;border-radius:14px;padding:11px 5px}.fd-session-grid strong{color:var(--fd-amber);font-size:17px;display:block}.fd-session-grid span{color:#f4efe76b;font-size:8px;font-family:var(--mono);text-transform:uppercase;margin-top:1px;display:block}.fd-profile-card{border-radius:17px;grid-template-columns:1fr 116px;align-items:center;gap:8px;padding:12px;display:grid}.fd-radar{width:116px;height:116px;overflow:visible}.fd-radar-grid{fill:#ffffff09;stroke:#ffffff1a;stroke-width:1px}.fd-radar-grid.inner{fill:#ffffff05;stroke-dasharray:2 3}.fd-radar-fill{fill:#e8a04c6b;stroke:var(--fd-amber);stroke-width:2px}.fd-radar circle{fill:#f4efe7}.fd-skill-list{flex-direction:column;gap:8px;display:flex}.fd-skill-row{color:#f4efe794;font-size:9px;font-family:var(--mono);grid-template-columns:48px 1fr 22px;align-items:center;gap:8px;display:grid}.fd-skill-row div{background:#ffffff14;border-radius:999px;height:6px;overflow:hidden}.fd-skill-row i{border-radius:inherit;background:linear-gradient(90deg, var(--fd-amber), var(--fd-green));height:100%;display:block}.fd-skill-row b{color:#f4efe7c7;text-align:right;font-weight:700}.fd-top{flex:none}.fd-live{appearance:none;cursor:pointer;font:inherit;font-family:var(--mono)}.fd-scroll{z-index:1;scrollbar-width:none;flex:1;min-height:0;padding:0 2px 2px;position:relative;overflow-y:auto}.fd-scroll::-webkit-scrollbar{width:0;height:0}.fd-screen,.fd-session-screen{flex-direction:column;gap:10px;min-height:100%;display:flex}.fd-session-screen{padding-bottom:2px}.fd-greeting h3,.fd-profile-head h3{letter-spacing:-.045em;margin:0;font-size:23px;line-height:1.08}.fd-greeting p,.fd-profile-head p{color:#f4efe794;margin:4px 0 0;font-size:11px}.fd-section-header{justify-content:space-between;align-items:center;gap:10px;margin-top:2px;display:flex}.fd-section-header strong{letter-spacing:-.01em;font-size:12px}.fd-section-header button{color:#e8a04ce6;font-family:var(--mono);cursor:pointer;background:0 0;border:none;font-size:8px}.fd-plan-row{appearance:none;color:#f4efe7;width:100%;font:inherit;text-align:left;cursor:pointer}.fd-plan-row:hover,.fd-progress-row:hover,.fd-exercise-card:hover{background:#e8a04c0e;border-color:#e8a04c5c}.fd-tools{grid-template-columns:repeat(3,1fr);gap:7px;display:grid}.fd-tools button{border:1px solid var(--fd-border);color:#f4efe7a3;cursor:pointer;background:#ffffff07;border-radius:13px;place-items:center;gap:2px;min-width:0;height:42px;font-size:9px;display:grid}.fd-continue-list,.fd-category-block,.fd-history-group,.fd-settings-list{flex-direction:column;gap:7px;display:flex}.fd-progress-row{appearance:none;border:1px solid var(--fd-border);width:100%;color:inherit;font:inherit;text-align:left;cursor:pointer;background:#ffffff06;border-radius:14px;grid-template-columns:1fr 54px;align-items:center;gap:10px;padding:10px;display:grid}.fd-progress-row strong,.fd-history-row strong{font-size:11px;line-height:1.25;display:block}.fd-progress-row span,.fd-history-row span{color:#f4efe770;margin-top:3px;font-size:9px;display:block}.fd-row-progress{background:#ffffff14;border-radius:999px;height:5px;overflow:hidden}.fd-row-progress i{border-radius:inherit;background:var(--fd-amber);height:100%;display:block}.fd-skill-mini-grid{grid-template-columns:repeat(4,1fr);gap:7px;display:grid}.fd-skill-mini-grid div{border:1px solid var(--fd-border);text-align:center;background:#ffffff06;border-radius:14px;padding:10px 5px}.fd-skill-mini-grid strong{color:var(--fd-amber);font-size:13px;display:block}.fd-skill-mini-grid span{color:#f4efe77a;font-size:8px;font-family:var(--mono)}.fd-search{border:1px solid var(--fd-border);color:#f4efe76e;background:#ffffff06;border-radius:14px;align-items:center;gap:8px;min-height:42px;padding:0 12px;font-size:11px;display:flex}.fd-filter-row{scrollbar-width:none;gap:6px;padding-bottom:1px;display:flex;overflow-x:auto}.fd-filter-row::-webkit-scrollbar{display:none}.fd-filter-row button{border:1px solid var(--fd-border);color:#f4efe794;cursor:pointer;background:#ffffff06;border-radius:999px;flex:none;padding:6px 9px;font-size:9px}.fd-filter-row button.active{color:#17100a;background:var(--fd-amber);border-color:var(--fd-amber);font-weight:800}.fd-weak-card{background:linear-gradient(135deg,#e8a04c24,#ffffff05);border:1px solid #e8a04c38;border-radius:15px;grid-template-columns:36px 1fr;gap:10px;padding:10px;display:grid}.fd-card-icon{width:34px;height:34px;color:var(--fd-amber);background:var(--fd-amber-soft);border-radius:11px;place-items:center;display:grid}.fd-weak-card strong{font-size:12px;display:block}.fd-weak-card span{color:#f4efe78c;margin-top:3px;font-size:10px;line-height:1.35;display:block}.fd-exercise-grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.fd-exercise-card{appearance:none;border:1px solid var(--fd-border);min-height:124px;color:inherit;text-align:left;cursor:pointer;background:radial-gradient(80px 70px at 100% 0,#e8a04c14,#0000 70%),#ffffff06;border-radius:14px;flex-direction:column;padding:10px;display:flex}.fd-card-top,.fd-card-bottom{justify-content:space-between;align-items:center;gap:6px;display:flex}.fd-badge{text-overflow:ellipsis;white-space:nowrap;max-width:76px;color:var(--fd-amber);background:var(--fd-amber-soft);font-family:var(--mono);border:1px solid #e8a04c47;border-radius:6px;padding:2px 5px;font-size:7px;overflow:hidden}.fd-badge.chord{color:#6ea8ff;background:#6ea8ff21;border-color:#6ea8ff47}.fd-badge.scale{color:#78c46a;background:#78c46a21;border-color:#78c46a47}.fd-badge.pick{color:#ff8a64;background:#ff8a6421;border-color:#ff8a6447}.fd-stars{color:var(--fd-amber);letter-spacing:-1px;white-space:nowrap;font-size:8px}.fd-exercise-card strong{margin-top:11px;font-size:11px;line-height:1.18;display:block}.fd-exercise-card p{color:#f4efe773;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:5px 0 8px;font-size:8px;line-height:1.35;display:-webkit-box;overflow:hidden}.fd-card-bottom{color:#f4efe76b;font-family:var(--mono);margin-top:auto;font-size:8px}.fd-card-bottom b{color:var(--fd-green)}.fd-session-top{grid-template-columns:32px 1fr 32px;align-items:center;gap:8px;display:grid}.fd-session-top button{border:1px solid var(--fd-border);color:#f4efe7;cursor:pointer;background:#ffffff08;border-radius:10px;place-items:center;width:32px;height:32px;font-size:18px;display:grid}.fd-session-top strong{font-size:12px;line-height:1.2;display:block}.fd-session-top span{color:#f4efe773;font-size:9px}.fd-tutor-lane{min-height:42px;color:var(--fd-amber);background:var(--fd-amber-soft);border:1px solid #e8a04c38;border-radius:13px;align-items:center;gap:7px;padding:9px 10px;font-size:9px;line-height:1.35;display:flex}.fd-chord-meter{background:var(--fd-amber-soft);border:1px solid #e8a04c33;border-radius:14px;grid-template-columns:auto 1fr auto;align-items:center;gap:8px;padding:9px 11px;display:grid}.fd-chord-meter span,.fd-chord-meter em{color:#f4efe780;font-family:var(--mono);text-transform:uppercase;font-size:8px;font-style:normal}.fd-chord-meter strong{color:var(--fd-amber);text-align:center;font-size:15px}.fd-chord-panel{scrollbar-width:none;gap:8px;padding-bottom:2px;display:flex;overflow-x:auto}.fd-chord-panel::-webkit-scrollbar{display:none}.fd-chord-card{border:1px solid var(--fd-border);text-align:center;background:#ffffff06;border-radius:14px;flex:0 0 92px;padding:9px 7px 8px;transition:border-color .2s,background .2s,transform .2s}.fd-chord-card.active{background:var(--fd-amber-soft);border-color:#e8a04c80;transform:translateY(-1px)}.fd-chord-card strong{color:var(--fd-amber);white-space:nowrap;margin-bottom:7px;font-size:12px;display:block}.fd-mini-fret{background:linear-gradient(#794a258c,#342217b3);border:1px solid #ffffff17;border-radius:8px;height:102px;position:relative;overflow:hidden}.fd-mini-fret:before{content:"";background:#f4efe76b;border-radius:999px;height:3px;position:absolute;top:14px;left:6%;right:6%;box-shadow:0 1px 5px #00000059}.fd-chord-string{background:linear-gradient(#f4efe780,#f4efe72e);width:1px;position:absolute;top:14px;bottom:6px;transform:translate(-50%)}.fd-chord-string:first-child,.fd-chord-string:nth-child(2){width:1.6px}.fd-fret-line{background:#f4efe733;height:1px;position:absolute;left:6%;right:6%}.fd-chord-marker{color:#f4efe78a;font-family:var(--mono);font-size:8px;font-weight:800;line-height:1;position:absolute;top:2px;transform:translate(-50%)}.fd-chord-marker.open{color:#f4efe7b8}.fd-chord-marker.mute{color:#e5645bc7}.fd-chord-dot{background:var(--fd-amber);color:#17100a;width:15px;height:15px;font-family:var(--mono);border-radius:50%;place-items:center;font-size:8px;font-style:normal;font-weight:900;display:grid;position:absolute;transform:translate(-50%,-50%);box-shadow:0 0 0 2px #00000059,0 0 10px #e8a04c2e}.fd-scale-panel,.fd-pick-panel{border:1px solid var(--fd-border);background:var(--fd-card);border-radius:17px;padding:11px}.fd-mode-row{gap:6px;margin-bottom:9px;display:flex;overflow:hidden}.fd-mode-row span{border:1px solid var(--fd-border);color:#f4efe77a;border-radius:999px;padding:5px 8px;font-size:8px}.fd-mode-row span.active{color:#17100a;background:var(--fd-amber);border-color:var(--fd-amber);font-weight:800}.fd-scale-meta{justify-content:space-between;align-items:flex-start;gap:8px;margin:-2px 0 9px;display:flex}.fd-scale-meta strong{color:#f4efe7;font-size:11px;line-height:1.2}.fd-scale-meta span{color:#f4efe76b;max-width:100px;font-family:var(--mono);text-align:right;text-transform:uppercase;font-size:7px;line-height:1.35}.fd-fretboard{background:radial-gradient(120px 80px at 52% 20%,#e8a04c1a,#0000 72%),linear-gradient(#5d3a22eb,#231913fa);border:1px solid #ffffff14;border-radius:14px;height:176px;position:relative;overflow:hidden;box-shadow:inset 0 12px 28px #0003}.fd-fretboard:after{content:"";background:#f4efe761;border-radius:999px;width:3px;position:absolute;top:8px;bottom:22px;left:18%;box-shadow:0 0 10px #00000052}.fd-fretboard em{color:#f4efe77a;font-family:var(--mono);z-index:2;font-size:8px;font-style:normal;font-weight:800;position:absolute;left:7px;transform:translateY(-50%)}.fd-scale-string{z-index:1;background:linear-gradient(90deg,#0000,#f4efe74d,#0000);height:1px;position:absolute;left:7px;right:8px;transform:translateY(-50%)}.fd-scale-string:first-of-type,.fd-scale-string:nth-of-type(2){height:1.7px}.fd-scale-fret{z-index:1;background:#f4efe72e;width:1px;position:absolute;top:8px;bottom:22px}.fd-fret-labels{z-index:2;height:12px;position:absolute;bottom:5px;left:0;right:0}.fd-fret-labels span{color:#f4efe761;font-family:var(--mono);font-size:7px;position:absolute;transform:translate(-50%)}.fd-scale-note{width:22px;height:22px;color:var(--fd-amber);cursor:pointer;z-index:3;background:#17100a;border:1px solid #e8a04ca6;border-radius:50%;font-size:9px;font-weight:800;transition:transform .15s,box-shadow .15s,background .15s;position:absolute;transform:translate(-50%,-50%);box-shadow:0 0 0 2px #00000057}.fd-scale-note.root{background:var(--fd-amber);color:#17100a}.fd-scale-note.open{border-color:#f4efe780;width:20px;height:20px}.fd-scale-note:hover{transform:translate(-50%,-50%)scale(1.1)}.fd-scale-note.active{color:#17100a;background:var(--fd-amber);box-shadow:0 0 0 5px #e8a04c29,0 0 18px #e8a04c61}.fd-pick-panel{flex-direction:column;gap:10px;padding:11px;display:flex}.fd-pick-strip{text-align:center}.fd-pick-bars{justify-content:center;gap:4px;display:flex}.fd-pick-bars span{background:#f4efe71f;border-radius:999px;width:11px;height:4px;transition:width .18s,background .18s}.fd-pick-bars span.hit{background:var(--fd-green)}.fd-pick-bars span.active{background:var(--fd-amber);width:24px;box-shadow:0 0 12px #e8a04c47}.fd-pick-strip p{color:#f4efe773;font-family:var(--mono);margin:6px 0 0;font-size:8px}.fd-pick-meta{justify-content:space-between;align-items:flex-start;gap:10px;display:flex}.fd-pick-meta strong{color:#f4efe7;font-size:12px;line-height:1.2;display:block}.fd-pick-meta span{color:#f4efe77a;margin-top:3px;font-size:9px;line-height:1.35;display:block}.fd-pick-meta b{color:var(--fd-amber);background:var(--fd-amber-soft);font-family:var(--mono);border:1px solid #e8a04c47;border-radius:999px;flex:none;padding:5px 7px;font-size:8px}.fd-tab-stave{background:radial-gradient(130px 70px at 50% 18%,#e8a04c17,#0000 72%),repeating-linear-gradient(4deg,#ffffff09 0 1px,#0000 1px 14px),linear-gradient(#4b3a2d,#352820 52%,#241b16);border:1px solid #ffffff14;border-radius:15px;height:178px;position:relative;overflow:hidden;box-shadow:inset 0 12px 28px #00000040}.fd-tab-stave em{color:#f4efe77a;font-family:var(--mono);z-index:2;font-size:8px;font-style:normal;font-weight:800;position:absolute;left:10px;transform:translateY(-50%)}.fd-pick-string{z-index:1;background:linear-gradient(90deg,#f4efe76b,#f4efe72e);height:1px;position:absolute;left:35px;right:12px;transform:translateY(-50%)}.fd-pick-string:nth-of-type(5),.fd-pick-string:nth-of-type(6){height:1.7px}.fd-pick-fret{z-index:1;background:#f4efe729;width:1px;position:absolute;top:18px;bottom:32px}.fd-pick-note{z-index:3;place-items:center;display:grid;position:absolute;transform:translate(-50%,-50%)}.fd-pick-note:before{content:"";background:0 0;width:1px;position:absolute;top:-72px;bottom:-72px}.fd-pick-note.active:before{background:repeating-linear-gradient(#e8a04c47 0 5px,#0000 5px 9px)}.fd-pick-note strong{width:25px;height:25px;color:var(--fd-amber);border:1.5px solid var(--fd-amber);background:#0e0e10;border-radius:50%;place-items:center;font-size:10px;line-height:1;display:grid;box-shadow:0 5px 10px #00000057}.fd-pick-note.active strong{color:#17100a;background:var(--fd-amber);width:30px;height:30px;box-shadow:0 0 0 6px #e8a04c29,0 0 18px #e8a04c59}.fd-pick-note.hit strong{color:#07140b;background:var(--fd-green);border-color:var(--fd-green)}.fd-pick-note b{color:#e8a04cdb;font-size:13px;font-weight:900;line-height:1;position:absolute;top:31px}.fd-pick-note.active b{color:var(--fd-amber);font-size:16px;top:35px}.fd-pick-note.hit b{color:var(--fd-green)}.fd-hearing-box{border:1px solid var(--fd-border);background:#ffffff06;border-radius:14px;justify-content:space-between;align-items:center;gap:10px;padding:10px;display:flex}.fd-hearing-box span{color:#f4efe76b;font-family:var(--mono);letter-spacing:.1em;font-size:8px;display:block}.fd-hearing-box strong{color:#f4efe7c7;margin-top:3px;font-size:10px;line-height:1.25;display:block}.fd-hearing-pulse{place-items:center;gap:3px;display:grid}.fd-hearing-pulse i{background:var(--fd-green);border-radius:50%;width:10px;height:10px;box-shadow:0 0 12px #73d99fb3}.fd-hearing-pulse small{color:#f4efe76b;font-family:var(--mono);text-transform:uppercase;font-size:7px}.fd-pick-stats{grid-template-columns:repeat(3,1fr);gap:7px;display:grid}.fd-pick-stats div{border:1px solid var(--fd-border);text-align:center;background:#ffffff06;border-radius:13px;padding:8px 4px}.fd-pick-stats span{color:#f4efe76b;font-family:var(--mono);text-transform:uppercase;font-size:7px;display:block}.fd-pick-stats strong{color:var(--fd-amber);margin-top:2px;font-size:12px;display:block}.fd-feedback-card{grid-template-columns:repeat(3,1fr);gap:7px;display:grid}.fd-feedback-card>div{border:1px solid var(--fd-border);text-align:center;background:#ffffff06;border-radius:14px;padding:10px 5px}.fd-feedback-card span{color:#f4efe76b;font-family:var(--mono);text-transform:uppercase;font-size:8px;display:block}.fd-feedback-card strong{color:var(--fd-green);margin-top:2px;font-size:14px;display:block}.fd-consistency{border:1px solid var(--fd-border);background:#ffffff06;border-radius:16px;justify-content:space-between;align-items:flex-end;height:86px;padding:12px 14px;display:flex}.fd-consistency span{background:linear-gradient(180deg, var(--fd-amber), #e8a04c2e);border-radius:999px;width:16px}.fd-history-row{border:1px solid var(--fd-border);background:#ffffff06;border-radius:14px;grid-template-columns:1fr 34px 34px;align-items:center;gap:8px;padding:10px;display:grid}.fd-history-row b{color:var(--fd-amber);text-align:right;font-size:12px}.fd-history-row em{color:var(--fd-green);font-family:var(--mono);text-align:right;font-size:8px;font-style:normal}.fd-profile-head{text-align:center;place-items:center;display:grid}.fd-avatar{color:#17100a;background:linear-gradient(135deg, var(--fd-amber), #f2b266);border-radius:22px;place-items:center;width:58px;height:58px;margin-bottom:8px;font-size:22px;font-weight:900;display:grid;box-shadow:0 18px 28px #e8a04c2e}.fd-settings-list button{border:1px solid var(--fd-border);color:#f4efe7b8;cursor:pointer;background:#ffffff06;border-radius:14px;justify-content:space-between;align-items:center;padding:12px;font-size:11px;display:flex}.fd-settings-list span{color:var(--fd-amber);font-size:16px}.fd-brand{letter-spacing:-.04em;color:var(--fd-amber);font-size:15px;font-weight:700}.fd-streak-chip{background:var(--fd-amber-soft);border:1px solid #e8a04c47;border-radius:999px;padding:4px 8px;font-size:9px;font-weight:600}.fd-chip-jump,.fd-flow-strip button{appearance:none;cursor:pointer;font-family:var(--mono)}.fd-chip-jump{border:1px solid var(--fd-border);color:#f5f5f7b3;background:#ffffff0a;border-radius:999px;padding:4px 8px;font-size:8px}.fd-flow-strip{scrollbar-width:none;flex-shrink:0;gap:4px;display:flex;overflow-x:auto}.fd-flow-strip::-webkit-scrollbar{display:none}.fd-flow-strip button{border:1px solid var(--fd-border);color:#f5f5f770;background:#ffffff08;border-radius:999px;flex:none;width:24px;height:20px;font-size:7px}.fd-flow-strip button.done{color:#f5f5f7c7}.fd-flow-strip button.active{color:#1a0f00;background:var(--fd-amber);border-color:var(--fd-amber)}.fd-screen-center{text-align:center;justify-content:center;align-items:center;min-height:100%}.fd-splash-logo{letter-spacing:-.05em;color:var(--fd-amber);font-size:34px;font-weight:700}.fd-splash-tag{color:#a0a0a8;margin:6px 0 0;font-size:11px}.fd-loading-dots{gap:5px;margin-top:28px;display:flex}.fd-loading-dots i{background:var(--fd-amber);border-radius:50%;width:6px;height:6px;animation:1s ease-in-out infinite fd-dot}.fd-loading-dots i:nth-child(2){animation-delay:.15s}.fd-loading-dots i:nth-child(3){animation-delay:.3s}@keyframes fd-dot{0%,to{opacity:.25;transform:translateY(0)}50%{opacity:1;transform:translateY(-3px)}}.fd-onboarding-top{justify-content:flex-end;display:flex}.fd-onboarding-top button{color:#6a6a72;cursor:pointer;background:0 0;border:none;font-size:10px}.fd-detected-card,.fd-loop-card,.fd-tutor-bubble{border:1px solid var(--fd-border);background:var(--fd-card);border-radius:14px;padding:10px}.fd-detected-card{align-items:center;gap:10px;display:flex}.fd-detected-card .fd-mini-fret.compact{flex:0 0 52px;width:52px;height:56px;margin:0}.fd-mini-fret.compact{height:56px}.fd-mini-fret-empty{color:#6a6a72;place-items:center;font-size:12px;display:grid}.fd-chord-base-fret{font-family:var(--mono);color:#a0a0a8;z-index:2;font-size:7px;position:absolute;top:28%;left:2px}.fd-detected-card span{font-family:var(--mono);letter-spacing:.1em;color:var(--fd-amber);font-size:7px;display:block}.fd-detected-card strong{font-size:14px}.fd-detected-bar{background:#ffffff14;border-radius:999px;height:4px;margin-top:6px;overflow:hidden}.fd-detected-bar i{background:var(--fd-amber);height:100%;display:block}.fd-loop-bars{gap:6px;display:flex}.fd-loop-bars span{text-align:center;background:#ffffff0a;border-radius:8px;flex:1;padding:8px 0;font-size:10px}.fd-loop-bars span.active{background:var(--fd-amber-soft);color:var(--fd-amber)}.fd-loop-bars span.loop{border:1px dashed #e8a04c59}.fd-tempo-ramp{color:#a0a0a8;font-size:9px;font-family:var(--mono);margin-top:8px}.fd-tutor-bubble{color:#a0a0a8;align-items:flex-start;gap:8px;display:flex}.fd-tutor-bubble p{margin:0;font-size:9px;line-height:1.45}.fd-onboarding-copy span{font-family:var(--mono);letter-spacing:.1em;color:#6a6a72;font-size:8px}.fd-onboarding-copy h3{letter-spacing:-.03em;white-space:pre-line;margin:8px 0;font-size:16px;line-height:1.15}.fd-onboarding-copy h3 .amber{color:var(--fd-amber)}.fd-onboarding-copy p{color:#a0a0a8;margin:0;font-size:10px;line-height:1.5}.fd-onboarding-foot{justify-content:space-between;align-items:center;margin-top:auto;display:flex}.fd-onboarding-dots{gap:5px;display:flex}.fd-onboarding-dots button{cursor:pointer;background:#ffffff29;border:none;border-radius:999px;width:6px;height:6px;padding:0}.fd-onboarding-dots button.active{background:var(--fd-amber);width:16px}.fd-onboarding-next{background:var(--fd-amber);color:#1a0f00;cursor:pointer;border:none;border-radius:999px;width:44px;height:44px;font-size:22px}.fd-welcome-logo{align-items:center;gap:6px;margin-bottom:14px;display:inline-flex}.fd-welcome-logo i{background:var(--fd-amber);border-radius:3px;width:10px;height:22px}.fd-welcome-logo span{letter-spacing:-.04em;text-transform:lowercase;font-size:18px;font-weight:600}.fd-welcome h3{letter-spacing:-.03em;margin:0 0 8px;font-size:17px;line-height:1.2}.fd-welcome h3 span{color:var(--fd-amber)}.fd-welcome p{color:#a0a0a8;margin:0 0 14px;font-size:10px;line-height:1.5}.fd-social,.fd-primary-wide{cursor:pointer;border-radius:12px;width:100%;margin-bottom:8px;padding:10px;font-family:inherit;font-size:11px;font-weight:600}.fd-social.google{border:1px solid var(--fd-border);color:#111;background:#fff}.fd-social.facebook{border:1px solid var(--fd-border);color:#fff;background:#1877f2}.fd-primary-wide{background:var(--fd-amber);color:#1a0f00;border:none}.fd-link-btn{color:#a0a0a8;cursor:pointer;background:0 0;border:none;font-family:inherit;font-size:10px}.fd-screen-title{letter-spacing:-.03em;font-size:15px;font-weight:700}.fd-muted{color:#a0a0a8;margin:0;font-size:9px;line-height:1.45}.fd-form-group{margin-top:10px}.fd-form-group>span{color:#6a6a72;margin-bottom:6px;font-size:9px;display:block}.fd-chip-row{flex-wrap:wrap;gap:6px;display:flex}.fd-chip-row button{border:1px solid var(--fd-border);color:#a0a0a8;cursor:pointer;background:0 0;border-radius:999px;padding:6px 10px;font-family:inherit;font-size:9px}.fd-chip-row button.active{background:var(--fd-amber-soft);color:var(--fd-amber);border-color:#e8a04c59}.fd-wave-orb{background:radial-gradient(circle,#e8a04c59,#e8a04c0d 68%);border-radius:50%;width:88px;height:88px;margin-bottom:14px;box-shadow:0 0 40px #e8a04c33}.fd-session-card{border:1px solid var(--fd-border);background:linear-gradient(135deg, #1e1a12, var(--fd-card));border-radius:14px;padding:10px;box-shadow:0 8px 24px #e8a04c14}.fd-session-kicker{font-family:var(--mono);letter-spacing:.12em;color:var(--fd-amber);font-size:7px}.fd-session-card>strong{letter-spacing:-.02em;margin-top:6px;font-size:13px;display:block}.fd-session-card>p{color:#a0a0a8;margin:4px 0 8px;font-size:9px;line-height:1.4}.fd-step-row{scrollbar-width:none;gap:6px;margin-bottom:8px;display:flex;overflow-x:auto}.fd-step-row::-webkit-scrollbar{display:none}.fd-step-chip{border:1px solid var(--fd-border);text-align:left;cursor:pointer;min-width:52px;font:inherit;color:inherit;background:#ffffff08;border-radius:10px;flex:none;padding:6px}.fd-step-chip.selected,.fd-step-chip.done{background:var(--fd-amber-soft);border-color:#e8a04c66}.fd-step-chip b{color:var(--fd-amber);font-size:10px;display:block}.fd-step-chip span{color:#a0a0a8;font-size:8px}.fd-start-session{background:var(--fd-amber);color:#1a0f00;cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;gap:6px;width:100%;padding:9px;font-family:inherit;font-size:11px;font-weight:600;display:inline-flex}.fd-tabs.library{grid-template-columns:1fr 1fr;gap:6px;display:grid}.fd-tabs.library button{border:1px solid var(--fd-border);color:#a0a0a8;cursor:pointer;background:0 0;border-radius:999px;padding:7px;font-family:inherit;font-size:9px}.fd-tabs.library button.active{background:var(--fd-amber-soft);color:var(--fd-amber);border-color:#e8a04c59}.fd-library-grid{grid-template-columns:repeat(3,1fr);gap:6px;display:grid}.fd-library-chord{border:1px solid var(--fd-border);background:var(--fd-card);text-align:center;border-radius:10px;padding:6px}.fd-library-chord strong{font-size:10px}.fd-library-chord .fd-mini-fret{height:52px;margin-top:4px}.fd-strum-list{flex-direction:column;gap:6px;display:flex}.fd-strum-row{border:1px solid var(--fd-border);background:var(--fd-card);cursor:pointer;font:inherit;color:inherit;text-align:left;border-radius:10px;align-items:center;gap:8px;padding:8px;display:flex}.fd-strum-row strong{font-size:10px;display:block}.fd-strum-row span{color:#a0a0a8;font-size:8px}.fd-stats-grid{grid-template-columns:repeat(2,1fr);gap:6px;display:grid}.fd-stats-grid>div{border:1px solid var(--fd-border);background:var(--fd-card);border-radius:10px;padding:8px}.fd-stats-grid strong{color:var(--fd-amber);font-size:14px;display:block}.fd-stats-grid span{color:#a0a0a8;font-size:8px}.fd-summary-overlay{z-index:5;background:#0e0e10d1;justify-content:center;align-items:center;padding:12px;display:flex;position:absolute;inset:0}.fd-summary-card{border:1px solid var(--fd-border);background:var(--fd-card-strong);text-align:center;border-radius:14px;width:100%;padding:12px}.fd-summary-card>span{font-family:var(--mono);letter-spacing:.1em;color:var(--fd-amber);font-size:8px}.fd-summary-card>strong{margin:6px 0;font-size:14px;display:block}.fd-summary-stats{grid-template-columns:repeat(3,1fr);gap:6px;margin:8px 0;display:grid}.fd-summary-stats b{color:var(--fd-amber);font-size:16px;display:block}.fd-summary-stats span{color:#a0a0a8;font-size:8px}.fd-summary-card>p{color:#a0a0a8;margin:0 0 10px;font-size:8px;line-height:1.4}.fd-summary-actions{gap:6px;display:flex}.fd-summary-actions button{border:1px solid var(--fd-border);color:#f5f5f7;cursor:pointer;background:0 0;border-radius:10px;flex:1;padding:8px;font-family:inherit;font-size:10px}.fd-summary-actions button.primary{background:var(--fd-amber);color:#1a0f00;border-color:var(--fd-amber);font-weight:600}.fd-api-links{flex-wrap:wrap;gap:10px;margin-top:18px;display:flex}.backend-case.fret{background:radial-gradient(520px 260px at 18% 0,#e8a04c1f,#0000 72%),#ffffff02}.backend-case.fret .backend-flow span,.backend-case.fret .backend-card span{color:#e8a04c}.fd-bottom-nav{z-index:1;border-top:1px solid var(--fd-border);background:#16161af5;flex:none;grid-template-columns:repeat(5,1fr);gap:0;min-height:48px;margin:0 -10px -6px;padding:4px 4px 3px;display:grid;position:relative}.fd-bottom-nav button{color:#6a6a72;cursor:pointer;font-family:var(--font);background:0 0;border:none;flex-direction:column;align-items:center;gap:2px;min-width:0;padding:2px 0;display:flex}.fd-bottom-nav b{text-overflow:ellipsis;white-space:nowrap;max-width:100%;font-size:6px;font-weight:500;overflow:hidden}.fd-bottom-nav button.active{color:var(--fd-amber)}.fd-bottom-nav button.active svg{filter:drop-shadow(0 0 6px #e8a04c73)}.fd-session-screen{flex-direction:column;flex:1;gap:6px;min-height:0;display:flex;overflow:hidden}.fd-strum-board,.fd-practice-card,.fd-scale-panel,.fd-pick-panel{flex-shrink:1;min-height:0}.fd-slot-grid{grid-template-columns:repeat(16,minmax(0,1fr));gap:2px;display:grid}.fd-scroll{-webkit-overflow-scrolling:touch;flex:1;min-height:0;position:relative;overflow:hidden auto}.mini-art{flex-direction:column;gap:10px;height:100%;padding:18px 16px;display:flex}.mini-art .mini-h{color:var(--text-faint);font-size:11px}.mini-art .mini-t{letter-spacing:-.02em;font-size:15px;font-weight:600}.mini-art .mini-bar{border:1px solid var(--border);height:36px;color:var(--text-dim);background:#ffffff05;border-radius:9px;align-items:center;gap:8px;padding:0 10px;font-size:10px;display:flex}.mini-art .mini-bar .mb-dot{border:1.5px solid var(--text-faint);border-radius:50%;width:10px;height:10px}.mini-art .mini-bar.done .mb-dot{background:var(--accent);border-color:var(--accent)}.mini-art .mini-bar.done{opacity:.5}.mini-art .mini-bar.done span{text-decoration:line-through}.mini-fret-art{--mf-amber:#e8a04c;color:#f5f5f7;background:#0e0e10;flex-direction:column;gap:7px;height:100%;padding:14px 11px 12px;display:flex}.mini-fret-top{justify-content:space-between;align-items:center;display:flex}.mini-fret-brand{letter-spacing:-.04em;color:var(--mf-amber);font-size:13px}.mini-fret-streak{border:1px solid #e8a04c59;border-radius:999px;padding:2px 6px;font-size:8px}.mini-fret-session{background:linear-gradient(135deg,#1e1a12,#16161a);border:1px solid #ffffff14;border-radius:12px;padding:8px}.mini-fret-session>span{font-family:var(--mono);letter-spacing:.1em;color:var(--mf-amber);font-size:6px;display:block}.mini-fret-session>strong{letter-spacing:-.02em;margin-top:4px;font-size:10px;display:block}.mini-fret-steps{gap:4px;margin-top:6px;display:flex}.mini-fret-steps em{text-align:center;color:#a0a0a8;border:1px solid #ffffff14;border-radius:6px;flex:1;padding:4px 0;font-size:7px;font-style:normal}.mini-fret-steps em.on{color:var(--mf-amber);background:#e8a04c24;border-color:#e8a04c59}.mini-fret-detected{background:#16161a;border:1px solid #ffffff14;border-radius:10px;padding:7px 8px}.mini-fret-detected span{font-family:var(--mono);letter-spacing:.1em;color:var(--mf-amber);font-size:6px;display:block}.mini-fret-detected strong{margin-top:2px;font-size:11px;display:block}.mini-fret-tabs{grid-template-columns:repeat(5,1fr);gap:3px;margin-top:auto;display:grid}.mini-fret-tabs span{text-align:center;color:#6a6a72;border:1px solid #ffffff14;border-radius:999px;padding:4px 0;font-size:6px}.mini-fret-tabs span.active{color:#1a0f00;background:var(--mf-amber);border-color:var(--mf-amber);font-weight:700}.cg-api-links{flex-wrap:wrap;gap:10px;margin-top:18px;display:flex}.backend-case.cinego{background:radial-gradient(520px 260px at 18% 0,#f85a211f,#0000 72%),radial-gradient(520px 260px at 100% 10%,#ff703312,#0000 76%),#ffffff02}.backend-case.cinego .backend-flow span,.backend-case.cinego .backend-card span{color:#f85a21}.mini-cinego-art{--cg-accent:#f85a21;--cg-accent-soft:#f85a2124;color:#f5f5f5;background:#1a1a1a;flex-direction:column;gap:10px;height:100%;padding:16px 13px 14px;display:flex}.mini-cinego-header{justify-content:space-between;align-items:center;display:flex}.mini-cinego-header strong{letter-spacing:-.03em;font-size:14px}.mini-cinego-live{background:var(--cg-accent-soft);color:var(--cg-accent);font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;border:1px solid #f85a2157;border-radius:999px;padding:3px 7px;font-size:7px}.mini-cinego-feature{cursor:default;min-height:72px;font:inherit;color:inherit;text-align:left;background:#2b2b2b;border:1px solid #ffffff14;border-radius:14px;padding:0;position:relative;overflow:hidden}.mini-cinego-feature img{object-fit:cover;width:100%;height:100%;display:block;position:absolute;inset:0}.mini-cinego-feature-copy{z-index:1;background:linear-gradient(#0000 20%,#1a1a1aeb);flex-direction:column;justify-content:flex-end;min-height:72px;padding:10px 12px;display:flex;position:relative}.mini-cinego-feature span{color:#f5f5f58f;font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;font-size:7px}.mini-cinego-feature strong{letter-spacing:-.03em;margin-top:4px;font-size:12px;display:block}.mini-cinego-section-label{letter-spacing:-.01em;color:#f7f5f0d1;font-size:10px;font-weight:600}.mini-cinego-row{flex:1;grid-template-columns:repeat(3,1fr);align-content:start;gap:6px;min-height:0;display:grid}.mini-cinego-card{flex-direction:column;gap:4px;min-width:0;display:flex}.mini-cinego-poster{aspect-ratio:2/3;object-fit:cover;background:#2b2b2b;border:1px solid #ffffff14;border-radius:10px;width:100%;display:block}.mini-cinego-card strong{letter-spacing:-.02em;white-space:nowrap;text-overflow:ellipsis;font-size:8px;overflow:hidden}.mini-cinego-card span{color:#f7f5f075;font-size:7px}.mini-cinego-tabs{grid-template-columns:repeat(3,1fr);gap:4px;margin-top:auto;display:grid}.mini-cinego-tabs span{text-align:center;color:#f7f5f075;background:#ffffff05;border:1px solid #ffffff14;border-radius:999px;padding:5px 0;font-size:7px}.mini-cinego-tabs span.active{color:#fff;border-color:var(--cg-accent);background:var(--cg-accent);font-weight:700}.cg-body{--cg-accent:#f85a21;--cg-accent-strong:#ff6b38;--cg-accent-soft:#f85a2129;--cg-green:#22c55e;--cg-red:#ef4444;--cg-card:#2b2b2bf0;--cg-card-strong:#1a1a1af5;--cg-border:#ffffff14;color:#f5f5f5;background:#1a1a1a;flex-direction:column;flex:1;gap:10px;min-height:0;padding:14px 12px 10px;display:flex;position:relative;overflow:hidden}.cg-bg{display:none}.cg-top,.cg-scroll,.cg-bottom-nav{z-index:1;position:relative}.cg-top{justify-content:space-between;align-items:flex-start;gap:10px;display:flex}.cg-kicker,.cg-micro{font-family:var(--mono);text-transform:uppercase;letter-spacing:.12em;color:#f7f5f07a;font-size:8px}.cg-title{letter-spacing:-.035em;margin-top:2px;font-size:17px;font-weight:700;line-height:1.08}.cg-chip-live{appearance:none;color:var(--cg-accent);background:var(--cg-accent-soft);font-size:8px;font-family:var(--mono);cursor:pointer;white-space:nowrap;border:1px solid #f85a2147;border-radius:999px;align-items:center;gap:5px;padding:5px 8px;display:inline-flex}.cg-flow-strip{z-index:1;scrollbar-width:none;gap:6px;padding-bottom:2px;display:flex;position:relative;overflow-x:auto}.cg-flow-strip::-webkit-scrollbar{display:none}.cg-flow-strip button{border:1px solid var(--cg-border);color:#f7f5f070;width:28px;height:24px;font-family:var(--mono);cursor:pointer;background:#ffffff07;border-radius:999px;flex:none;font-size:8px}.cg-flow-strip button.done{color:#f7f5f0c7;border-color:#ffffff1f}.cg-flow-strip button.active{color:#fff;border-color:var(--cg-accent);background:var(--cg-accent)}.cg-scroll{scrollbar-width:none;flex:1;min-height:0;padding:0 2px 2px;overflow-y:auto}.cg-scroll::-webkit-scrollbar{width:0;height:0}.cg-screen{flex-direction:column;gap:10px;min-height:100%;display:flex}.cg-screen-center{justify-content:center}.cg-auth-hero,.cg-form-card,.cg-success-card,.cg-feature-card,.cg-movie-card,.cg-info-card,.cg-cinema-card,.cg-hold-bar,.cg-seat-footer,.cg-ticket-card,.cg-profile-card,.cg-menu-list button,.cg-quick-row button{border:1px solid var(--cg-border);background:var(--cg-card);box-shadow:0 18px 34px #0000003d}.cg-auth-hero,.cg-success-card,.cg-profile-card,.cg-splash-card,.cg-onboarding-card,.cg-cinema-banner,.cg-alert-card{border-radius:17px;padding:13px}.cg-auth-hero{background:linear-gradient(135deg, #f85a212e, #ffffff05), var(--cg-card);grid-template-columns:40px 1fr;align-items:start;gap:10px;display:grid}.cg-mark,.cg-success-badge,.cg-avatar{color:#130e08;background:linear-gradient(180deg, var(--cg-accent-strong), var(--cg-accent));border-radius:12px;place-items:center;width:38px;height:38px;font-weight:800;display:grid;box-shadow:0 8px 16px #f85a2133}.cg-auth-hero strong,.cg-greeting h3,.cg-detail-overlay strong,.cg-ticket-head strong,.cg-profile-card strong{letter-spacing:-.02em;margin-top:3px;font-size:14px;display:block}.cg-auth-hero p,.cg-greeting p,.cg-detail-overlay p,.cg-info-card p,.cg-success-card p,.cg-splash-card p,.cg-onboarding-card p,.cg-ticket-card p{color:#f7f5f0a1;margin:6px 0 0;font-size:10px;line-height:1.55}.cg-splash-card,.cg-onboarding-card,.cg-cinema-banner,.cg-alert-card{border:1px solid var(--cg-border);background:var(--cg-card);box-shadow:0 18px 34px #0000003d}.cg-splash-card{text-align:center;background:radial-gradient(circle at 50% 0%, #f85a212e, transparent 45%), var(--cg-card-strong);place-items:center;gap:8px;min-height:220px;display:grid}.cg-splash-card strong,.cg-onboarding-card strong,.cg-alert-card strong{letter-spacing:-.04em;font-size:18px}.cg-loader{background:linear-gradient(90deg,#ffffff14,#f85a21cc,#ffffff14);border-radius:999px;width:64px;height:4px}.cg-onboarding-card{flex-direction:column;justify-content:flex-end;min-height:176px;display:flex}.cg-page-dots{justify-content:center;gap:8px;display:flex}.cg-page-dots button{cursor:pointer;background:#ffffff2e;border:none;border-radius:999px;width:8px;height:8px}.cg-page-dots button.active{background:linear-gradient(180deg, var(--cg-accent-strong), var(--cg-accent));width:28px}.cg-auth-steps{grid-template-columns:repeat(3,1fr);gap:6px;display:grid}.cg-auth-step{border:1px solid var(--cg-border);background:#ffffff06;border-radius:13px;padding:10px 9px}.cg-auth-step span{color:#f7f5f06b;font-family:var(--mono);font-size:8px;display:block}.cg-auth-step strong{color:#f7f5f0c7;margin-top:5px;font-size:10px;line-height:1.35;display:block}.cg-auth-step.active{background:#f85a2114;border-color:#f85a2157}.cg-auth-step.active span,.cg-auth-step.done span{color:var(--cg-accent)}.cg-auth-step.done{background:#ffffff08}.cg-form-card{border-radius:16px;flex-direction:column;gap:9px;padding:12px;display:flex}.cg-form-card label{color:#f7f5f080;text-transform:uppercase;letter-spacing:.12em;font-size:9px;font-family:var(--mono);flex-direction:column;gap:5px;display:flex}.cg-form-card label div{color:#f7f5f0c7;min-height:38px;font-family:var(--font);letter-spacing:normal;text-transform:none;background:#ffffff06;border:1px solid #ffffff12;border-radius:12px;align-items:center;padding:0 11px;font-size:11px;display:flex}.cg-otp-row{grid-template-columns:repeat(6,1fr);gap:6px;display:grid}.cg-otp-row span{height:40px;color:var(--cg-accent);background:#f85a2114;border:1px solid #f85a2138;border-radius:11px;place-items:center;font-size:13px;font-weight:700;display:grid}.cg-auth-note{color:#f7f5f080;font-size:9px;font-family:var(--mono);background:#ffffff06;border-radius:11px;padding:10px 11px;line-height:1.45}.cg-success-card{grid-template-columns:40px 1fr;align-items:start;gap:10px;display:grid}.cg-success-badge{width:34px;height:34px}.cg-success-card strong,.cg-greeting strong,.cg-section-head strong,.cg-info-card strong,.cg-seat-footer strong{letter-spacing:-.02em;font-size:13px;display:block}.cg-actions{justify-content:flex-end;gap:8px;margin-top:auto;display:flex}.cg-actions button,.cg-seat-footer button,.cg-feature-card button{appearance:none;border:1px solid var(--cg-border);cursor:pointer;border-radius:12px;height:38px;padding:0 14px;font-size:11px;font-weight:700}.cg-actions .primary,.cg-seat-footer button,.cg-feature-card button{border-color:var(--cg-accent);color:#fff;background:var(--cg-accent)}.cg-actions .ghost{color:#f7f5f0c2;background:#ffffff07}.cg-oauth-list,.cg-chip-grid{flex-wrap:wrap;gap:8px;display:flex}.cg-oauth-list button,.cg-chip-grid button{appearance:none;border:1px solid var(--cg-border);background:var(--cg-card);color:#f7f5f0cc;cursor:pointer;border-radius:999px;min-height:38px;padding:0 14px;font-size:10px;box-shadow:0 18px 34px #0000003d}.cg-oauth-list button{justify-content:center;width:100%}.cg-chip-grid button.active{color:#fff;border-color:var(--cg-accent);background:var(--cg-accent)}.cg-greeting h3{letter-spacing:-.045em;margin:4px 0 0;font-size:23px;line-height:1.08}.cg-greeting p{margin-top:4px}.cg-feature-card{background-blend-mode:screen, normal;border-radius:17px;flex-direction:column;justify-content:flex-end;gap:4px;min-height:96px;padding:13px;display:flex}.cg-feature-card span,.cg-ticket-head span{color:#f7f5f08a;font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;font-size:8px}.cg-feature-card strong{letter-spacing:-.03em;font-size:15px;display:block}.cg-feature-card p{color:#f7f5f0a3;margin:0;font-size:10px;line-height:1.45}.cg-feature-card button{width:fit-content;margin-top:7px}.cg-section-head,.cg-subnav,.cg-cinema-head,.cg-ticket-head{justify-content:space-between;align-items:center;gap:10px;display:flex}.cg-section-head button,.cg-subnav button,.cg-menu-list button b{color:var(--cg-accent);font-family:var(--mono);cursor:pointer;background:0 0;border:none;font-size:9px}.cg-home-screen{gap:12px}.cg-home-topbar{justify-content:space-between;align-items:center;gap:10px;display:flex}.cg-home-user{align-items:center;gap:8px;min-width:0;display:flex}.cg-home-user strong{letter-spacing:-.02em;white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.cg-home-avatar{background:#2b2b2b;border:1px solid #ffffff14;border-radius:50%;flex:none;width:34px;height:34px}.cg-home-bell{cursor:pointer;background:#2b2b2b;border:1px solid #555c;border-radius:50%;width:34px;height:34px;position:relative}.cg-home-bell-dot{background:var(--cg-accent);border-radius:50%;width:7px;height:7px;position:absolute;top:7px;right:7px}.cg-featured-pager{border:1px solid var(--cg-border);cursor:pointer;background:#2b2b2b;border-radius:16px;width:100%;height:108px;padding:0;position:relative;overflow:hidden}.cg-featured-pager img{object-fit:cover;width:100%;height:100%;display:block}.cg-featured-gradient{pointer-events:none;background:linear-gradient(#0000 35%,#1a1a1ad1);position:absolute;inset:0}.cg-featured-dots{pointer-events:none;justify-content:center;gap:8px;display:flex;position:absolute;bottom:10px;left:0;right:0}.cg-featured-dots span{background:#ffb899;border-radius:50%;width:8px;height:8px}.cg-featured-dots span.active{background:var(--cg-accent)}.cg-movie-row{scrollbar-width:none;gap:10px;padding-bottom:2px;display:flex;overflow-x:auto}.cg-movie-row::-webkit-scrollbar{display:none}.cg-movie-card-vertical{flex-direction:column;flex:0 0 88px;gap:6px;min-width:0;display:flex}.cg-movie-card-vertical.active .cg-movie-poster-btn img{box-shadow:0 0 0 1px var(--cg-accent)}.cg-movie-poster-btn{cursor:pointer;background:0 0;border:none;padding:0}.cg-movie-poster-btn img{object-fit:cover;background:#2b2b2b;border:1px solid #ffffff14;border-radius:16px;width:88px;height:118px;display:block}.cg-movie-card-vertical strong{letter-spacing:.04em;white-space:nowrap;text-overflow:ellipsis;font-size:8px;overflow:hidden}.cg-book-btn,.cg-watchlist-btn{appearance:none;cursor:pointer;border-radius:20px;height:26px;padding:0 10px;font-size:8px;font-weight:600}.cg-book-btn{border:1px solid var(--cg-accent);color:var(--cg-accent);background:0 0}.cg-watchlist-btn{color:#f5f5f5b8;background:0 0;border:1px solid #55555580}.cg-movie-list,.cg-cinema-list,.cg-menu-list{flex-direction:column;gap:7px;display:flex}.cg-movie-card{appearance:none;text-align:left;width:100%;color:inherit;font:inherit;cursor:pointer;border-radius:15px;grid-template-columns:50px 1fr auto;align-items:center;gap:10px;padding:9px;display:grid}.cg-movie-card.active{background:#f85a210f;border-color:#f85a2157}.cg-poster,.cg-poster img{aspect-ratio:3/4;object-fit:cover;background:#2b2b2b;border:1px solid #ffffff14;border-radius:12px;display:block}.cg-movie-card strong{font-size:11px;line-height:1.25;display:block}.cg-movie-card span,.cg-info-card span:not(.cg-micro),.cg-profile-card span,.cg-menu-list button span,.cg-seat-footer span{color:#f7f5f075;margin-top:3px;font-size:9px;line-height:1.45;display:block}.cg-movie-card b,.cg-cinema-head b,.cg-ticket-head b,.cg-hold-bar b{color:var(--cg-accent);font-family:var(--mono);font-size:9px}.cg-quick-row{grid-template-columns:repeat(2,1fr);gap:7px;display:grid}.cg-quick-row button{appearance:none;color:#f7f5f0b8;cursor:pointer;border-radius:13px;justify-content:center;align-items:center;gap:6px;min-height:42px;font-size:10px;display:inline-flex}.cg-subnav{min-height:34px}.cg-subnav span{font-size:10px;font-family:var(--mono);color:#f7f5f094}.cg-subnav button{border:1px solid var(--cg-border);background:#ffffff07;border-radius:10px;place-items:center;width:30px;height:30px;display:grid}.cg-detail-hero{border:1px solid var(--cg-border);background:#2b2b2b;border-radius:16px;min-height:132px;position:relative;overflow:hidden}.cg-detail-hero>img{object-fit:cover;width:100%;height:100%;display:block;position:absolute;inset:0}.cg-detail-overlay{z-index:1;background:linear-gradient(#1a1a1a14,#1a1a1aeb);grid-template-columns:54px 1fr;align-items:end;gap:10px;min-height:132px;padding:12px;display:grid;position:relative}.cg-detail-poster{object-fit:cover;background:#2b2b2b;border:1px solid #ffffff14;border-radius:12px;width:54px;height:78px;display:block}.cg-detail-overlay span{font-size:8px;font-family:var(--mono);background:#1a1a1a6b;border:1px solid #ffffff29;border-radius:999px;padding:4px 7px;display:inline-flex}.cg-detail-overlay strong{letter-spacing:-.02em;margin-top:6px;font-size:13px;display:block}.cg-detail-overlay p{color:#f5f5f59e;margin:4px 0 0;font-size:9px;line-height:1.45}.cg-meta-grid{grid-template-columns:repeat(3,1fr);gap:7px;display:grid}.cg-meta-grid div{border:1px solid var(--cg-border);color:#f7f5f0ad;background:#ffffff06;border-radius:13px;justify-content:center;align-items:center;gap:5px;min-height:40px;font-size:9px;display:flex}.cg-info-card,.cg-ticket-card{border-radius:16px;padding:12px}.cg-date-strip,.cg-time-row{scrollbar-width:none;gap:6px;display:flex;overflow-x:auto}.cg-date-strip::-webkit-scrollbar{display:none}.cg-time-row::-webkit-scrollbar{display:none}.cg-date-strip button,.cg-time-row button{border:1px solid var(--cg-border);color:#f7f5f0ad;cursor:pointer;background:#ffffff06;border-radius:999px;flex:none;min-width:52px;height:34px;font-size:9px}.cg-date-strip button.active,.cg-time-row button.active{color:#fff;border-color:var(--cg-accent);background:var(--cg-accent);font-weight:700}.cg-cinema-card{border-radius:16px;padding:11px}.cg-cinema-card.active{background:#f85a210e;border-color:#f85a2157}.cg-cinema-banner{flex-direction:column;gap:5px;display:flex}.cg-cinema-banner span{color:#f7f5f07a;align-items:center;gap:5px;font-size:9px;display:inline-flex}.cg-cinema-head strong{font-size:12px;display:block}.cg-cinema-head span{color:#f7f5f07a;align-items:center;gap:5px;margin-top:4px;font-size:9px;display:inline-flex}.cg-hold-bar{border-radius:15px;justify-content:space-between;align-items:center;padding:11px 12px;display:flex}.cg-screen-arch{color:#f7f5f057;width:78%;min-height:20px;font-family:var(--mono);letter-spacing:.16em;background:linear-gradient(#ffffff1f,#ffffff05);border:1px solid #ffffff14;border-radius:999px 999px 10px 10px;place-items:center;margin:3px auto 0;font-size:8px;display:grid}.cg-seat-map{border:1px solid var(--cg-border);background:radial-gradient(140px 100px at 50% 0,#f85a2114,#0000 72%),#ffffff06;border-radius:18px;flex-direction:column;gap:6px;padding:12px 10px;display:flex}.cg-seat-row{grid-template-columns:16px repeat(10,1fr);align-items:center;gap:5px;display:grid}.cg-seat-row span{color:#f7f5f066;font-family:var(--mono);font-size:8px}.cg-seat{aspect-ratio:1;color:#f7f5f08c;cursor:pointer;background:#ffffff08;border:1px solid #ffffff14;border-radius:8px 8px 4px 4px;font-size:8px}.cg-seat.selected{color:#fff;border-color:var(--cg-accent);background:var(--cg-accent)}.cg-seat.taken{cursor:default;color:#f7f5f040;background:#ffffff03}.cg-seat-legend{color:#f7f5f075;font-size:8px;font-family:var(--mono);justify-content:space-between;gap:6px;display:flex}.cg-seat-legend span{align-items:center;gap:5px;display:inline-flex}.cg-seat-legend i{border:1px solid #ffffff14;border-radius:3px;width:9px;height:9px;display:inline-block}.cg-seat-legend .available{background:#ffffff08}.cg-seat-legend .selected{background:var(--cg-accent);border-color:var(--cg-accent)}.cg-seat-legend .taken{background:#ffffff03}.cg-seat-footer{border-radius:16px;grid-template-columns:1fr auto;align-items:center;gap:10px;padding:11px 12px;display:grid}.cg-alert-card{background:linear-gradient(135deg, #f59e0b2e, #ffffff08), var(--cg-card);justify-content:space-between;align-items:center;gap:10px;display:flex}.cg-alert-card span{color:var(--cg-accent);font-family:var(--mono);font-size:11px}.cg-ticket-card-accent{background:linear-gradient(180deg, #f85a212e, #ffffff08), var(--cg-card)}.cg-ticket-head{align-items:start}.cg-ticket-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-top:12px;display:grid}.cg-ticket-grid div{background:#ffffff06;border:1px solid #ffffff12;border-radius:12px;padding:9px}.cg-ticket-grid span{color:#f7f5f06b;font-family:var(--mono);text-transform:uppercase;letter-spacing:.12em;font-size:8px;display:block}.cg-ticket-grid strong{margin-top:4px;font-size:11px;display:block}.cg-barcode{opacity:.92;background:repeating-linear-gradient(90deg,#f7f5f0e6 0 3px,#f7f5f02e 3px 5px);border-radius:10px;height:42px;margin-top:12px}.cg-profile-card{grid-template-columns:40px 1fr;align-items:center;gap:10px;display:grid}.cg-menu-list button{appearance:none;text-align:left;width:100%;color:inherit;font:inherit;cursor:pointer;border-radius:15px;grid-template-columns:1fr auto;align-items:center;gap:10px;padding:11px 12px;display:grid}.cg-menu-list button strong{font-size:11px;display:block}.cg-bottom-nav{border-top:1px solid var(--cg-border);background:#1a1a1a;flex-wrap:nowrap;flex:none;align-items:center;width:calc(100% + 24px);margin:0 -12px -10px;padding:7px 0 6px;display:flex}.cg-bottom-nav button{color:#f7f5f05c;cursor:pointer;min-width:0;font-family:var(--font);background:0 0;border:none;flex-direction:column;flex:1 1 0;justify-content:center;align-items:center;gap:2px;padding:0;display:flex}.cg-bottom-nav span{border:1px solid #f7f5f017;border-radius:7px;flex-shrink:0;place-items:center;width:18px;height:18px;font-size:7px;display:grid}.cg-bottom-nav b{white-space:nowrap;text-overflow:ellipsis;max-width:100%;font-size:7px;font-weight:500;line-height:1;overflow:hidden}.cg-bottom-nav button.active{color:var(--cg-accent)}.cg-bottom-nav button.active span{color:#fff;background:var(--cg-accent);border-color:var(--cg-accent)}.mini-fret-card{padding:10px}.mini-fret-card-head{justify-content:space-between;gap:6px;margin-bottom:8px;display:flex}.mini-fret-card-head span{font-size:10px;font-weight:650}.mini-fret-card-head b{color:var(--mf-green);font-size:10px}.mini-fret-strings{background:#0000002e;border-radius:10px;height:82px;position:relative;overflow:hidden}.mini-fret-strings i{background:linear-gradient(90deg,#0000,#f4efe74d,#0000);height:1px;position:absolute;left:7px;right:7px}.mini-fret-strings i:first-child{height:1.6px;top:14px}.mini-fret-strings i:nth-child(2){height:1.4px;top:25px}.mini-fret-strings i:nth-child(3){top:36px}.mini-fret-strings i:nth-child(4){top:47px}.mini-fret-strings i:nth-child(5){top:58px}.mini-fret-strings i:nth-child(6){top:69px}.mini-fret-strings em{color:#17100a;background:var(--mf-amber);border-radius:50%;place-items:center;width:18px;height:18px;font-size:12px;font-style:normal;font-weight:900;display:grid;position:absolute;transform:translate(-50%,-50%);box-shadow:0 0 0 3px #e8a04c21}.mini-fret-strings em.bass{top:25px}.mini-fret-strings em.top{top:60px}.mini-fret-skill{flex-direction:column;gap:6px;margin-top:auto;display:flex}.mini-fret-skill div{grid-template-columns:44px 1fr;align-items:center;gap:7px;display:grid}.mini-fret-skill span{color:#f4efe773;font-family:var(--mono);font-size:7px}.mini-fret-skill i{background:linear-gradient(90deg, var(--mf-amber), var(--mf-green));border-radius:999px;height:5px}.about-grid{grid-template-columns:1fr 1fr;align-items:start;gap:60px;display:grid}@media (width<=860px){.about-grid{grid-template-columns:1fr}}.about-copy p{color:var(--text-dim);margin:0 0 18px;font-size:16px;line-height:1.7}.about-copy p strong{color:var(--text);font-weight:500}.about-stats{border:1px solid var(--border);border-radius:var(--radius-lg);grid-template-columns:1fr 1fr;gap:0;display:grid;overflow:hidden}.about-stat{border-right:1px solid var(--border);border-bottom:1px solid var(--border);padding:24px 22px}.about-stat:nth-child(2n){border-right:none}.about-stat:nth-last-child(-n+2){border-bottom:none}.about-stat .num{letter-spacing:-.02em;margin-bottom:4px;font-size:28px;font-weight:600}.about-stat .num em{color:var(--accent);font-style:normal}.about-stat .lbl{color:var(--text-faint);font-size:12px}.tool-row{flex-wrap:wrap;gap:8px;margin-top:20px;display:flex}.cert-block{border-top:1px solid var(--border);margin-top:80px;padding-top:60px}.cert-head{max-width:720px;margin-bottom:32px}.cert-title{letter-spacing:-.02em;margin:6px 0 8px;font-size:clamp(24px,2.6vw,32px);font-weight:500}.cert-lede{color:var(--text-dim);margin:0;font-size:14px;line-height:1.6}.cert-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px;display:grid}.cert-card{appearance:none;border:1px solid var(--border);text-align:left;cursor:pointer;font:inherit;color:inherit;background:#ffffff03;border-radius:14px;flex-direction:column;padding:0;transition:all .25s;display:flex;overflow:hidden}.cert-card:hover{border-color:var(--accent-line);background:#ffffff06;transform:translateY(-2px)}.cert-thumb{aspect-ratio:4/3;border-bottom:1px solid var(--border);background:#ffffff0a;overflow:hidden}.cert-thumb img{object-fit:cover;object-position:center;width:100%;height:100%;transition:transform .35s;display:block}.cert-card:hover .cert-thumb img{transform:scale(1.04)}.cert-meta{padding:14px 16px 16px}.cert-card-title{color:var(--text);letter-spacing:-.005em;margin-bottom:4px;font-size:14px;font-weight:500}.cert-card-issuer{color:var(--text-dim);margin-bottom:2px;font-size:12px}.cert-card-date{color:var(--text-faint);font-size:11px;font-family:var(--mono)}.cert-modal{z-index:200;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000000d9;place-items:center;padding:24px;animation:.2s certfade;display:grid;position:fixed;inset:0}@keyframes certfade{0%{opacity:0}to{opacity:1}}.cert-modal-inner{flex-direction:column;gap:14px;width:100%;max-width:1100px;max-height:90vh;display:flex;position:relative}.cert-modal-inner img{object-fit:contain;border-radius:10px;max-width:100%;max-height:80vh;box-shadow:0 30px 80px #0009}.cert-modal-meta{text-align:center;color:var(--text-dim);font-size:13px}.cert-modal-title{color:var(--text);margin-bottom:4px;font-size:16px;font-weight:500}.cert-modal-close{width:32px;height:32px;color:var(--text);cursor:pointer;background:#ffffff14;border:1px solid #ffffff24;border-radius:50%;place-items:center;font-size:18px;line-height:1;transition:all .2s;display:grid;position:absolute;top:-38px;right:0}.cert-modal-close:hover{background:#ffffff29}.contact-card{border:1px solid var(--border);text-align:center;background:radial-gradient(600px 300px at 50% -50%, #a78bfa1f, transparent 70%), var(--bg-card);border-radius:22px;padding:60px 48px;position:relative;overflow:hidden}.contact-card:before{content:"";pointer-events:none;background-image:linear-gradient(90deg,#ffffff08 1px,#0000 1px),linear-gradient(#ffffff08 1px,#0000 1px);background-size:36px 36px;position:absolute;inset:0;-webkit-mask-image:radial-gradient(at 50% 0,#000 40%,#0000 85%);mask-image:radial-gradient(at 50% 0,#000 40%,#0000 85%)}.contact-card>*{position:relative}.contact-card h2{letter-spacing:-.03em;margin:0 0 14px;font-size:clamp(30px,4vw,44px);font-weight:600;line-height:1.1}.contact-card p{color:var(--text-dim);max-width:460px;margin:0 auto 32px}.contact-email{color:#0a0a0a;text-align:center;overflow-wrap:anywhere;word-break:break-word;box-sizing:border-box;background:#fff;border-radius:12px;justify-content:center;align-items:center;gap:10px;width:min(100%,520px);max-width:100%;margin:0 auto;padding:14px clamp(14px,4vw,22px);font-size:clamp(13px,3.2vw,15px);font-weight:600;line-height:1.35;transition:transform .2s,box-shadow .2s;display:inline-flex}.contact-email svg{flex-shrink:0}.contact-email:hover{transform:translateY(-1px);box-shadow:0 10px 28px #00000038}.contact-links{color:var(--text-dim);flex-wrap:wrap;justify-content:center;gap:16px 22px;margin-top:26px;font-size:13px;display:flex}@media (width<=720px){.contact-card{padding:44px 24px}.contact-card h2{font-size:clamp(26px,7vw,36px)}.contact-card p{margin-bottom:24px;padding:0 4px}.contact-email{width:100%;padding:16px 18px}.contact-links{gap:12px 18px}}@media (width<=420px){.contact-card{padding:36px 16px}.contact-email{flex-direction:column;gap:8px;padding:14px 12px;font-size:13px}}.contact-links a{align-items:center;gap:6px;transition:color .2s;display:inline-flex}.contact-links a:hover{color:var(--text)}.footer{border-top:1px solid var(--border);color:var(--text-faint);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:40px 0 60px;font-size:12px;display:flex}.footer .mono{font-family:var(--mono)}.backend-case.turningpoint{background:radial-gradient(520px 260px at 18% 0,#ff7a001f,#0000 72%),radial-gradient(520px 260px at 100% 10%,#ff9a4012,#0000 76%),#ffffff02}.backend-case.turningpoint .backend-flow span,.backend-case.turningpoint .backend-card span{color:#ff7a00}.tp-api-links{flex-wrap:wrap;gap:10px;margin-top:18px;display:flex}.mini-turningpoint-art{--tp-primary:#ff7a00;--tp-primary-soft:#ff7a0024;color:#404040;height:100%;font-family:"Poppins", var(--sans);background:#fff;flex-direction:column;gap:8px;padding:16px 13px 14px;display:flex}.mini-tp-header{justify-content:space-between;align-items:center;display:flex}.mini-tp-header strong{letter-spacing:-.03em;color:#404040;font-size:13px}.mini-tp-live{background:var(--tp-primary-soft);color:var(--tp-primary);font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;border:1px solid #ff7a0057;border-radius:999px;padding:3px 7px;font-size:7px}.mini-tp-hero{border:1px solid #e5e5e5;border-radius:12px;min-height:58px;position:relative;overflow:hidden}.mini-tp-hero img{object-fit:cover;width:100%;height:100%;position:absolute;inset:0}.mini-tp-hero>div{z-index:1;background:linear-gradient(#0000 10%,#ffffffeb);flex-direction:column;justify-content:flex-end;min-height:58px;padding:8px 10px;display:flex;position:relative}.mini-tp-hero span{color:#737373;font-size:7px}.mini-tp-hero strong{color:#404040;font-size:11px}.mini-tp-section-label{color:#404040;font-size:9px;font-weight:600}.mini-tp-row{gap:6px;display:flex;overflow:hidden}.mini-tp-card{background:#fafafa;border:1px solid #e5e5e5;border-radius:10px;flex:1;min-width:0;overflow:hidden}.mini-tp-card img{object-fit:cover;width:100%;height:34px;display:block}.mini-tp-card strong,.mini-tp-card span{padding:0 5px;display:block}.mini-tp-card strong{white-space:nowrap;text-overflow:ellipsis;margin-top:4px;font-size:8px;overflow:hidden}.mini-tp-card span{color:#737373;padding-bottom:5px;font-size:8px}.mini-tp-featured{background:#fafafa;border:1px solid #e5e5e5;border-radius:10px;align-items:center;gap:8px;padding:6px;display:flex}.mini-tp-featured img{object-fit:cover;border-radius:8px;width:34px;height:34px}.mini-tp-featured span{color:var(--tp-primary);font-size:7px;font-weight:600;display:block}.mini-tp-featured strong{font-size:9px}.mini-tp-tabs{gap:4px;margin-top:auto;display:flex}.mini-tp-tabs span{text-align:center;color:#737373;border:1px solid #0000;border-radius:999px;flex:1;padding:5px 2px;font-size:7px}.mini-tp-tabs span.active{color:#404040;background:var(--tp-primary-soft);border-color:#ff7a0047;font-weight:600}.tp-brand{color:var(--tp-primary,#ff7a00);font-family:Pacifico,cursive;font-size:18px;line-height:1.1}.tp-scroll-splash{margin:0 -10px;padding:0}.tp-screen-splash{gap:0;min-height:100%;padding:0}.tp-splash-gradient{color:#fff;text-align:center;background:linear-gradient(#ec320d 0%,#ff7a00 100%);flex-direction:column;justify-content:center;align-items:center;gap:6px;min-height:100%;padding:24px 16px;display:flex}.tp-splash-logo{object-fit:contain;width:88px;height:auto}.tp-splash-title{letter-spacing:-.02em;font-family:Pacifico,cursive;font-size:28px}.tp-splash-tag{opacity:.95;margin:0;font-size:14px;font-weight:500}.tp-splash-dots{gap:5px;margin-top:18px;display:flex}.tp-splash-dots i{background:#ffffff8c;border-radius:999px;width:6px;height:6px;animation:1.2s ease-in-out infinite tp-splash-pulse}.tp-splash-dots i:nth-child(2){animation-delay:.15s}.tp-splash-dots i:nth-child(3){animation-delay:.3s}@keyframes tp-splash-pulse{0%,to{opacity:.35;transform:scale(.85)}50%{opacity:1;transform:scale(1)}}.tp-screen-onboarding{gap:10px}.tp-onboarding-top{justify-content:flex-end;display:flex}.tp-onboarding-top button{color:var(--tp-text-dim);cursor:pointer;background:0 0;border:none;font-family:inherit;font-size:10px}.tp-onboarding-art{border:1px solid var(--tp-border);background:#fff;border-radius:14px;overflow:hidden}.tp-onboarding-art img{object-fit:cover;width:100%;height:120px;display:block}.tp-onboarding-copy strong{margin-bottom:4px;font-size:14px;line-height:1.2;display:block}.tp-onboarding-copy p{color:var(--tp-text-dim);margin:0;font-size:9px;line-height:1.45}.tp-onboarding-foot{justify-content:space-between;align-items:center;gap:8px;margin-top:auto;display:flex}.tp-onboarding-dots{gap:5px;display:flex}.tp-onboarding-dots button{cursor:pointer;background:#d4d4d4;border:none;border-radius:999px;width:6px;height:6px;padding:0}.tp-onboarding-dots button.active{background:var(--tp-primary);width:16px}.tp-onboarding-next{background:var(--tp-primary);color:#fff;cursor:pointer;border:none;border-radius:999px;padding:8px 14px;font-family:inherit;font-size:10px;font-weight:600}.tp-screen-welcome{text-align:center;align-items:center;padding-top:8px}.tp-screen-welcome h2{margin:0;font-size:18px;font-weight:400;line-height:1.2}.tp-welcome-brand{color:var(--tp-primary);margin-top:6px;font-family:Pacifico,cursive;font-size:22px}.tp-welcome-art img{width:100%;max-width:200px;height:auto;margin:10px auto 0;display:block}.tp-auth-actions{flex-direction:column;gap:8px;width:100%;margin-top:auto;display:flex}.tp-auth-primary{width:100%}.tp-outline-btn{appearance:none;border:1px solid var(--tp-primary);width:100%;color:var(--tp-primary);cursor:pointer;background:#fff;border-radius:12px;padding:10px 12px;font-family:inherit;font-size:11px;font-weight:600}.tp-link-btn{color:var(--tp-text-dim);cursor:pointer;background:0 0;border:none;padding:4px;font-family:inherit;font-size:10px}.tp-form-card{border:1px solid var(--tp-border);background:var(--tp-surface);border-radius:12px;flex-direction:column;gap:8px;padding:10px;display:flex}.tp-form-card label{color:var(--tp-text-dim);text-transform:uppercase;letter-spacing:.06em;flex-direction:column;gap:3px;font-size:8px;display:flex}.tp-form-card label div{color:var(--tp-text);text-transform:none;letter-spacing:0;font-size:11px;font-weight:500}.tp-oauth-btn{border:1px solid var(--tp-border);cursor:pointer;background:#fff;border-radius:12px;width:100%;padding:10px;font-family:inherit;font-size:10px;font-weight:600}.tp-form-note{margin:0;font-size:8px}.tp-otp-copy strong{font-size:13px;display:block}.tp-otp-copy p{color:var(--tp-text-dim);margin:4px 0 0;font-size:9px;line-height:1.4}.tp-otp-boxes{grid-template-columns:repeat(6,1fr);gap:5px;display:grid}.tp-otp-boxes span{aspect-ratio:1;border:1px solid var(--tp-border);background:#fff;border-radius:10px;place-items:center;font-size:12px;font-weight:600;display:grid}.tp-otp-boxes span.filled{border-color:var(--tp-primary);background:var(--tp-primary-soft);color:var(--tp-primary)}.tp-screen-center{text-align:center;justify-content:center;align-items:center;padding-top:20px}.tp-verified-icon{background:var(--tp-primary-soft);width:72px;height:72px;color:var(--tp-primary);border-radius:999px;place-items:center;margin-bottom:12px;font-size:32px;font-weight:700;display:grid}.tp-screen-center strong{font-size:14px}.tp-screen-center p{color:var(--tp-text-dim);max-width:220px;margin:6px 0 14px;font-size:9px;line-height:1.45}.tp-body{--tp-primary:#ff7a00;--tp-primary-soft:#ff7a0024;--tp-text:#404040;--tp-text-dim:#737373;--tp-border:#e5e5e5;--tp-surface:#fafafa;min-height:0;color:var(--tp-text);font-family:"Poppins", var(--sans);background:#fff;flex-direction:column;flex:1;gap:8px;padding:12px 10px 6px;display:flex;position:relative;overflow:hidden}.tp-top{justify-content:space-between;align-items:flex-start;gap:8px;display:flex}.tp-kicker{font-family:var(--mono);text-transform:uppercase;letter-spacing:.1em;color:var(--tp-text-dim);font-size:7px}.tp-title{letter-spacing:-.03em;color:var(--tp-text);margin-top:2px;font-size:16px;font-weight:700;line-height:1.1}.tp-chip-live{appearance:none;color:var(--tp-primary);background:var(--tp-primary-soft);font-size:7px;font-family:var(--mono);cursor:pointer;white-space:nowrap;border:1px solid #ff7a0047;border-radius:999px;align-items:center;gap:4px;padding:5px 8px;display:inline-flex}.tp-flow-strip{scrollbar-width:none;gap:5px;display:flex;overflow-x:auto}.tp-flow-strip::-webkit-scrollbar{display:none}.tp-flow-strip button{border:1px solid var(--tp-border);width:26px;height:22px;color:var(--tp-text-dim);font-family:var(--mono);cursor:pointer;background:#fff;border-radius:999px;flex:none;font-size:7px}.tp-flow-strip button.done{color:var(--tp-text);border-color:#d4d4d4}.tp-flow-strip button.active{color:#fff;border-color:var(--tp-primary);background:var(--tp-primary)}.tp-scroll{scrollbar-width:none;flex:1;min-height:0;padding:0 1px;overflow-y:auto}.tp-scroll::-webkit-scrollbar{width:0;height:0}.tp-screen{flex-direction:column;gap:8px;min-height:100%;padding-bottom:4px;display:flex}.tp-greeting span{color:var(--tp-text-dim);font-size:10px;display:block}.tp-greeting strong{letter-spacing:-.03em;font-size:15px;font-weight:700}.tp-search{border:1px solid var(--tp-border);background:var(--tp-surface);color:var(--tp-text-dim);border-radius:12px;padding:9px 10px;font-size:10px}.tp-hero{border:1px solid var(--tp-border);border-radius:14px;min-height:96px;position:relative;overflow:hidden}.tp-hero img,.tp-detail-hero img,.tp-dest-card img,.tp-list-card img,.tp-guide-hero img{object-fit:cover;display:block}.tp-hero img{width:100%;height:100%;position:absolute;inset:0}.tp-hero-copy{z-index:1;background:linear-gradient(#0000 8%,#fffffff0);flex-direction:column;justify-content:flex-end;min-height:96px;padding:10px 12px;display:flex;position:relative}.tp-hero-copy span{color:var(--tp-text-dim);font-size:9px}.tp-hero-copy strong{font-size:13px;font-weight:700}.tp-hero-dots{z-index:2;gap:4px;display:flex;position:absolute;bottom:8px;right:10px}.tp-hero-dots button{cursor:pointer;background:#40404040;border:none;border-radius:999px;width:6px;height:6px;padding:0}.tp-hero-dots button.active{background:var(--tp-primary);width:14px}.tp-section-head{justify-content:space-between;align-items:center;margin-top:2px;display:flex}.tp-section-head strong{font-size:11px;font-weight:600}.tp-section-head button,.tp-mini-btn{appearance:none;color:var(--tp-primary);cursor:pointer;background:0 0;border:none;font-family:inherit;font-size:9px;font-weight:600}.tp-card-row{scrollbar-width:none;gap:8px;display:flex;overflow-x:auto}.tp-card-row::-webkit-scrollbar{display:none}.tp-dest-card{border:1px solid var(--tp-border);text-align:left;cursor:pointer;font:inherit;color:inherit;background:#fff;border-radius:12px;flex:0 0 108px;padding:0;position:relative;overflow:hidden}.tp-dest-card img{object-fit:cover;width:100%;height:64px;display:block}.tp-dest-card div{padding:6px 8px 8px}.tp-dest-card span{color:var(--tp-text-dim);font-size:8px;display:block}.tp-dest-card strong{margin-top:2px;font-size:10px;display:block}.tp-heart{color:#d4d4d4;cursor:pointer;background:#ffffffeb;border-radius:999px;place-items:center;width:22px;height:22px;font-size:11px;display:grid;position:absolute;top:6px;right:6px}.tp-heart.on,.tp-heart-btn.on{color:var(--tp-primary)}.tp-screen-title{letter-spacing:-.03em;font-size:15px;font-weight:700}.tp-muted{color:var(--tp-text-dim);margin:0;font-size:9px;line-height:1.4}.tp-tabs{gap:6px;display:flex}.tp-tabs button{border:1px solid var(--tp-border);color:var(--tp-text-dim);cursor:pointer;background:#fff;border-radius:999px;flex:1;padding:7px 8px;font-family:inherit;font-size:9px}.tp-tabs button.active{background:var(--tp-primary-soft);color:var(--tp-primary);border-color:#ff7a0059;font-weight:600}.tp-list{flex-direction:column;gap:8px;display:flex}.tp-list.compact .tp-list-card img{width:44px;height:44px}.tp-list-card{border:1px solid var(--tp-border);text-align:left;cursor:pointer;font:inherit;color:inherit;background:#fff;border-radius:12px;align-items:flex-start;gap:8px;padding:8px;display:flex;position:relative}.tp-list-card.static{cursor:default}.tp-guide-row{scrollbar-width:none;gap:8px;padding-bottom:2px;display:flex;overflow-x:auto}.tp-guide-row::-webkit-scrollbar{display:none}.tp-guide-tile{border:1px solid var(--tp-border);background:#fff;border-radius:12px;flex:0 0 118px;overflow:hidden}.tp-guide-tile img{object-fit:cover;width:100%;height:64px;display:block}.tp-guide-tile div{padding:6px 8px 8px}.tp-guide-tile span{color:var(--tp-primary);text-transform:uppercase;letter-spacing:.06em;font-size:7px;font-weight:600;display:block}.tp-guide-tile strong{margin-top:3px;font-size:9px;line-height:1.25;display:block}.tp-list-card img{object-fit:cover;border-radius:10px;flex-shrink:0;width:52px;height:52px}.tp-list-card strong{font-size:11px;display:block}.tp-list-card span{color:var(--tp-text-dim);align-items:center;gap:3px;margin-top:2px;font-size:8px;display:inline-flex}.tp-list-card p{color:var(--tp-text-dim);margin:4px 0 0;font-size:8px;line-height:1.35}.tp-recipe-card{border:1px solid var(--tp-border);background:var(--tp-surface);border-radius:12px;align-items:center;gap:8px;padding:8px;display:flex}.tp-recipe-thumb{background:#fff;border-radius:10px;flex-shrink:0;width:48px;height:48px}.tp-guide-hero{border:1px solid var(--tp-border);border-radius:14px;max-height:108px;overflow:hidden}.tp-guide-hero img{width:100%;height:108px}.tp-recipe-card strong{font-size:11px;display:block}.tp-recipe-card span{color:var(--tp-text-dim);font-size:8px}.tp-subnav{justify-content:space-between;align-items:center;gap:8px;display:flex}.tp-subnav button{appearance:none;background:var(--tp-surface);cursor:pointer;width:28px;height:28px;color:var(--tp-text);border:none;border-radius:999px;font-size:16px;line-height:1}.tp-subnav span{text-align:center;flex:1;font-size:12px;font-weight:600}.tp-heart-btn{color:#d4d4d4;font-size:14px}.tp-detail-hero{border:1px solid var(--tp-border);border-radius:14px;overflow:hidden}.tp-detail-hero img{object-fit:cover;width:100%;height:110px;display:block}.tp-detail-head span{color:var(--tp-text-dim);font-size:9px}.tp-detail-head strong{margin-top:2px;font-size:15px;font-weight:700;display:block}.tp-detail-head p{color:var(--tp-text-dim);margin:4px 0 0;font-size:9px;line-height:1.45}.tp-pill-row{flex-wrap:wrap;gap:5px;display:flex}.tp-pill-row span{background:var(--tp-primary-soft);color:var(--tp-primary);border:1px solid #ff7a0033;border-radius:999px;padding:5px 8px;font-size:8px}.tp-primary-btn{appearance:none;background:var(--tp-primary);color:#fff;cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;gap:6px;padding:10px 12px;font-family:inherit;font-size:11px;font-weight:600;display:inline-flex}.tp-map-card{border:1px solid var(--tp-border);background:var(--tp-surface);color:var(--tp-primary);border-radius:12px;align-items:center;gap:8px;padding:10px;display:flex}.tp-map-card strong{color:var(--tp-text);font-size:10px;display:block}.tp-map-card span{color:var(--tp-text-dim);font-size:8px}.tp-badge{background:var(--tp-primary-soft);color:var(--tp-primary);border-radius:999px;padding:3px 7px;font-size:8px;font-weight:600}.tp-guide-card{border:1px solid var(--tp-border);background:var(--tp-surface);border-radius:14px;padding:10px}.tp-guide-head strong{font-size:12px;display:block}.tp-guide-head span{color:var(--tp-text-dim);margin-top:3px;font-size:8px;display:block}.tp-guide-section{border-top:1px solid var(--tp-border);margin-top:8px;padding-top:8px}.tp-guide-section b{color:var(--tp-primary);margin-bottom:3px;font-size:9px;display:block}.tp-guide-section p{color:var(--tp-text-dim);margin:0;font-size:9px;line-height:1.45}.tp-notify-card{color:var(--tp-text-dim);border:1px dashed #ff7a0059;border-radius:12px;align-items:flex-start;gap:6px;padding:8px;font-size:8px;line-height:1.4;display:flex}.tp-saved-grid{grid-template-columns:repeat(3,1fr);gap:6px;display:grid}.tp-saved-tile{border:1px solid var(--tp-border);text-align:center;cursor:pointer;font:inherit;color:inherit;background:#fff;border-radius:12px;padding:10px 6px}.tp-saved-tile strong{color:var(--tp-primary);font-size:16px;display:block}.tp-saved-tile span{color:var(--tp-text-dim);margin-top:2px;font-size:7px;display:block}.tp-profile-row{border:1px solid var(--tp-border);background:var(--tp-surface);border-radius:14px;align-items:center;gap:10px;padding:10px;display:flex}.tp-avatar{background:var(--tp-primary-soft);width:40px;height:40px;color:var(--tp-primary);border-radius:999px;place-items:center;font-weight:700;display:grid}.tp-profile-row strong{font-size:12px;display:block}.tp-profile-row span{color:var(--tp-text-dim);font-size:9px}.tp-settings-group{flex-direction:column;gap:4px;display:flex}.tp-settings-group>span{color:var(--tp-text-dim);text-transform:uppercase;letter-spacing:.06em;margin-top:4px;font-size:8px}.tp-settings-item{border:1px solid var(--tp-border);cursor:pointer;font:inherit;color:inherit;text-align:left;background:#fff;border-radius:12px;justify-content:space-between;align-items:center;gap:8px;padding:10px;display:flex}.tp-settings-item strong{font-size:10px;font-weight:500}.tp-logout-btn{color:#dc2626;cursor:pointer;background:#ef44440f;border:1px solid #ef444440;border-radius:12px;margin-top:6px;padding:10px;font-family:inherit;font-size:10px;font-weight:600}.tp-bottom-nav{border-top:1px solid var(--tp-border);grid-template-columns:repeat(4,1fr);gap:2px;margin-top:2px;padding-top:6px;display:grid}.tp-bottom-nav button{appearance:none;color:var(--tp-text-dim);cursor:pointer;background:0 0;border:none;flex-direction:column;align-items:center;gap:2px;padding:4px 2px;font-family:inherit;display:flex}.tp-bottom-nav button span{font-size:7px}.tp-bottom-nav button.active{color:var(--tp-primary)}
