:root{
  --ground:#12100f; --ground2:#1a1614; --card:#211c19;
  --ink:#f4efe7; --soft:#b8aca0; --line:rgba(244,239,231,.10);
  --marigold:#f2b64b; --lilac:#b8a7e8; --coral:#e98a6d; --mint:#9fd8c0;
  --serif:'Fraunces',Georgia,serif; --sans:'Inter',system-ui,sans-serif;
  --max:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--ground);color:var(--ink);font-family:var(--sans);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--max);margin:0 auto;padding:0 clamp(20px,5vw,40px)}
h1,h2,h3{font-family:var(--serif);font-weight:500;letter-spacing:-.01em;line-height:1.06;margin:0}
.eyebrow{font-size:12px;letter-spacing:.24em;text-transform:uppercase;color:var(--marigold);font-weight:700}
.btn{display:inline-flex;align-items:center;gap:9px;background:linear-gradient(180deg,#ffd47e,var(--marigold));color:#2a1e08;font-weight:700;font-family:var(--sans);border:0;border-radius:999px;padding:14px 26px;cursor:pointer;font-size:1rem;transition:transform .15s,box-shadow .15s;box-shadow:0 6px 30px rgba(242,182,75,.22)}
.btn:hover{transform:translateY(-2px);box-shadow:0 10px 38px rgba(242,182,75,.32)}
.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--line);box-shadow:none}
.btn-ghost:hover{border-color:rgba(244,239,231,.35);box-shadow:none}
nav{position:sticky;top:0;z-index:50;backdrop-filter:blur(12px);background:rgba(18,16,15,.72);border-bottom:1px solid var(--line)}
nav .wrap{display:flex;align-items:center;justify-content:space-between;gap:14px;min-height:64px;padding-top:8px;padding-bottom:8px;flex-wrap:wrap}
.logo{font-family:var(--serif);font-size:1.5rem;font-weight:600;letter-spacing:.01em;display:flex;align-items:center;gap:8px}
.logo .stitch{width:9px;height:9px;border-radius:50%;background:var(--marigold);box-shadow:0 0 14px var(--marigold)}
.navlinks{display:flex;gap:clamp(14px,2.4vw,26px);align-items:center;flex-wrap:wrap}
.nl{font-size:.95rem;color:var(--soft);font-weight:500;transition:color .15s}
.nl:hover{color:var(--ink)}
.nl.active{color:var(--ink);border-bottom:1px solid var(--marigold);padding-bottom:2px}
nav .btn{padding:9px 18px;font-size:.9rem}
section{padding:clamp(64px,10vh,120px) 0}
.page-hero{padding:clamp(56px,9vh,96px) 0 clamp(28px,4vh,44px)}
.page-hero h1{font-size:clamp(2.5rem,6.4vw,4.8rem);max-width:18ch;margin-top:16px}
.page-hero h1 em{font-style:italic;color:var(--marigold)}
.page-hero .lead{color:var(--soft);font-size:clamp(1.08rem,2vw,1.3rem);max-width:56ch;margin-top:20px}
.page-hero .lead b{color:var(--ink);font-weight:600}
.hero{padding:clamp(60px,10vh,110px) 0 clamp(40px,6vh,64px)}
.hero h1{font-size:clamp(2.8rem,7.6vw,5.6rem);max-width:16ch}
.hero h1 em{font-style:italic;color:var(--marigold)}
.hero p.lead{font-size:clamp(1.1rem,2.1vw,1.4rem);color:var(--soft);max-width:52ch;margin:22px 0 30px;line-height:1.55}
.hero p.lead b{color:var(--ink);font-weight:600}
.cta-row{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.cast{display:grid;grid-template-columns:repeat(5,1fr);gap:clamp(10px,1.4vw,18px);margin-top:clamp(40px,6vh,60px)}
.cast a{border-radius:18px;overflow:hidden;aspect-ratio:1/1;background:#000;position:relative;display:block;border:1px solid var(--line);transition:transform .2s}
.cast a:hover{transform:translateY(-4px)}
.cast img{width:100%;height:100%;object-fit:cover;display:block}
.cast span{position:absolute;left:0;right:0;bottom:0;padding:26px 12px 10px;font-family:var(--serif);font-size:.95rem;background:linear-gradient(transparent,rgba(10,8,7,.85));text-align:center}
.how{background:var(--ground2)}
.how h2{font-size:clamp(2rem,5vw,3.4rem)}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,24px);margin-top:clamp(36px,5vh,56px)}
.step{background:var(--card);border:1px solid var(--line);border-radius:20px;padding:30px 26px 32px}
.step .num{font-family:var(--serif);font-size:2rem;color:var(--marigold)}
.step h3{font-size:1.4rem;margin-top:10px}
.step p{color:var(--soft);margin:10px 0 0;font-size:1rem}
.step p b{color:var(--ink);font-weight:600}
.roster-head h2{font-size:clamp(2.1rem,5.4vw,3.7rem);max-width:18ch}
.roster-head p{color:var(--soft);font-size:1.12rem;max-width:56ch;margin-top:18px}
.case{margin-top:clamp(48px,7vh,80px)}
.case .meta{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap;margin-bottom:18px}
.case .meta h3{font-size:clamp(1.6rem,3.4vw,2.3rem)}
.case .meta h3 em{font-style:italic;color:var(--marigold)}
.case .meta .vert{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--soft);font-weight:700;border:1px solid var(--line);border-radius:999px;padding:6px 14px}
.case .meta .vert.avail{border-color:rgba(159,216,192,.45);color:var(--mint)}
.case .bio{color:var(--soft);font-size:1.05rem;max-width:60ch;margin:0 0 22px}
.tiles{display:grid;grid-template-columns:1fr 1fr 1.42fr;gap:12px}
.tile{border-radius:18px;overflow:hidden;background:#000;border:1px solid var(--line);position:relative}
.tile img,.tile video{width:100%;height:100%;object-fit:cover;display:block}
.tile .tag{position:absolute;left:12px;bottom:10px;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(244,239,231,.85);background:rgba(10,8,7,.55);backdrop-filter:blur(6px);border-radius:999px;padding:4px 11px;font-weight:600}
.case .more,.more{display:inline-block;margin-top:18px;color:var(--marigold);font-weight:600;border-bottom:1px solid rgba(242,182,75,.4);padding-bottom:2px}
.anatomy{background:var(--ground2)}
.anatomy h2{font-size:clamp(2rem,5vw,3.4rem);max-width:22ch}
.anatomy .sub{color:var(--soft);font-size:1.1rem;margin-top:16px;max-width:58ch}
.counts{display:flex;flex-wrap:wrap;gap:10px;margin-top:26px}
.counts span{border:1px solid rgba(242,182,75,.35);border-radius:999px;padding:8px 16px;font-size:.9rem;color:var(--ink);background:var(--card)}
.counts span b{color:var(--marigold);font-weight:700}
.item{display:grid;grid-template-columns:1.15fr 1fr;gap:clamp(24px,4vw,56px);align-items:center;margin-top:clamp(44px,6vh,72px)}
.item:nth-child(even){direction:rtl}
.item>*{direction:ltr}
.item .num{font-family:var(--serif);font-size:1rem;color:var(--marigold);letter-spacing:.08em}
.item h3{font-size:clamp(1.4rem,3vw,2rem);margin-top:8px}
.item .spec{display:inline-block;margin-top:12px;font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;font-weight:700;color:var(--marigold);border:1px solid rgba(242,182,75,.35);border-radius:999px;padding:5px 13px}
.item p{color:var(--soft);margin:14px 0 0;font-size:1.02rem;max-width:52ch}
.item p b{color:var(--ink);font-weight:600}
.item .duo{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.use-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(14px,1.8vw,22px);margin-top:clamp(36px,5vh,56px)}
.kit-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:clamp(36px,5vh,56px)}
.kit-grid .tile.wide{grid-column:1/-1}
.kit-vids{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:12px}
.case .kit-vids .tile{aspect-ratio:16/9}
.kit-note{margin-top:clamp(28px,4vh,40px);border:1px dashed rgba(242,182,75,.35);border-radius:18px;padding:22px 28px;color:var(--soft);font-size:1rem}
.kit-note b{color:var(--ink);font-weight:600}
.grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(14px,1.8vw,22px);margin-top:clamp(40px,6vh,64px)}
.part{background:var(--card);border:1px solid var(--line);border-radius:20px;padding:28px 24px 30px}
.part .num{font-family:var(--serif);font-size:.95rem;color:var(--marigold);letter-spacing:.08em}
.part h3{font-size:1.35rem;margin-top:10px}
.part p{color:var(--soft);margin:10px 0 0;font-size:.98rem}
.stats h2{font-size:clamp(2rem,5.2vw,3.5rem);max-width:20ch}
.stats .sub{color:var(--soft);font-size:1.1rem;margin-top:16px;max-width:58ch}
.stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(14px,1.8vw,22px);margin-top:clamp(36px,5vh,56px)}
.stat{background:var(--card);border:1px solid var(--line);border-radius:20px;padding:30px 26px 28px}
.stat .n{font-family:var(--serif);font-size:clamp(2.4rem,4.6vw,3.4rem);color:var(--marigold);line-height:1}
.stat p{color:var(--ink);margin:14px 0 0;font-size:1rem}
.stat .src{display:block;color:var(--soft);font-size:.82rem;margin-top:12px}
.stat-foot{color:var(--soft);font-size:.9rem;margin-top:22px;max-width:72ch}
.bridge{background:var(--ground2)}
.bridge .row{display:grid;grid-template-columns:1.2fr 1fr;gap:clamp(28px,5vw,64px);align-items:center}
.bridge h2{font-size:clamp(2rem,5vw,3.3rem)}
.bridge p{color:var(--soft);font-size:1.1rem;margin-top:18px;max-width:52ch}
.bridge p b{color:var(--ink);font-weight:600}
.bridge .mark{font-family:var(--serif);font-size:clamp(1.6rem,3vw,2.2rem);border:1px solid var(--line);border-radius:24px;padding:clamp(28px,4vw,48px);text-align:center;background:var(--card)}
.bridge .mark .x{color:var(--soft);font-size:.6em;display:block;margin:10px 0}
.pricing .head{max-width:62ch}
.pricing h2{font-size:clamp(2rem,5.2vw,3.5rem)}
.pricing .sub{color:var(--soft);font-size:1.12rem;margin-top:16px;max-width:54ch}
.tiers{display:grid;grid-template-columns:1fr 1fr;gap:clamp(16px,2vw,26px);margin-top:clamp(40px,6vh,64px)}
.tier{background:var(--card);border:1px solid var(--line);border-radius:24px;padding:36px 32px 38px;position:relative}
.tier.licensed{border-color:rgba(242,182,75,.35)}
.tier .badge{position:absolute;top:-13px;left:32px;background:var(--marigold);color:#2a1e08;font-size:.75rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;border-radius:999px;padding:5px 14px}
.tier .kind{font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--soft);font-weight:700}
.tier .price{font-family:var(--serif);font-size:clamp(2rem,4vw,2.8rem);margin-top:14px}
.tier .price small{font-size:.45em;color:var(--soft);font-family:var(--sans);font-weight:500;letter-spacing:0}
.tier .renew{color:var(--soft);font-size:.95rem;margin-top:6px}
.tier ul{list-style:none;margin:24px 0 0;padding:0}
.tier li{padding:10px 0;border-top:1px solid var(--line);color:var(--ink);font-size:.99rem;display:flex;gap:10px}
.tier li::before{content:'·';color:var(--marigold);font-weight:700}
.plain{margin-top:clamp(20px,3vh,30px);display:grid;grid-template-columns:1fr 1fr;gap:clamp(16px,2vw,26px)}
.plain .p{border:1px dashed rgba(242,182,75,.35);border-radius:18px;padding:24px 26px}
.plain h3{font-size:1.15rem;color:var(--marigold)}
.plain p{color:var(--soft);font-size:.98rem;margin:10px 0 0}
.plain p b{color:var(--ink);font-weight:600}
.addon{margin-top:clamp(20px,3vh,30px);border:1px solid var(--line);background:var(--card);border-radius:18px;padding:22px 28px;display:flex;gap:16px;flex-wrap:wrap;align-items:baseline;justify-content:space-between}
.addon .l{font-family:var(--serif);font-size:1.25rem}
.addon .l b{color:var(--marigold);font-weight:600}
.addon .r{color:var(--soft);font-size:.97rem;max-width:52ch}
.faq{margin-top:clamp(44px,6vh,72px)}
.faq h2{font-size:clamp(1.8rem,4.4vw,2.8rem)}
.faq details{border-bottom:1px solid var(--line);padding:6px 0}
.faq summary{cursor:pointer;font-family:var(--serif);font-size:1.2rem;padding:16px 0;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:14px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:'+';color:var(--marigold);font-family:var(--sans);font-weight:600;font-size:1.3rem}
.faq details[open] summary::after{content:'\2212'}
.faq .a{color:var(--soft);font-size:1rem;padding:0 0 18px;max-width:70ch}
.faq .a b{color:var(--ink);font-weight:600}
.claim{background:var(--ground2)}
.claim .box{max-width:640px;margin:0 auto;text-align:center}
.claim h2{font-size:clamp(2.1rem,5.4vw,3.4rem)}
.claim .sub{color:var(--soft);margin:16px auto 0;max-width:48ch;font-size:1.05rem}
form{margin-top:36px;display:grid;grid-template-columns:1fr 1fr;gap:14px;text-align:left}
form[hidden]{display:none}
.f-full{grid-column:1/-1}
input{width:100%;background:var(--card);border:1px solid var(--line);border-radius:14px;color:var(--ink);font-family:var(--sans);font-size:1rem;padding:15px 18px;outline:none;transition:border-color .15s}
input:focus{border-color:rgba(242,182,75,.55)}
input::placeholder{color:rgba(184,172,160,.7)}
form .btn{grid-column:1/-1;justify-content:center;margin-top:6px}
.msg{grid-column:1/-1;font-size:.98rem;min-height:1.4em;margin:0;text-align:center}
.msg.err{color:var(--coral)}
.msg.ok{color:var(--marigold);font-family:var(--serif);font-size:1.3rem}
.hp{position:absolute;left:-9999px;opacity:0;height:0;overflow:hidden}
.next-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(14px,1.8vw,22px);margin-top:clamp(36px,5vh,52px);text-align:left}
.cta-band{background:var(--ground2);border-top:1px solid var(--line);text-align:center}
.cta-band h2{font-size:clamp(2rem,5vw,3.2rem)}
.cta-band p{color:var(--soft);max-width:48ch;margin:16px auto 28px}
.teaser{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:clamp(32px,4vh,48px)}
.lib-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(10px,1.4vw,16px);margin-top:clamp(36px,5vh,56px)}
.lib-card{position:relative;border-radius:18px;overflow:hidden;aspect-ratio:1/1;border:1px solid var(--line);cursor:pointer;background:#000;transition:transform .25s,box-shadow .25s;padding:0;text-align:left}
.lib-card:hover{transform:translateY(-5px);box-shadow:0 16px 44px rgba(0,0,0,.45);border-color:rgba(242,182,75,.4)}
.lib-card img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .45s}
.lib-card:hover img{transform:scale(1.07)}
.lib-card .lc-info{position:absolute;left:0;right:0;bottom:0;padding:44px 14px 12px;background:linear-gradient(transparent,rgba(10,8,7,.92))}
.lib-card .lc-name{font-family:var(--serif);font-size:1.15rem;color:var(--ink);display:block}
.lib-card .lc-vert{font-size:.75rem;letter-spacing:.12em;text-transform:uppercase;color:var(--soft);font-weight:600;display:block;max-height:0;opacity:0;overflow:hidden;transition:max-height .25s,opacity .25s,margin .25s}
.lib-card:hover .lc-vert,.lib-card:focus .lc-vert{max-height:2em;opacity:1;margin-top:3px}
#lib-modal{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:clamp(10px,3vw,40px);background:rgba(10,8,7,.78);backdrop-filter:blur(8px)}
#lib-modal[hidden]{display:none}
.lm-box{background:var(--ground2);border:1px solid var(--line);border-radius:24px;max-width:1020px;width:100%;max-height:calc(100dvh - 40px);overflow-y:auto;padding:clamp(22px,4vw,40px);position:relative}
.lm-close{position:absolute;top:14px;right:16px;background:none;border:0;color:var(--soft);font-size:1.8rem;cursor:pointer;line-height:1}
.lm-close:hover{color:var(--ink)}
.lm-meta{display:flex;align-items:baseline;gap:12px;flex-wrap:wrap;margin-bottom:12px;padding-right:36px}
.lm-meta h3{font-family:var(--serif);font-size:clamp(1.7rem,4vw,2.4rem)}
.lm-meta h3 em{font-style:italic;color:var(--marigold)}
.lm-bio{color:var(--soft);font-size:1.02rem;max-width:64ch;margin:0 0 20px}
.lm-links{display:flex;gap:18px;flex-wrap:wrap;align-items:center;margin-top:22px}
#felt-chat{position:fixed;right:clamp(14px,3vw,28px);bottom:clamp(14px,3vw,28px);z-index:90;font-family:var(--sans);display:flex;flex-direction:column;align-items:flex-end;gap:10px}

