/* ============================================================
   TENSLY V2 — Light Editorial Design System
   Self-contained, no framework. Brand red kept as sharp accent.
   ============================================================ */

/* ---- Reset ---- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:auto}
img,svg,video{display:block;max-width:100%}
button,input,select,textarea{font:inherit;color:inherit}
a{color:inherit;text-decoration:none}
ul{list-style:none}
:focus-visible{outline:2px solid var(--red);outline-offset:3px;border-radius:2px}

/* ---- Tokens ---- */
:root{
  --paper:#f3f3f1;         /* soft off-white page base (not stark white, not cream) */
  --surface:#ffffff;       /* crisp white — cards, frames, inputs pop against the base */
  --paper-2:#e9e8e5;       /* deeper alt section */
  --paper-3:#ddddd8;
  --ink:#141416;
  --ink-2:#52525a;         /* secondary text ~7:1 */
  --ink-3:#76757c;         /* labels ~4.8:1 */
  --line:#e1e0db;
  --line-2:#e8e7e3;
  --red:#fe4444;           /* brand: fills, large type, accents */
  --red-text:#d62a2a;      /* accessible red for small text on white */
  --red-deep:#e22f2f;      /* hover */
  /* muted accent tints (graphic colour, used sparingly) */
  --pale-red:#fdecec;   --pale-red-ink:#b02f2c;
  --pale-blue:#e7f1fb;  --pale-blue-ink:#1f6c9f;
  --pale-green:#eaf3ec; --pale-green-ink:#346538;
  --pale-amber:#fbf2dc; --pale-amber-ink:#8a5d00;
  --coal:#121214;          /* dark blocks */
  --coal-2:#1b1b1f;
  --on-coal:#f4f3f1;
  --on-coal-2:rgba(244,243,241,.66);
  --on-coal-3:rgba(244,243,241,.42);
  --line-coal:rgba(255,255,255,.12);

  --display:'Bricolage Grotesque','Space Grotesk',system-ui,sans-serif;
  --sans:'Inter',system-ui,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,'SF Mono',monospace;

  --r:16px; --r-sm:10px; --r-lg:22px;
  --ease:cubic-bezier(.16,1,.3,1);
  --maxw:1280px;
  --gutter:clamp(20px,5vw,40px);
}

html,body{background:var(--paper)}
body{
  font-family:var(--sans);
  color:var(--ink);
  font-size:16px;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
::selection{background:var(--red);color:#fff}

/* ---- Layout ---- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--gutter);padding-right:var(--gutter)}
.sec{padding:clamp(64px,9vw,128px) 0}
.sec-sm{padding:clamp(44px,6vw,72px) 0}
.hairline{height:1px;background:var(--line);border:0}

/* ---- Typography ---- */
.display{font-family:var(--display);font-weight:700;letter-spacing:-.03em;line-height:1;color:var(--ink);text-wrap:balance}
h1,h2,h3,h4{font-family:var(--display);font-weight:700;letter-spacing:-.025em;color:var(--ink);text-wrap:balance}
.h-hero{font-size:clamp(2.6rem,7vw,6rem);line-height:.95;letter-spacing:-.04em;font-weight:800}
.h-1{font-size:clamp(2rem,4.6vw,3.6rem);line-height:1.02}
.h-2{font-size:clamp(1.5rem,3vw,2.3rem);line-height:1.06}
.h-3{font-size:clamp(1.15rem,1.8vw,1.4rem);line-height:1.15}
.lead{font-size:clamp(1.02rem,1.5vw,1.2rem);line-height:1.6;color:var(--ink-2);max-width:54ch}
.body{color:var(--ink-2);line-height:1.62}
.muted{color:var(--ink-3)}
.tnum{font-variant-numeric:tabular-nums}

.eyebrow{font-family:var(--mono);font-size:11px;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--red-text);display:inline-flex;align-items:center;gap:.6rem}
.eyebrow::before{content:"";width:20px;height:2px;background:var(--red);display:inline-block}
.kicker{font-family:var(--mono);font-size:11px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3)}

/* red underline accent (drawn) */
.uline{position:relative;white-space:nowrap}
.uline svg{position:absolute;left:0;right:0;bottom:-.16em;width:100%;height:.36em;overflow:visible}
.uline path{fill:none;stroke:var(--red);stroke-width:7;stroke-linecap:round;stroke-dasharray:640;stroke-dashoffset:640}
.js .uline.draw path{animation:draw 1s var(--ease) .35s forwards}
@keyframes draw{to{stroke-dashoffset:0}}

