/* ===== Turquino Studios — shared design system ===== */
@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@500;600;700&family=Inter:wght@400;500;600;700&display=swap');
:root{
  --teal:#19b8b0;
  --teal-bright:#27d6cd;
  --teal-dark:#0c726d;
  --ink:#0b1011;
  --ink-2:#10191a;
  --paper:#f6fbfb;
  --muted:#8fb4b1;
  --line:rgba(255,255,255,.10);
  --radius:18px;
  --maxw:1180px;
  --font:'Inter',-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --display:'Space Grotesk','Inter',-apple-system,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--font);background:var(--ink);color:#eaf6f5;-webkit-font-smoothing:antialiased;line-height:1.55}
/* Lenis smooth scroll */
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}
.lenis.lenis-smooth [data-lenis-prevent]{overscroll-behavior:contain}
.lenis.lenis-stopped{overflow:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.eyebrow{display:inline-block;font-size:12px;font-weight:800;letter-spacing:.22em;text-transform:uppercase;color:var(--ink);background:var(--teal);padding:6px 12px;border-radius:5px}
h1,h2,h3{font-family:var(--display);letter-spacing:-.02em;line-height:1.02;color:#fff}
h1{font-size:clamp(38px,6vw,84px);font-weight:700}
h2{font-size:clamp(30px,4.4vw,56px);font-weight:700}
h3{font-size:clamp(19px,1.8vw,25px);font-weight:600}
p{color:#cfe6e4}
.lead{font-size:clamp(16px,1.5vw,20px);color:#bcdedb;max-width:60ch}

/* ===== Buttons ===== */
.btn{display:inline-block;font-weight:800;font-size:15px;padding:15px 30px;border-radius:999px;cursor:pointer;border:0;transition:transform .15s,background .15s,color .15s}
.btn-primary{background:var(--teal);color:var(--ink)}
.btn-primary:hover{background:#fff;transform:translateY(-2px)}
.btn-ghost{background:transparent;color:#fff;border:1px solid var(--line)}
.btn-ghost:hover{border-color:var(--teal);color:var(--teal-bright)}

/* ===== Nav ===== */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;gap:6px;padding:14px 22px;background:linear-gradient(rgba(11,16,17,.72),rgba(11,16,17,0));transition:background .25s}
.nav.solid{background:rgba(11,16,17,.92);border-bottom:1px solid var(--line)}
.nav .logo{font-weight:800;font-size:15px;letter-spacing:.04em;color:#fff;margin-right:auto;display:flex;align-items:center;gap:10px}
.nav .logo .dot{width:10px;height:10px;border-radius:50%;background:var(--teal);box-shadow:0 0 12px var(--teal)}
.nav .logo .logomark{height:34px;width:auto;display:block;transition:transform .3s}
.nav .logo:hover .logomark{transform:translateY(-1px) scale(1.05)}
@media (max-width:520px){.nav .logo .logotext{display:none}}
.nav a.link{font-size:13px;font-weight:600;color:#d7eceb;padding:8px 12px;border-radius:999px;transition:background .15s,color .15s}
.nav a.link:hover{background:rgba(255,255,255,.08);color:#fff}
.nav a.link.active{color:var(--teal-bright)}
.nav .btn{padding:9px 18px;font-size:13px}
.nav-toggle{display:none;background:none;border:0;color:#fff;font-size:22px;cursor:pointer;margin-left:6px}
@media (max-width:880px){
  .nav .link,.nav .nav-cta-text{display:none}
  .nav-toggle{display:block}
  .nav.open .menu{display:flex}
  .nav .menu{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;gap:2px;background:rgba(11,16,17,.97);padding:12px 18px;border-bottom:1px solid var(--line)}
  .nav.open .menu a.link{display:block;font-size:15px;padding:12px 8px}
  .nav.open .menu .btn{align-self:flex-start;margin-top:6px}
}
.menu{display:flex;align-items:center;gap:4px}

/* ===== Sections ===== */
.section{padding:clamp(64px,9vw,120px) 0}
.section-head{max-width:720px;margin-bottom:48px}
.section-head h2{margin:14px 0 16px}
.grid{display:grid;gap:22px}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-2{grid-template-columns:repeat(2,1fr)}
@media (max-width:860px){.cols-3{grid-template-columns:1fr 1fr}}
@media (max-width:600px){.cols-3,.cols-2{grid-template-columns:1fr}}

/* ===== Cards ===== */
.card{background:var(--ink-2);border:1px solid var(--line);border-radius:var(--radius);padding:28px;transition:transform .2s,border-color .2s}
.card:hover{transform:translateY(-4px);border-color:rgba(25,184,176,.5)}
.card .ico{width:46px;height:46px;border-radius:12px;background:rgba(25,184,176,.14);display:flex;align-items:center;justify-content:center;font-size:22px;margin-bottom:18px}
.card h3{margin-bottom:8px}
.card p{font-size:15px}

/* ===== Customers marquee ===== */
.marquee{overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:22px 0;background:var(--ink-2)}
.marquee .track{display:flex;gap:60px;width:max-content;animation:scrollx 28s linear infinite;align-items:center}
.marquee:hover .track{animation-play-state:paused}
.marquee .item{font-weight:800;font-size:20px;color:#5d8c89;letter-spacing:.02em;white-space:nowrap;opacity:.8}
@keyframes scrollx{to{transform:translateX(-50%)}}

/* ===== Pricing ===== */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;align-items:stretch}
@media (max-width:860px){.price-grid{grid-template-columns:1fr}}
.tier{position:relative;background:var(--ink-2);border:1px solid var(--line);border-radius:var(--radius);padding:32px 28px;display:flex;flex-direction:column}
.tier.featured{border-color:var(--teal);box-shadow:0 0 0 1px var(--teal),0 24px 60px rgba(25,184,176,.12)}
.tier .tag{position:absolute;top:-12px;left:28px;background:var(--teal);color:var(--ink);font-size:11px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;padding:5px 12px;border-radius:999px}
.tier h3{font-size:22px}
.tier .price{font-size:40px;font-weight:800;color:#fff;margin:12px 0 4px}
.tier .price small{font-size:15px;font-weight:600;color:var(--muted)}
.tier .sub{font-size:14px;color:var(--muted);margin-bottom:20px}
.tier ul{list-style:none;margin:0 0 26px;display:flex;flex-direction:column;gap:11px}
.tier li{font-size:14px;color:#d3e8e6;padding-left:26px;position:relative}
.tier li::before{content:"✓";position:absolute;left:0;color:var(--teal-bright);font-weight:800}
.tier .btn{margin-top:auto;text-align:center}

/* ===== Template gallery ===== */
.tpl{position:relative;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);background:var(--ink-2);aspect-ratio:16/11;display:flex;align-items:flex-end;transition:transform .25s,border-color .25s,box-shadow .25s}
.tpl:hover{transform:translateY(-5px);border-color:var(--teal);box-shadow:0 22px 50px rgba(0,0,0,.4)}
.tpl .ph{position:absolute;inset:0;background:linear-gradient(135deg,#123c40,#0c2628);display:flex;align-items:center;justify-content:center;color:#2f6f6b;font-weight:800;font-size:40px;letter-spacing:.1em}
.tpl .shot{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:top center;transition:transform .5s ease,filter .3s;filter:saturate(1.02)}
.tpl:hover .shot{transform:scale(1.05)}
.tpl .meta{position:relative;width:100%;padding:18px 20px;background:linear-gradient(transparent,rgba(6,13,14,.55) 35%,rgba(6,13,14,.95));z-index:2}
.tpl .meta .cat{font-size:11px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--teal-bright)}
.tpl .meta h3{font-size:18px;margin-top:4px}
.tpl .live{position:absolute;top:14px;right:14px;z-index:3;display:flex;align-items:center;gap:6px;background:rgba(6,13,14,.7);backdrop-filter:blur(4px);border:1px solid var(--line);color:#dff3f1;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:5px 10px;border-radius:999px}
.tpl .live .ld{width:7px;height:7px;border-radius:50%;background:#3ee8a0;box-shadow:0 0 8px #3ee8a0}

/* ===== Pinned showcase (Tres Mares style, white) ===== */
.showcase{background:#f6fbfb;color:#0b1011}
.showcase .pinwrap{min-height:100vh;display:flex;align-items:center;padding:90px 0}
.showcase .grid2{display:grid;grid-template-columns:0.85fr 1.15fr;gap:54px;align-items:center;width:100%}
@media (max-width:880px){.showcase .grid2{grid-template-columns:1fr;gap:30px}}
.showcase h2{color:#0b1011}
.showcase .sublead{color:#5d7370;max-width:34ch;margin-top:12px}
.showcase .tlist{list-style:none;margin:26px 0 30px;display:flex;flex-direction:column;gap:6px}
.showcase .tlist li{font-family:var(--display);font-weight:700;font-size:clamp(22px,2.8vw,38px);line-height:1.25;color:#bcd0ce;cursor:pointer;transition:color .35s,transform .35s;display:flex;align-items:center;gap:14px}
.showcase .tlist li .ld{width:9px;height:9px;border-radius:50%;background:var(--teal);opacity:0;transform:scale(0);transition:opacity .3s,transform .3s}
.showcase .tlist li.active{color:#0b1011;transform:translateX(6px)}
.showcase .tlist li.active .ld{opacity:1;transform:scale(1)}
.showcase .preview{position:relative;border-radius:18px;overflow:hidden;border:1px solid rgba(0,0,0,.1);box-shadow:0 34px 80px rgba(0,0,0,.22);aspect-ratio:16/10;background:#0c2628}
.showcase .preview img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:top center;opacity:0;transform:scale(1.03);transition:opacity .6s ease,transform .6s ease}
.showcase .preview img.active{opacity:1;transform:scale(1)}
.showcase .plive{position:absolute;top:14px;left:14px;z-index:3;display:inline-flex;align-items:center;gap:6px;background:rgba(11,16,17,.85);color:#fff;font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;padding:6px 10px;border-radius:999px;opacity:0;transition:opacity .3s}
.showcase .plive.on{opacity:1}
.showcase .plive .ld{width:6px;height:6px;border-radius:50%;background:#3ee8a0;box-shadow:0 0 8px #3ee8a0}
.showcase .viewlive{position:absolute;bottom:14px;right:14px;z-index:3;background:#fff;color:#0b1011;font-weight:700;font-size:13px;padding:9px 16px;border-radius:999px;box-shadow:0 6px 18px rgba(0,0,0,.25);transition:transform .2s}
.showcase .viewlive:hover{transform:translateY(-2px)}
.showcase .pcat{display:inline-block;margin-top:16px;font-size:12px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--teal-dark)}
.showcase .scol .btn{margin-top:4px}

/* ===== Template cards (Figma-style, white) ===== */
.tcard{background:#fff;border-radius:14px;overflow:hidden;border:1px solid rgba(0,0,0,.08);display:flex;flex-direction:column;transition:transform .2s,box-shadow .2s}
.tcard:hover{transform:translateY(-5px);box-shadow:0 20px 44px rgba(0,0,0,.4)}
.tcard .thumb{position:relative;aspect-ratio:16/10;background:#0c2628;overflow:hidden}
.tcard .thumb img{width:100%;height:100%;object-fit:cover;object-position:top center;transition:transform .5s}
.tcard:hover .thumb img{transform:scale(1.04)}
.tcard .thumb .ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:42px;color:#2f6f6b;background:linear-gradient(135deg,#123c40,#0c2628)}
.tcard .live{position:absolute;top:10px;left:10px;display:inline-flex;align-items:center;gap:6px;background:rgba(11,16,17,.85);color:#fff;font-size:10px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;padding:5px 9px;border-radius:999px}
.tcard .live .ld{width:6px;height:6px;border-radius:50%;background:#3ee8a0;box-shadow:0 0 8px #3ee8a0}
.tcard .info{padding:14px 16px}
.tcard .info h3{color:#0b1011;font-size:16px;font-weight:700}
.tcard .by{color:#5d7370;font-size:13px;margin-top:3px}
.tcard .by b{color:#0b1011;font-weight:600}
.tcard .stats{display:flex;gap:18px;margin-top:12px;color:#5d7370;font-size:13px;font-weight:600}
.tcard .stats span{display:inline-flex;align-items:center;gap:6px}
.tcard .stats svg{width:15px;height:15px;fill:currentColor}

/* ===== Blog ===== */
.post{display:flex;flex-direction:column;gap:14px;background:var(--ink-2);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:transform .2s,border-color .2s}
.post:hover{transform:translateY(-4px);border-color:var(--teal)}
.post .thumb{aspect-ratio:16/9;background:linear-gradient(135deg,#123c40,#0c2628);display:flex;align-items:center;justify-content:center;font-size:34px;color:#2f6f6b}
.post .body{padding:22px}
.post .cat{font-size:11px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--teal-bright)}
.post h3{margin:8px 0;font-size:20px}
.post p{font-size:14px}
.post .date{font-size:13px;color:var(--muted);margin-top:12px}

/* ===== Forms ===== */
.field{display:flex;flex-direction:column;gap:7px;margin-bottom:18px}
.field label{font-size:13px;font-weight:700;color:#cfe6e4}
.field input,.field textarea,.field select{background:var(--ink-2);border:1px solid var(--line);border-radius:12px;padding:14px 16px;color:#fff;font:inherit;font-size:15px}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--teal)}
.field textarea{min-height:140px;resize:vertical}

/* ===== Footer ===== */
.footer{background:var(--ink-2);border-top:1px solid var(--line);padding:64px 0 36px;margin-top:0}
.footer .top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:30px}
@media (max-width:760px){.footer .top{grid-template-columns:1fr 1fr}}
@media (max-width:480px){.footer .top{grid-template-columns:1fr}}
.footer h4{font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:16px}
.footer a{display:block;color:#cfe6e4;font-size:14px;padding:5px 0;transition:color .15s}
.footer a:hover{color:var(--teal-bright)}
.footer .brand{font-weight:800;font-size:20px;color:#fff;margin-bottom:14px;display:flex;align-items:center;gap:12px}
.footer .brand .footmark{height:46px;width:auto;display:block}
.footer .brand .dot{display:inline-block;width:10px;height:10px;border-radius:50%;background:var(--teal);box-shadow:0 0 12px var(--teal);margin-left:4px}
.footer .legal{margin-top:40px;padding-top:24px;border-top:1px solid var(--line);display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;color:var(--muted);font-size:13px}

/* ===== Reveal on scroll ===== */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ===== Page hero (inner pages) ===== */
.pagehero{padding:160px 0 60px;border-bottom:1px solid var(--line);background:radial-gradient(80% 120% at 50% 0%,rgba(25,184,176,.12),transparent 60%)}
.pagehero p{margin-top:14px}

/* ===== Custom pixel cursor (fine-pointer devices only) ===== */
@media (hover:hover) and (pointer:fine){
  body.has-cursor{cursor:none}
  body.has-cursor a,body.has-cursor button,body.has-cursor .btn,body.has-cursor [role=button],body.has-cursor input,body.has-cursor textarea,body.has-cursor select{cursor:none}
  #cursor{position:fixed;top:0;left:0;width:30px;height:34px;z-index:9999;pointer-events:none;transform:translate(-2px,-2px);transition:transform .12s ease,opacity .2s;will-change:transform}
  #cursor svg{width:100%;height:100%;display:block;filter:drop-shadow(0 2px 4px rgba(0,0,0,.4))}
  #cursor.hover{transform:translate(-2px,-2px) scale(1.5)}
  #cursor.down{transform:translate(-2px,-2px) scale(.8)}
  #cursor.hidden{opacity:0}
}

/* ===== Brand loader (first visit) ===== */
#tqloader{position:fixed;inset:0;z-index:10000;background:#0b1011;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:22px;
  transition:transform .65s cubic-bezier(.76,0,.24,1),opacity .4s}
#tqloader.out{transform:translateY(-100%)}
#tqloader .logobox{width:min(320px,66vw);position:relative;display:flex;align-items:center;justify-content:center}
#tqloader img,#tqloader video{width:100%;height:auto;display:block;animation:logoIn 1s cubic-bezier(.22,1,.36,1)}
/* full-bleed when a real logo video is playing */
#tqloader.hasvideo{background:#181d20}
#tqloader.hasvideo .logobox{position:absolute;inset:0;width:100%;height:100%}
#tqloader.hasvideo video{width:100%;height:100%;object-fit:cover;animation:none}
#tqloader.hasvideo .bar{position:absolute;bottom:42px;left:50%;transform:translateX(-50%)}
#tqloader .shine{position:absolute;inset:0;pointer-events:none;
  -webkit-mask:url('logo.png') center/contain no-repeat;mask:url('logo.png') center/contain no-repeat;
  background:linear-gradient(115deg,transparent 42%,rgba(255,255,255,.85) 50%,transparent 58%);
  background-size:280% 100%;background-position:200% 0;animation:shine 2s ease-in-out .4s infinite}
@keyframes shine{0%{background-position:200% 0}60%,100%{background-position:-120% 0}}
#tqloader .fallback{font-family:var(--display);font-weight:700;font-size:clamp(26px,5vw,44px);color:#fff;letter-spacing:.04em;text-align:center;animation:logoIn 1s ease}
#tqloader .fallback small{display:block;font-size:.4em;letter-spacing:.5em;color:var(--teal);margin-top:8px;font-weight:600}
#tqloader .bar{width:min(220px,50vw);height:3px;border-radius:3px;background:rgba(255,255,255,.12);overflow:hidden}
#tqloader .bar i{display:block;height:100%;width:0;background:var(--teal);box-shadow:0 0 12px var(--teal);animation:fill 1.7s ease forwards}
@keyframes logoIn{from{opacity:0;transform:scale(.9)}to{opacity:1;transform:none}}
@keyframes fill{to{width:100%}}

/* ===== Page fade transition (bulletproof: transparent base, can't get stuck) ===== */
#pageFade{position:fixed;inset:0;background:#0b1011;z-index:9990;pointer-events:none;opacity:0;animation:pgOut .55s ease}
@keyframes pgOut{0%{opacity:1}100%{opacity:0}}

/* ===== Page transition overlay (teal wipe) ===== */
#trans{position:fixed;inset:0;z-index:9998;background:var(--teal);transform:translateY(100%);pointer-events:none}
#trans.cover{transform:translateY(0)}
#trans.reveal{transform:translateY(-100%)}
#trans.anim{transition:transform .55s cubic-bezier(.76,0,.24,1)}
#trans .tlogo{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:var(--display);font-weight:700;font-size:clamp(22px,4vw,40px);color:var(--ink);letter-spacing:-.02em;opacity:0;transition:opacity .25s}
#trans.cover .tlogo{opacity:1}

/* ===== Kinetic headline reveal ===== */
.kinetic .line{display:block;overflow:hidden}
.kinetic .line > span{display:block;transform:translateY(105%);transition:transform .8s cubic-bezier(.22,1,.36,1)}
.kinetic.in .line > span{transform:none}
.kinetic.in .line:nth-child(2) > span{transition-delay:.08s}
.kinetic.in .line:nth-child(3) > span{transition-delay:.16s}

/* ===== Service marquee (big, scroll-reactive) ===== */
.bigmarquee{overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:26px 0;background:var(--ink)}
.bigmarquee .track{display:flex;gap:48px;width:max-content;will-change:transform}
.bigmarquee .item{font-family:var(--display);font-weight:700;font-size:clamp(30px,5vw,64px);letter-spacing:-.02em;color:#16302f;white-space:nowrap;text-transform:uppercase;-webkit-text-stroke:1px var(--teal-dark)}
.bigmarquee .item.fill{color:var(--teal);-webkit-text-stroke:0}
.bigmarquee .star{color:var(--teal);font-size:clamp(24px,4vw,48px);align-self:center}

/* Magnetic button feel */
.btn{will-change:transform}

/* ===== Fragmented vs integrated wedge ===== */
.wedge{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:14px}
@media (max-width:760px){.wedge{grid-template-columns:1fr}}
.wedge .col{border-radius:var(--radius);padding:30px;border:1px solid var(--line)}
.wedge .mess{background:#16100f;border-color:rgba(255,120,90,.22)}
.wedge .engine{background:linear-gradient(160deg,rgba(25,184,176,.14),var(--ink-2));border-color:var(--teal)}
.wedge h3{font-size:20px;margin-bottom:6px}
.wedge .tag{font-size:12px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;margin-bottom:18px;display:inline-block}
.wedge .mess .tag{color:#e8916f}
.wedge .engine .tag{color:var(--teal-bright)}
.wedge ul{list-style:none;display:flex;flex-direction:column;gap:12px}
.wedge li{font-size:15px;padding-left:30px;position:relative;color:#cfe6e4}
.wedge .mess li{color:#caa79c}
.wedge .mess li::before{content:"✕";position:absolute;left:0;color:#d8694a;font-weight:800}
.wedge .engine li::before{content:"✓";position:absolute;left:0;color:var(--teal-bright);font-weight:800}
.wedge .engine .foot{margin-top:22px;font-family:var(--display);font-weight:600;color:#fff;font-size:18px}

/* ===== Studio hero (About) ===== */
.studio-hero{position:relative;min-height:92vh;display:flex;align-items:flex-end;overflow:hidden;
  background:radial-gradient(120% 90% at 50% 10%,#1f6f6a,#0c2e2c 60%,var(--ink));}
.studio-hero .photo{position:absolute;inset:0;background-size:cover;background-position:center 30%;opacity:.85}
.studio-hero .photo::after{content:"";position:absolute;inset:0;background:linear-gradient(transparent 30%,rgba(8,18,18,.85))}
.studio-hero .ph-note{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:1;color:rgba(255,255,255,.5);font-size:13px;font-weight:600;letter-spacing:.04em;text-align:center;border:1px dashed rgba(255,255,255,.3);padding:14px 20px;border-radius:12px;max-width:80%}
.studio-hero .inner{position:relative;z-index:2;width:100%;padding:0 0 8vh}
.studio-hero .big{font-family:var(--display);font-weight:700;font-size:clamp(48px,12vw,160px);line-height:.92;letter-spacing:-.03em;color:#fff;text-shadow:0 4px 30px rgba(0,0,0,.4)}
.studio-hero .sub{margin-top:18px;max-width:54ch;font-size:clamp(16px,1.6vw,21px);color:#dff3f1}
.studio-hero .floatcur{position:absolute;z-index:3;width:54px;height:60px;top:28%;right:14%;animation:floaty 4s ease-in-out infinite;filter:drop-shadow(0 6px 14px rgba(0,0,0,.4))}
@keyframes floaty{0%,100%{transform:translateY(0) rotate(-4deg)}50%{transform:translateY(-16px) rotate(2deg)}}

/* status ticker */
.ticker{display:inline-flex;align-items:center;gap:12px;margin-top:26px;background:rgba(8,22,22,.55);border:1px solid var(--line);backdrop-filter:blur(4px);padding:12px 18px;border-radius:999px;font-size:15px}
.ticker .dot{width:9px;height:9px;border-radius:50%;background:#3ee8a0;box-shadow:0 0 10px #3ee8a0;flex:0 0 9px}
.ticker .lbl{color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.1em;font-size:12px}
.ticker .txt{color:#fff;font-weight:600;font-family:var(--display)}
.ticker .txt.swap{animation:tswap .4s ease}
@keyframes tswap{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* hover-flip team cards */
.flip{perspective:1000px;background:none;border:0;padding:0}
.flip .inner{position:relative;width:100%;aspect-ratio:3/4;transform-style:preserve-3d;transition:transform .6s cubic-bezier(.4,.2,.2,1)}
.flip:hover .inner{transform:rotateY(180deg)}
.flip .face{position:absolute;inset:0;backface-visibility:hidden;border-radius:14px;overflow:hidden;display:flex;align-items:flex-end;border:1px solid var(--line)}
.flip .face img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.flip .front{background:linear-gradient(135deg,#16302f,#0c2628)}
.flip .back{transform:rotateY(180deg);background:linear-gradient(135deg,#19b8b0,#0c726d)}
.flip .ph-letter{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--display);font-weight:700;font-size:48px;color:rgba(255,255,255,.35)}
.flip .cap{position:relative;z-index:2;width:100%;padding:14px 16px;background:linear-gradient(transparent,rgba(6,13,14,.9))}
.flip .back .cap{background:linear-gradient(transparent,rgba(7,40,38,.85))}
.flip .cap h3{font-size:17px}
.flip .cap .role{font-size:12px;color:#cfe6e4;margin-top:2px}
.flip .hint{position:absolute;top:12px;right:12px;z-index:3;font-size:10px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:#cfe6e4;background:rgba(6,13,14,.5);padding:4px 8px;border-radius:999px}