/* ---- the character button ---- */
#fc-open{display:inline-flex;align-items:center;gap:11px;background:none;border:0;padding:4px;cursor:pointer}
#fc-open[hidden]{display:none}
.fc-ball{display:block;width:78px;height:83px;filter:drop-shadow(0 10px 24px rgba(0,0,0,.42)) drop-shadow(0 4px 18px rgba(242,182,75,.3));animation:fc-bob 3s ease-in-out infinite;transform-origin:50% 100%}
.fc-ball .fc-face{display:block;width:100%;height:100%}
#fc-open:hover .fc-ball{animation-play-state:paused;transform:scale(1.14) rotate(-4deg);transition:transform .28s cubic-bezier(.2,1.1,.3,1.5)}

/* face states (shared by button + panel header) */
.fc-face .fc-eye{transform-box:fill-box;transform-origin:center center;transition:transform .12s ease}
.fc-face.is-blink .fc-eye{transform:scaleY(.08)!important}
.fc-face .fc-m{transition:opacity .12s}
.fc-face .fc-m-happy,.fc-face .fc-m-hmm{opacity:0}
.fc-face.is-happy .fc-m-idle,.fc-face.is-thinking .fc-m-idle{opacity:0}
.fc-face.is-happy .fc-m-happy{opacity:1}
.fc-face.is-thinking .fc-m-hmm{opacity:1}
#fc-open:hover .fc-m-idle{opacity:0}
#fc-open:hover .fc-m-happy{opacity:1}
.fc-face.is-thinking .fc-eye{transform:translate(2.2px,-3.2px)}
.fc-face.is-hello{animation:fc-hello .7s cubic-bezier(.3,1.5,.4,1)}
.fc-face.is-cheer{animation:fc-cheer .55s cubic-bezier(.3,1.6,.4,1)}