/* ---- Buttons ---- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;font-weight:600;font-size:.92rem;line-height:1;padding:.92rem 1.5rem;border-radius:999px;cursor:pointer;border:1px solid transparent;transition:transform .22s var(--ease),background .22s ease,color .2s ease,border-color .22s ease,box-shadow .22s ease;white-space:nowrap}
.btn svg{width:15px;height:15px}
.btn-primary{background:var(--red);color:#fff;box-shadow:0 12px 26px -12px rgba(254,68,68,.7)}
.btn-primary:hover{background:var(--red-deep);transform:translateY(-2px);box-shadow:0 16px 30px -12px rgba(254,68,68,.75)}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{background:#000;transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--ink);transform:translateY(-2px)}
.btn-sm{padding:.62rem 1.15rem;font-size:.85rem}
.btn:active{transform:translateY(0)}
.link-arrow{display:inline-flex;align-items:center;gap:.45rem;font-weight:600;color:var(--ink);transition:gap .2s ease}
.link-arrow svg{width:14px;height:14px;transition:transform .25s var(--ease)}
.link-arrow:hover svg{transform:translate(3px,-3px)}

/* ---- Header ---- */
#hdr{position:fixed;top:0;left:0;right:0;z-index:60;transition:background .3s ease,box-shadow .3s ease,border-color .3s ease}
#hdr .bar{height:74px;display:flex;align-items:center;gap:2rem}
#hdr.scrolled{background:rgba(255,255,255,.82);backdrop-filter:blur(18px) saturate(150%);-webkit-backdrop-filter:blur(18px) saturate(150%);border-bottom:1px solid var(--line)}
.hdr-logo{color:var(--ink);height:30px;width:auto;flex-shrink:0}
.nav{display:flex;align-items:center;gap:1.9rem;margin:0 auto}
.nav a{position:relative;font-size:.92rem;font-weight:500;color:var(--ink-2);transition:color .2s ease}
.nav a:hover{color:var(--ink)}
.nav a::after{content:"";position:absolute;left:0;right:100%;bottom:-6px;height:2px;background:var(--red);transition:right .28s var(--ease)}
.nav a:hover::after{right:0}
.nav a.nav-accent,#mobnav a.nav-accent{color:var(--red-text);font-weight:600}
.nav a.nav-accent:hover{color:var(--red)}
.hdr-cta{flex-shrink:0}
#burger{display:none;margin-left:auto;width:44px;height:44px;align-items:center;justify-content:center;cursor:pointer;background:none;border:0;color:var(--ink)}
#burger line{stroke:currentColor;stroke-width:1.8;stroke-linecap:round;transform-box:fill-box;transform-origin:center;transition:transform .32s var(--ease),opacity .2s ease}
#burger.open line:nth-child(1){transform:translateY(5px) rotate(45deg)}
#burger.open line:nth-child(2){opacity:0}
#burger.open line:nth-child(3){transform:translateY(-5px) rotate(-45deg)}
#mobnav{display:none;background:rgba(255,255,255,.97);backdrop-filter:blur(18px);border-top:1px solid var(--line)}
#mobnav .inner{padding:18px var(--gutter) 24px;display:flex;flex-direction:column;gap:2px}
#mobnav a{padding:12px 10px;font-weight:500;color:var(--ink-2);border-radius:10px}
#mobnav a:hover{background:var(--paper-2);color:var(--ink)}
@keyframes mob-in{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}
#mobnav.in{display:block;animation:mob-in .26s var(--ease)}

/* ---- Hero ---- */
.hero{padding-top:clamp(118px,15vw,168px);padding-bottom:clamp(48px,7vw,84px);position:relative}
.hero-top{display:flex;align-items:flex-start;justify-content:space-between;gap:2rem;margin-bottom:clamp(28px,4vw,44px)}
.hero-idx{font-family:var(--mono);font-size:11px;letter-spacing:.14em;color:var(--ink-3);text-align:right;line-height:1.7;flex-shrink:0}
.hero h1{margin-bottom:clamp(28px,4vw,40px)}
.hero-grid{display:grid;grid-template-columns:1fr;gap:clamp(36px,5vw,64px);align-items:end}
@media(min-width:980px){.hero-grid{grid-template-columns:1.05fr .95fr}}
.hero-sub{margin-bottom:2rem}
.hero-cta{display:flex;flex-wrap:wrap;gap:.7rem;margin-bottom:1.6rem}
.hero-meta{font-family:var(--mono);font-size:11px;letter-spacing:.04em;color:var(--ink-3);display:flex;flex-wrap:wrap;gap:.4rem 1.2rem}