/* button choreography */
#fc-open.is-launching .fc-ball{animation:fc-launch .38s cubic-bezier(.45,0,.7,.4) forwards}
#fc-open.fc-return .fc-ball{animation:fc-return .75s cubic-bezier(.22,1.6,.36,1)}
#fc-open.is-wiggle .fc-ball{animation:fc-wiggle 1.2s ease-in-out}

/* stitch-confetti burst */
#fc-burst{position:absolute;right:44px;bottom:44px;width:0;height:0;pointer-events:none;z-index:95}
.fc-bit{position:absolute;left:0;top:0;width:9px;height:9px;border-radius:50%;opacity:0;animation:fc-bit .62s cubic-bezier(.2,.7,.4,1) forwards}
.fc-bit-thread{width:14px;height:4px;border-radius:3px}
@keyframes fc-bit{0%{transform:translate(0,0) scale(.4) rotate(0);opacity:1}70%{opacity:1}100%{transform:translate(var(--dx),var(--dy)) scale(1) rotate(var(--rot));opacity:0}}

/* the psst bubble */
#fc-nudge{background:var(--ground2);border:1px solid rgba(242,182,75,.45);color:var(--ink);font-size:.88rem;padding:10px 15px;border-radius:16px;max-width:230px;cursor:pointer;box-shadow:0 12px 40px rgba(0,0,0,.45);position:relative;margin-bottom:6px;margin-right:2px}
#fc-nudge::after{content:"";position:absolute;right:32px;bottom:-6.5px;width:12px;height:12px;background:var(--ground2);border-right:1px solid rgba(242,182,75,.45);border-bottom:1px solid rgba(242,182,75,.45);transform:rotate(45deg)}
#fc-nudge[hidden]{display:none}
#fc-nudge.fc-nudge-in{animation:fc-nudge-in .5s cubic-bezier(.2,1.6,.35,1) both}
#fc-nudge.fc-nudge-out{animation:fc-nudge-out .28s ease-in both}