/* Browser frame for real screenshot */
.frame{border-radius:var(--r);overflow:hidden;border:1px solid var(--line);background:#fff;box-shadow:0 30px 60px -30px rgba(18,18,20,.32),0 8px 20px -12px rgba(18,18,20,.12)}
.frame-bar{display:flex;align-items:center;gap:6px;padding:11px 14px;background:var(--paper-2);border-bottom:1px solid var(--line)}
.frame-bar .dot{width:10px;height:10px;border-radius:50%;background:#d6d5d2}
.frame-bar .url{margin-left:8px;flex:1;background:#fff;border:1px solid var(--line);border-radius:7px;padding:5px 12px;font-family:var(--mono);font-size:11px;color:var(--ink-3)}
.frame-img{position:relative;aspect-ratio:16/11;background:var(--paper-2);overflow:hidden}
.frame-img img{width:100%;height:100%;object-fit:cover;object-position:top}
.frame-cap{margin-top:14px;display:flex;justify-content:space-between;align-items:center;gap:1rem;font-size:.85rem}
.frame-cap .nm{font-weight:600;color:var(--ink)}
.frame-cap .tg{font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--red-text)}

/* ---- Section heading ---- */
.shead{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:1.2rem 2rem;margin-bottom:clamp(34px,5vw,56px)}
.shead .kicker{margin-bottom:1rem;display:block}

/* ---- Logo wall ---- */
.logos{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:clamp(28px,5vw,64px)}
.logos img{height:24px;width:auto;filter:grayscale(1) brightness(0);opacity:.42;transition:opacity .25s ease}
.logos img:hover{opacity:.85}

/* ---- Work gallery ---- */
.work-grid{display:grid;grid-template-columns:1fr;gap:clamp(28px,3.4vw,44px);align-items:start}
@media(min-width:760px){.work-grid{grid-template-columns:1fr 1fr}}
.work-stack{display:flex;flex-direction:column;gap:clamp(22px,2.8vw,34px)}
.work-trio{display:grid;grid-template-columns:1fr;gap:clamp(22px,2.8vw,34px)}
@media(min-width:720px){.work-trio{grid-template-columns:repeat(3,1fr)}}
.work{display:block}
.work .shot{position:relative;border-radius:var(--r);overflow:hidden;background:var(--paper-2);border:1px solid var(--line)}
.work .shot img{position:relative;z-index:2;display:block;width:100%;height:auto;transition:transform .7s var(--ease)}
.work .shot .cover-compose{aspect-ratio:4/3}
.work:hover .shot img{transform:scale(1.04)}
.work.tall .shot{aspect-ratio:4/3}
@media(min-width:760px){.work.feature{grid-column:span 2}}
.work .meta{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;margin-top:18px}
.work .meta h3{font-size:clamp(1.25rem,2vw,1.6rem);letter-spacing:-.02em}
.work .meta .res{font-size:.9rem;color:var(--ink-2);margin-top:4px}
.work .meta .tagsec{font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--red-text);white-space:nowrap}
.work .seeline{display:inline-flex;align-items:center;gap:.4rem;font-weight:600;font-size:.86rem;color:var(--ink);margin-top:10px}
.work .seeline svg{width:13px;height:13px;transition:transform .25s var(--ease)}
.work:hover .seeline svg{transform:translate(3px,-3px)}
/* composed cover when no image */
.cover-compose{position:absolute;inset:0;z-index:1;display:flex;flex-direction:column;justify-content:space-between;padding:clamp(20px,3vw,32px);background:var(--paper-2)}
.cover-compose .num{font-family:var(--display);font-weight:800;font-size:clamp(3rem,7vw,5.4rem);line-height:.8;color:var(--paper-3);letter-spacing:-.04em}
.cover-compose .tag{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--red-text)}
.cover-compose .nm{font-family:var(--display);font-weight:700;font-size:clamp(1.3rem,2.4vw,1.9rem);color:var(--ink);letter-spacing:-.02em}
.cover-compose .rl{font-size:.86rem;color:var(--ink-2);margin-top:4px}