/* ---- the panel ---- */
#fc-panel[hidden]{display:none}
#fc-panel{width:min(380px,calc(100vw - 28px));height:min(560px,calc(100dvh - 60px));background:var(--ground2);border:1px solid var(--line);border-radius:20px;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 24px 80px rgba(0,0,0,.55);transform-origin:calc(100% - 34px) calc(100% + 10px)}
#fc-panel.fc-in{animation:fc-panel-in .68s cubic-bezier(.34,1.3,.4,1) both}
#fc-panel.fc-out{animation:fc-panel-out .3s cubic-bezier(.55,-.2,.75,.3) both}
#fc-head{display:flex;align-items:center;gap:10px;padding:12px 16px;border-bottom:1px solid var(--line);background:var(--card)}
.fc-head-face{width:40px;height:42px;flex:none}
.fc-head-face .fc-face{display:block;width:100%;height:100%}
.fc-head-name{font-family:var(--serif);font-size:1.15rem;font-weight:600;color:var(--ink);display:flex;align-items:baseline;gap:8px;flex:1}
.fc-head-name small{font-family:var(--sans);font-size:.75rem;color:var(--soft);font-weight:500}
#fc-close{background:none;border:0;color:var(--soft);font-size:1.5rem;cursor:pointer;line-height:1;padding:2px 6px;transition:transform .2s cubic-bezier(.25,1.4,.4,1)}
#fc-close:hover{color:var(--ink);transform:rotate(90deg) scale(1.15)}
#fc-msgs{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px}
.fc-msg{max-width:85%;padding:10px 14px;border-radius:16px;font-size:.93rem;line-height:1.5;white-space:pre-wrap;word-wrap:break-word;animation:fc-msg-in .42s cubic-bezier(.2,1.4,.35,1) both}
.fc-bot{background:var(--card);border:1px solid var(--line);color:var(--ink);align-self:flex-start;border-bottom-left-radius:6px;transform-origin:0 100%}
.fc-user{background:linear-gradient(180deg,#ffd47e,var(--marigold));color:#2a1e08;align-self:flex-end;border-bottom-right-radius:6px;transform-origin:100% 100%}
.fc-dots{display:inline-flex;gap:5px;padding:3px 2px}
.fc-dots i{width:8px;height:8px;border-radius:50%;background:var(--marigold);opacity:.5;animation:fc-dot 1s cubic-bezier(.3,0,.3,1) infinite}
.fc-dots i:nth-child(2){animation-delay:.14s}
.fc-dots i:nth-child(3){animation-delay:.28s}
#fc-chips{display:flex;flex-direction:column;gap:8px;align-items:flex-start}
.fc-chip{background:none;border:1px solid rgba(242,182,75,.4);color:var(--marigold);border-radius:999px;padding:7px 14px;font-size:.85rem;cursor:pointer;font-family:var(--sans);transition:background .15s,transform .25s cubic-bezier(.2,1.4,.35,1)}
.fc-chip:hover{background:rgba(242,182,75,.12);transform:translateX(5px) scale(1.03)}
#fc-form{display:flex;gap:8px;padding:12px;border-top:1px solid var(--line);background:var(--card)}
#fc-in{flex:1;background:var(--ground);border:1px solid var(--line);border-radius:999px;color:var(--ink);font-family:var(--sans);font-size:.93rem;padding:10px 16px;outline:none}
#fc-in:focus{border-color:rgba(242,182,75,.55)}
#fc-send{width:40px;height:40px;border-radius:50%;border:0;background:linear-gradient(180deg,#ffd47e,var(--marigold));color:#2a1e08;font-size:1.1rem;font-weight:700;cursor:pointer;transition:transform .22s cubic-bezier(.2,1.5,.35,1)}
#fc-send:hover{transform:scale(1.15) rotate(12deg)}
#fc-send:active{transform:scale(.85)}

/* ---- keyframes ---- */
@keyframes fc-bob{0%,100%{transform:translateY(0) scale(1,1)}50%{transform:translateY(-5px) scale(.97,1.04)}}
@keyframes fc-launch{0%{transform:scale(1) translateY(0)}30%{transform:scale(1.28,.6) translateY(9px)}62%{transform:scale(.8,1.3) translateY(-56px) rotate(-10deg);opacity:1}100%{transform:scale(.25) translateY(-84px) rotate(14deg);opacity:0}}
@keyframes fc-return{0%{transform:scale(.15) translateY(-40px) rotate(16deg);opacity:0}45%{transform:scale(1.22,.8) translateY(4px) rotate(-4deg);opacity:1}65%{transform:scale(.9,1.12) translateY(-7px)}82%{transform:scale(1.06,.95) translateY(1px)}100%{transform:scale(1) translateY(0) rotate(0)}}
@keyframes fc-wiggle{0%,100%{transform:rotate(0)}12%{transform:rotate(-13deg) scale(1.06)}28%{transform:rotate(11deg)}44%{transform:rotate(-9deg)}60%{transform:rotate(7deg)}76%{transform:rotate(-3deg)}}
@keyframes fc-hello{0%{transform:rotate(0) scale(1)}28%{transform:rotate(-16deg) scale(1.18)}60%{transform:rotate(11deg) scale(1.06)}100%{transform:rotate(0) scale(1)}}
@keyframes fc-cheer{0%{transform:scale(1)}35%{transform:scale(1.22) rotate(-6deg)}70%{transform:scale(.95) rotate(3deg)}100%{transform:scale(1)}}
@keyframes fc-panel-in{0%{transform:scale(.22) translateY(70px) rotate(5deg);opacity:0}45%{transform:scale(1.07) translateY(-12px) rotate(-1.4deg);opacity:1}66%{transform:scale(.965) translateY(5px) rotate(.5deg)}84%{transform:scale(1.02) translateY(-2px)}100%{transform:scale(1) translateY(0) rotate(0)}}
@keyframes fc-panel-out{0%{transform:scale(1);opacity:1}25%{transform:scale(1.03) translateY(-6px)}100%{transform:scale(.28) translateY(56px) rotate(4deg);opacity:0}}
@keyframes fc-msg-in{0%{transform:translateY(14px) scale(.82);opacity:0}60%{transform:translateY(-2px) scale(1.03);opacity:1}100%{transform:translateY(0) scale(1)}}
@keyframes fc-nudge-in{0%{transform:translateY(14px) scale(.7);opacity:0}55%{transform:translateY(-4px) scale(1.06);opacity:1}100%{transform:translateY(0) scale(1)}}
@keyframes fc-nudge-out{0%{opacity:1}100%{transform:translateY(8px) scale(.9);opacity:0}}
@keyframes fc-dot{0%,100%{transform:translateY(0) scale(1);opacity:.45}35%{transform:translateY(-7px) scale(1.15);opacity:1}}
@media(prefers-reduced-motion:reduce){
  .fc-ball,#fc-panel.fc-in,#fc-panel.fc-out,.fc-msg,#fc-open.fc-return .fc-ball,#fc-open.is-wiggle .fc-ball,#fc-open.is-launching .fc-ball,.fc-face.is-hello,.fc-face.is-cheer,.fc-bit{animation:none!important}
}

footer{border-top:1px solid var(--line);padding:56px 0 40px;color:var(--soft);font-size:.92rem}
.fcols{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:clamp(24px,4vw,60px);align-items:start}
.fcols .logo{font-size:1.3rem;color:var(--ink)}
.fcols p{margin:12px 0 0;max-width:32ch}
.fhead{font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:700;color:var(--soft);margin-bottom:14px}
.fnav a{display:block;padding:5px 0;color:var(--soft)}
.fnav a:hover{color:var(--ink)}
.fbase{border-top:1px solid var(--line);margin-top:44px;padding-top:22px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:.85rem}
.fbase a{border-bottom:1px solid var(--line)}
@media(max-width:920px){
  .cast{grid-template-columns:repeat(3,1fr)}
  .cast a:nth-child(4),.cast a:nth-child(5){display:none}
  .steps{grid-template-columns:1fr}
  .tiles{grid-template-columns:1fr 1fr}
  .tiles .tile:last-child{grid-column:1/-1}
  .grid4{grid-template-columns:1fr 1fr}
  .tiers{grid-template-columns:1fr}
  .plain{grid-template-columns:1fr}
  .kit-grid{grid-template-columns:1fr 1fr}
  .lib-grid{grid-template-columns:repeat(2,1fr)}
  .item{grid-template-columns:1fr}
  .use-grid{grid-template-columns:1fr 1fr}
  .stat-grid{grid-template-columns:1fr}
  .bridge .row{grid-template-columns:1fr}
  .teaser{grid-template-columns:1fr}
  .next-steps{grid-template-columns:1fr}
  .fcols{grid-template-columns:1fr}
}
@media(max-width:560px){
  .grid4{grid-template-columns:1fr}
  .tiles{grid-template-columns:1fr}
  .kit-grid{grid-template-columns:1fr}
  .kit-vids{grid-template-columns:1fr}
  form{grid-template-columns:1fr}
  .cast{grid-template-columns:repeat(3,1fr)}
  .nl{font-size:.85rem}
}

/* kit page carousels: still <-> animation */
.kcar{overflow:hidden}
.kcar .kcar-track{display:flex;transition:transform .45s cubic-bezier(.3,0,.2,1);height:100%}
.kcar .kcar-slide{flex:0 0 100%;min-width:100%}
.kcar .kcar-slide img,.kcar .kcar-slide video{width:100%;height:100%;object-fit:cover;display:block}
.kcar-btn{position:absolute;top:50%;transform:translateY(-50%);width:38px;height:38px;border-radius:50%;border:1px solid rgba(244,239,231,.25);background:rgba(10,8,7,.55);backdrop-filter:blur(6px);color:var(--ink);font-size:1.15rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:2;transition:background .2s}
.kcar-btn:hover{background:rgba(242,182,75,.85);color:#241a10}
.kcar-btn.prev{left:10px}
.kcar-btn.next{right:10px}
.kcar .kmode{position:absolute;right:12px;bottom:10px;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(244,239,231,.85);background:rgba(10,8,7,.55);backdrop-filter:blur(6px);border-radius:999px;padding:4px 11px;font-weight:600;z-index:2}
.kit-hub-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;margin-top:28px}
.kit-hub-grid a{display:block;border-radius:16px;overflow:hidden;border:1px solid var(--line);position:relative;background:#000;transition:transform .25s,border-color .25s}
.kit-hub-grid a:hover{transform:translateY(-4px);border-color:rgba(242,182,75,.5)}
.kit-hub-grid img{width:100%;aspect-ratio:1;object-fit:cover;display:block}
.kit-hub-grid span{position:absolute;left:10px;bottom:8px;font-size:.78rem;font-weight:600;color:rgba(244,239,231,.92);background:rgba(10,8,7,.55);backdrop-filter:blur(6px);border-radius:999px;padding:3px 10px}

/* reserve: plan picker + post-submit close panel */
.plan-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:4px}
.plan-pill{background:none;border:1px solid var(--line);color:var(--soft);border-radius:999px;padding:9px 16px;font-size:.88rem;font-family:var(--sans);cursor:pointer;transition:all .15s}
.plan-pill:hover{border-color:rgba(242,182,75,.5);color:var(--ink)}
.plan-pill.on{border-color:var(--marigold);color:var(--ink);background:rgba(242,182,75,.12);font-weight:600}
#claim-done{animation:fc-msg-in .45s cubic-bezier(.2,1.4,.35,1) both}
.dep-box{margin-top:22px;border:1px dashed rgba(242,182,75,.5);border-radius:18px;padding:22px 24px}
.dep-head{font-family:var(--serif);font-size:1.15rem;color:var(--marigold);font-weight:600}
.dep-box p{color:var(--soft);font-size:.98rem;margin:10px 0 16px}
.dep-box p b{color:var(--ink)}
.dep-fine{font-size:.82rem!important;margin:12px 0 0!important;color:var(--soft);opacity:.8}