/* ---- Services editorial list ---- */
.svc-list{border-top:1px solid var(--line)}
.svc{display:grid;grid-template-columns:auto 1fr auto;gap:1.4rem;align-items:center;padding:clamp(26px,3.4vw,40px) 0;border-bottom:1px solid var(--line);position:relative;transition:padding-left .35s var(--ease)}
.svc .n{font-family:var(--mono);font-size:.82rem;color:var(--ink-3);align-self:start;padding-top:.55rem;transition:color .3s ease}
.svc .nm{font-family:var(--display);font-weight:700;font-size:clamp(1.7rem,4vw,2.9rem);line-height:1.02;letter-spacing:-.025em;color:var(--ink);transition:color .25s ease}
.svc .ds{color:var(--ink-2);font-size:.95rem;line-height:1.55;max-width:56ch;margin-top:.7rem}
.svc .tg{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:1rem}
.tag{font-family:var(--mono);font-size:10.5px;letter-spacing:.03em;color:var(--ink-2);border:1px solid var(--line);border-radius:999px;padding:.3rem .72rem}
.svc .go{width:48px;height:48px;border-radius:999px;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--ink-3);align-self:start;flex-shrink:0;transition:all .3s var(--ease)}
.svc::after{content:"";position:absolute;left:0;bottom:-1px;height:2px;width:0;background:var(--red);transition:width .4s var(--ease)}
.svc:hover{padding-left:.8rem}
.svc:hover::after{width:100%}
.svc:hover .n{color:var(--red-text)}
.svc:hover .go{background:var(--red);border-color:var(--red);color:#fff;transform:translate(2px,-2px)}

/* ---- Dark statement band ---- */
.band-dark{background:var(--coal);color:var(--on-coal)}
.band-dark .grain{position:absolute;inset:0;opacity:.5;mix-blend-mode:overlay;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.statement{font-family:var(--display);font-weight:700;letter-spacing:-.03em;line-height:1.1;font-size:clamp(1.9rem,4.4vw,3.3rem);color:var(--ink);text-wrap:balance}
.statement .ac{color:var(--red)}
.statement .sl{display:block}
.js .statement .sl{opacity:0;transform:translateY(.32em);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.statement .sl.in{opacity:1;transform:none}
.steps{display:grid;grid-template-columns:1fr;gap:0}
.step{display:grid;grid-template-columns:auto 1fr;gap:1.1rem;padding:1.5rem 0;border-top:1px solid var(--line);align-items:baseline}
.step .sn{font-family:var(--mono);font-size:.78rem;color:var(--red-text)}
.step h4{font-family:var(--display);color:var(--ink);font-size:1.05rem;margin-bottom:.35rem}
.step p{color:var(--ink-2);font-size:.88rem;line-height:1.55}

/* ---- Pricing ---- */
.toggle{display:inline-flex;position:relative;background:var(--paper-2);border:1px solid var(--line);border-radius:999px;padding:5px}
.toggle .slide{position:absolute;top:5px;bottom:5px;left:5px;border-radius:999px;background:var(--ink);transition:transform .34s var(--ease),width .34s var(--ease),background .25s ease;pointer-events:none}
.toggle.abo .slide{background:var(--red)}
.toggle button{position:relative;z-index:1;border:0;background:none;cursor:pointer;font-weight:600;font-size:.86rem;padding:.62rem 1.3rem;border-radius:999px;color:var(--ink-3);transition:color .25s ease;white-space:nowrap}
.toggle button.active{color:#fff}
.plans{display:grid;grid-template-columns:1fr;gap:18px}
@media(min-width:640px){.plans{grid-template-columns:1fr 1fr}}
@media(min-width:1080px){.plans{grid-template-columns:repeat(4,1fr)}}
.plan{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:1.7rem;display:flex;flex-direction:column;position:relative;transition:transform .28s var(--ease),box-shadow .28s ease,border-color .25s ease}
.plan:hover{transform:translateY(-4px);box-shadow:0 24px 50px -28px rgba(18,18,20,.28)}
.plan--featured{border-color:var(--red);box-shadow:0 0 0 1px var(--red),0 26px 56px -30px rgba(254,68,68,.5)}
.plan .pl{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);margin-bottom:.8rem}
.plan .price{display:flex;align-items:flex-end;gap:.5rem;margin-bottom:.2rem}
.price-num{font-family:var(--display);font-weight:800;font-size:2.5rem;letter-spacing:-.04em;line-height:1;color:var(--ink)}
.price-dec{font-family:var(--display);font-weight:700;font-size:1.05rem;color:var(--ink);margin-bottom:.25rem}
.price-old{font-size:.85rem;color:var(--ink-3);text-decoration:line-through;margin-bottom:.35rem}
.price-period{font-family:var(--mono);font-size:.72rem;color:var(--ink-3);margin-bottom:1.2rem}
.plan .desc{font-size:.86rem;color:var(--ink-2);line-height:1.55;margin-bottom:1.3rem;flex:0 0 auto}
.plan ul{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.4rem;flex:1}
.plan li{display:flex;align-items:center;gap:.55rem;font-size:.85rem;color:var(--ink-2)}
.plan li svg{width:15px;height:15px;flex-shrink:0}
.badge{position:absolute;top:-11px;left:1.7rem;font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;padding:.32rem .7rem;border-radius:999px}
.badge-red{background:var(--red);color:#fff}
.badge-line{background:var(--surface);border:1px solid var(--red);color:var(--red-text)}
.abo-note{display:none;align-items:center;gap:.5rem;font-size:.74rem;color:var(--ink-3);background:var(--paper-2);border:1px solid var(--line);border-radius:10px;padding:.55rem .75rem;margin-bottom:.9rem}
.abo-note.on{display:flex}
.abo-note svg{width:14px;height:14px;flex-shrink:0}
@keyframes pout{to{opacity:0;transform:translateY(-6px)}}
@keyframes pin{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.flip-out{animation:pout .16s ease forwards}
.flip-in{animation:pin .22s var(--ease) forwards}
#pitch{overflow:hidden;max-height:0;opacity:0;transition:max-height .6s var(--ease),opacity .4s ease,margin-bottom .5s ease}
#pitch.on{max-height:720px;opacity:1;margin-bottom:2.4rem}
.pitch-card{background:var(--paper-2);border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(1.6rem,3vw,2.6rem)}

/* ---- Audit ---- */
.audit-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}
.audit-item{display:grid;grid-template-columns:auto 1fr;gap:1.1rem;padding:1.5rem 0}
.audit-ic{width:42px;height:42px;border-radius:11px;background:rgba(254,68,68,.08);display:flex;align-items:center;justify-content:center;flex-shrink:0}

/* ---- Contact ---- */
.field label{display:block;font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);margin-bottom:.5rem}
.inp{width:100%;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-sm);padding:.85rem 1rem;font-size:.92rem;color:var(--ink);transition:border-color .2s ease,box-shadow .2s ease}
.inp::placeholder{color:var(--ink-3)}
.inp:focus{outline:none;border-color:var(--red);box-shadow:0 0 0 3px rgba(254,68,68,.12)}
textarea.inp{resize:vertical;min-height:120px}
select.inp{appearance:none;-webkit-appearance:none;-moz-appearance:none;cursor:pointer;padding-right:2.8rem;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 16 16' fill='none' stroke='%2354545a' stroke-width='1.7' stroke-linecap='round' stroke-linejoin='round'><path d='M4 6l4 4 4-4'/></svg>");background-repeat:no-repeat;background-position:right 1rem center}
select.inp::-ms-expand{display:none}
select.inp:has(option[value=""]:checked){color:var(--ink-3)}
select.inp option{color:var(--ink);background:var(--surface)}
select.inp option[value=""]{color:var(--ink-3)}
.form-status{display:none;margin-top:.4rem;padding:.8rem 1rem;border-radius:var(--r-sm);font-size:.88rem;font-weight:500;line-height:1.45}
.form-status.ok{background:var(--pale-green);color:var(--pale-green-ink);border:1px solid rgba(52,101,56,.22)}
.form-status.err{background:var(--pale-red);color:var(--pale-red-ink);border:1px solid rgba(176,47,44,.22)}
.btn:disabled{opacity:.6;cursor:default;transform:none}

/* ---- Footer ---- */
footer{background:var(--coal);color:var(--on-coal-2)}
footer .ft-logo{color:#fff;height:30px;width:auto}
footer a{color:var(--on-coal-2);transition:color .2s ease}
footer a:hover{color:#fff}
.ft-h{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--on-coal-3);margin-bottom:1.1rem}
.ft-grid{display:flex;flex-wrap:wrap;justify-content:space-between;gap:2.4rem;padding-bottom:3rem;border-bottom:1px solid var(--line-coal)}
.ft-links{display:flex;flex-wrap:wrap;gap:2.6rem}
.ft-col li{margin-bottom:.7rem;font-size:.88rem}

/* ---- Background graphic system (subtle, lively) ---- */
.has-gfx{position:relative;overflow:hidden}
.has-gfx > .wrap{position:relative;z-index:1}
.has-gfx::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;background-image:radial-gradient(rgba(18,18,20,.5) 1px,transparent 1px);background-size:26px 26px;opacity:.06}
.band-red.has-gfx::before{background-image:radial-gradient(rgba(255,255,255,.6) 1px,transparent 1px);opacity:.07}
.gfx{position:absolute;z-index:0;pointer-events:none}
.gfx-ring{border:1.5px solid rgba(18,18,20,.11);border-radius:50%}
.gfx-ring.dashed{border-style:dashed}
.gfx-ring.red{border-color:rgba(254,68,68,.22)}
.gfx-ring.w{border-color:rgba(255,255,255,.22)}
.gfx-cross{color:rgba(254,68,68,.32)}
.gfx-cross.ink{color:rgba(18,18,20,.14)}
.gfx-cross.w{color:rgba(255,255,255,.5)}
.gfx-cross svg{width:100%;height:100%}
.gfx-sq{border-radius:12px;background:var(--pale-blue);opacity:.6}
@keyframes gfx-spin{to{transform:rotate(360deg)}}
@keyframes gfx-float{0%,100%{transform:translateY(0)}50%{transform:translateY(-28px)}}
@keyframes gfx-drift{0%,100%{transform:translate(0,0)}50%{transform:translate(16px,-14px)}}
.gfx-spin{animation:gfx-spin 55s linear infinite}
.gfx-float{animation:gfx-float 9s ease-in-out infinite}
.gfx-drift{animation:gfx-drift 14s ease-in-out infinite}
@media(max-width:680px){.gfx{opacity:.6}.gfx-hide-m{display:none}}
@media(prefers-reduced-motion:reduce){.gfx-spin,.gfx-float{animation:none}}

/* ---- Reveal ---- */
.js .reveal{opacity:0;transform:translateY(16px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.js .reveal.vis{opacity:1;transform:none}
.d1{transition-delay:.06s}.d2{transition-delay:.12s}.d3{transition-delay:.18s}.d4{transition-delay:.24s}

/* ---- Scroll progress ---- */
#prog{position:fixed;top:0;left:0;height:2px;width:0;background:var(--red);z-index:100;pointer-events:none}

/* ---- Intro loader (typographic curtain) ---- */
html:not(.js) #loader{display:none}
#loader{position:fixed;inset:0;z-index:200;background:var(--ink);display:flex;align-items:center;justify-content:center;transition:transform .85s cubic-bezier(.76,0,.24,1)}
#loader.gone{transform:translateY(-101%)}
.lstage{position:relative;display:flex;align-items:center;justify-content:center;min-height:1.4em;padding:0 24px}
.lword{font-family:var(--display);font-weight:700;font-size:clamp(1.9rem,5vw,3.3rem);letter-spacing:-.03em;color:#fff;white-space:nowrap;transition:opacity .25s ease,transform .35s var(--ease)}
.lword .pt{color:var(--red)}
.llogo{position:absolute;left:50%;top:50%;transform:translate(-50%,calc(-50% + 10px));height:clamp(30px,3.6vw,42px);width:auto;color:#fff;opacity:0;transition:opacity .42s ease .34s,transform .52s var(--ease) .34s}
.lstage.final .lword{opacity:0;transform:translateY(-10px);transition:opacity .22s ease,transform .28s var(--ease)}
.lstage.final .llogo{opacity:1;transform:translate(-50%,-50%)}
@media(prefers-reduced-motion:reduce){#loader,.lword,.llogo{transition:none}}

/* ---- Why Tensly (structural Swiss grid, no cards) ---- */
.why{display:grid;grid-template-columns:1fr;gap:clamp(28px,3vw,40px) clamp(28px,3vw,48px)}
@media(min-width:640px){.why{grid-template-columns:1fr 1fr}}
@media(min-width:1024px){.why{grid-template-columns:repeat(4,1fr)}}
.why-item{padding-top:1.3rem;border-top:1.5px solid var(--ink)}
.why-item .wn{font-family:var(--mono);font-size:.74rem;letter-spacing:.06em;color:var(--red-text);display:block;margin-bottom:1rem}
.why-item h3{font-family:var(--display);font-weight:600;font-size:1.18rem;letter-spacing:-.01em;margin-bottom:.6rem;color:var(--ink)}
.why-item p{color:var(--ink-2);font-size:.92rem;line-height:1.6}

/* ---- Hero: textured backdrop + work collage on a colour stage ---- */
.hero{position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;background-image:radial-gradient(rgba(18,18,20,.55) 1px,transparent 1px);background-size:24px 24px;opacity:.08}
.hero .wrap{position:relative;z-index:1}
/* big technical target motif filling the empty backdrop */
.hero-target{position:absolute;z-index:0;pointer-events:none;width:clamp(380px,46vw,660px);aspect-ratio:1;left:-13%;top:12%}
.hero-target svg{width:100%;height:100%;overflow:visible}
.hero-target .t-line{stroke:rgba(18,18,20,.11);stroke-width:1;fill:none}
.hero-target .t-dash{stroke:rgba(18,18,20,.14);stroke-width:1;fill:none;stroke-dasharray:2 7}
.hero-target .t-center{fill:var(--red)}
.hero-target .t-dot{fill:rgba(18,18,20,.2)}
@media(max-width:760px){.hero-target{width:340px;left:-30%;top:auto;bottom:-6%;opacity:.7}}
.hero figure{position:relative;margin:0}
.hero-stage{position:relative;background:var(--pale-red);border-radius:var(--r-lg);padding:clamp(24px,3vw,42px) clamp(24px,3vw,42px) clamp(38px,4vw,54px)}
.phone{position:absolute;right:-16px;bottom:-20px;width:116px;border-radius:20px;background:#111114;border:4px solid #1c1c22;overflow:hidden;box-shadow:0 24px 50px -22px rgba(18,18,20,.5);z-index:4}
.phone .ph-screen{aspect-ratio:9/18;overflow:hidden}
.phone .ph-screen img{width:100%;height:100%;object-fit:cover;object-position:top}
@media(max-width:680px){.phone{display:none}}
/* graphic composition around the hero visual */
.hero-visual{position:relative}
.hero-visual > figure{position:relative;z-index:1}
.deco{position:absolute;pointer-events:none}
.deco-ring{width:clamp(210px,26vw,330px);aspect-ratio:1;border:1.5px solid rgba(18,18,20,.13);border-radius:50%;top:-17%;right:-13%;z-index:0}
.deco-ring2{width:clamp(120px,15vw,190px);aspect-ratio:1;border:1.5px solid rgba(254,68,68,.35);border-radius:50%;top:-7%;right:-3%;z-index:0}
.deco-dot{width:13px;height:13px;border-radius:50%;background:var(--red);top:-4%;right:24%;z-index:6}
.deco-sq{width:30px;height:30px;border-radius:7px;background:var(--pale-blue);bottom:18%;left:-7%;z-index:6;transform:rotate(8deg)}
.deco-plus{top:9%;left:-4%;z-index:6;color:var(--red)}
.deco-plus svg{width:22px;height:22px}
.deco-tag{bottom:-2%;right:6%;z-index:6;font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:.35rem .7rem}
@media(max-width:680px){.deco-ring,.deco-ring2,.deco-sq,.deco-plus,.deco-tag{display:none}}

/* ---- Services: colourful cards with graphic icons ---- */
.svc-cards{display:grid;grid-template-columns:1fr;gap:18px}
@media(min-width:680px){.svc-cards{grid-template-columns:1fr 1fr}}
@media(min-width:1000px){.svc-cards{grid-template-columns:repeat(3,1fr)}}
.svc-card{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:var(--surface);text-decoration:none;transition:transform .3s var(--ease),box-shadow .3s ease,border-color .25s ease}
.svc-card:hover{transform:translateY(-5px);box-shadow:0 26px 56px -30px rgba(18,18,20,.32)}
.svc-card .scv{position:relative;height:190px;overflow:hidden;background:var(--paper-2)}
.svc-card .scv img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s var(--ease)}
.svc-card:hover .scv img{transform:scale(1.04)}
.svc-card .sbody{padding:1.5rem 1.6rem 1.7rem;display:flex;flex-direction:column;flex:1}
.svc-card h3{font-family:var(--display);font-weight:700;font-size:1.3rem;letter-spacing:-.02em;margin-bottom:.6rem;color:var(--ink)}
.svc-card .sds{color:var(--ink-2);font-size:.9rem;line-height:1.55;margin-bottom:1.1rem;flex:1}
.svc-card .stags{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:1.2rem}
.svc-card .more{display:inline-flex;align-items:center;gap:.4rem;font-weight:600;font-size:.85rem;color:var(--ink);margin-top:auto}
.svc-card .more svg{width:13px;height:13px;transition:transform .25s var(--ease)}
.svc-card:hover .more svg{transform:translate(3px,-3px)}
.tint-red{background:var(--pale-red);color:var(--pale-red-ink)}
.tint-blue{background:var(--pale-blue);color:var(--pale-blue-ink)}
.tint-green{background:var(--pale-green);color:var(--pale-green-ink)}

/* ---- Why: graphic icon chips ---- */
.why-item .wic{width:46px;height:46px;border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:1.1rem}
.why-item .wic svg{width:24px;height:24px}

/* ---- Tech stack row ---- */
.stack{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:clamp(24px,4vw,52px)}
.stack-item{display:inline-flex;align-items:center;gap:.6rem;color:var(--ink-2);font-weight:500;font-size:.92rem}
.stack-item img{height:24px;width:24px;object-fit:contain}

/* ---- Statement as a drenched brand-red band ---- */
.band-red{background:var(--red);color:#fff}
.band-red .statement{color:#fff}
.band-red .statement .ac{color:#fff;text-decoration:underline;text-decoration-color:rgba(255,255,255,.55);text-decoration-thickness:3px;text-underline-offset:6px}
.band-red .step{border-top-color:rgba(255,255,255,.28)}
.band-red .step .sn{color:#fff;opacity:.85}
.band-red .step h4{color:#fff}
.band-red .step p{color:rgba(255,255,255,.82)}

/* ---- FAQ (editorial accordion) ---- */
.faq{border-top:1px solid var(--line);max-width:920px}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding:1.5rem 0;background:none;border:0;cursor:pointer;text-align:left;font-family:var(--display);font-weight:600;font-size:clamp(1.05rem,1.7vw,1.3rem);letter-spacing:-.01em;color:var(--ink);transition:color .2s ease}
.faq-q:hover{color:var(--red-text)}
.faq-ic{flex-shrink:0;width:20px;height:20px;position:relative;margin-top:.15em}
.faq-ic::before,.faq-ic::after{content:"";position:absolute;background:var(--ink);transition:transform .3s var(--ease),background .2s ease}
.faq-ic::before{left:0;top:50%;width:100%;height:2px;transform:translateY(-50%)}
.faq-ic::after{top:0;left:50%;width:2px;height:100%;transform:translateX(-50%)}
.faq-item.open .faq-ic::after{transform:translateX(-50%) scaleY(0)}
.faq-item.open .faq-ic::before{background:var(--red)}
.faq-a{overflow:hidden;max-height:0;transition:max-height .4s var(--ease)}
.faq-a-inner{padding:0 2.5rem 1.6rem 0;color:var(--ink-2);line-height:1.65;font-size:.95rem}

/* ---- Legal pages ---- */
.legal-head{padding:calc(74px + clamp(40px,6vw,72px)) 0 clamp(30px,4vw,46px);border-bottom:1px solid var(--line)}
.breadcrumb{display:flex;align-items:center;gap:.5rem;font-family:var(--mono);font-size:11px;letter-spacing:.04em;color:var(--ink-3);margin-bottom:1.4rem}
.breadcrumb a{color:var(--ink-3)}.breadcrumb a:hover{color:var(--ink)}
.breadcrumb svg{width:11px;height:11px;opacity:.6}
.legal-meta{font-family:var(--mono);font-size:11px;letter-spacing:.04em;color:var(--ink-3);margin-top:1rem}
.legal-body{padding:clamp(44px,6vw,76px) 0}
.legal-prose{max-width:760px}
.legal-prose h2{font-family:var(--display);font-weight:700;font-size:clamp(1.15rem,2.1vw,1.5rem);letter-spacing:-.02em;color:var(--ink);margin:2.4rem 0 .9rem}
.legal-prose h2:first-child{margin-top:0}
.legal-prose p{color:var(--ink-2);line-height:1.72;margin-bottom:1rem;font-size:.96rem}
.legal-prose ul{margin:0 0 1.1rem 1.2rem}
.legal-prose li{color:var(--ink-2);line-height:1.7;margin-bottom:.45rem;font-size:.96rem;list-style:disc}
.legal-prose a{color:var(--red-text);text-decoration:underline;text-underline-offset:2px}
.legal-prose a:hover{color:var(--red)}
.legal-prose strong{color:var(--ink);font-weight:600}
.legal-prose hr{border:0;border-top:1px solid var(--line);margin:2rem 0}

/* ---- Headline: one subtle line rise on load ---- */
.h-hero .ln{display:block}
.h-hero .ln > span{display:inline-block}
.js .h-hero .ln > span{opacity:0;transform:translateY(.38em);animation:lnrise .85s var(--ease) forwards}
.h-hero .ln:nth-child(1) > span{animation-delay:.05s}
.h-hero .ln:nth-child(2) > span{animation-delay:.15s}
.h-hero .ln:nth-child(3) > span{animation-delay:.25s}
@keyframes lnrise{to{opacity:1;transform:none}}
@media(prefers-reduced-motion:reduce){.h-hero .ln > span{opacity:1!important;transform:none!important;animation:none!important}}

/* ---- Responsive ---- */
@media(max-width:980px){
  .nav,.hdr-cta{display:none}
  #burger{display:flex}
  .hero-idx{display:none}
}
@media(max-width:640px){
  .svc{grid-template-columns:auto 1fr;gap:1rem}
  .svc .go{display:none}
  .frame-cap{flex-direction:column;align-items:flex-start;gap:.3rem}
}

@media(prefers-reduced-motion:reduce){
  *{scroll-behavior:auto!important}
  .reveal,.mw{opacity:1!important;transform:none!important;transition:none!important}
  .uline path{stroke-dashoffset:0!important;animation:none!important}
  .btn:hover,.plan:hover,.work:hover .shot img{transform:none}
}
