/* ═══════════════════════════════════════════════════════════
   TrueMake Designs — Vibrant Contemporary + Bento Grid
   Sora (display) + DM Sans (body)
   Near-white #fafafa + Deep violet #3d32c8 + Orange #f04e1b
   CSS prefix: tm-
   Nav: FLOATING PILL — centered glass pill above content
   Hero: BENTO GRID — asymmetric tiles forming hero
   ═══════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Sora:wght@300;400;500;600;700;800&family=DM+Sans:ital,wght@0,300;0,400;0,500;0,600;1,400&display=swap');

:root {
  --tm-white:   #fafafa;
  --tm-ink:     #111128;
  --tm-violet:  #3d32c8;
  --tm-violet2: #2e25a3;
  --tm-violet3: #5346e0;
  --tm-orange:  #f04e1b;
  --tm-orange2: #d43d10;
  --tm-soft:    #f0eeff;
  --tm-soft2:   #e4e0fe;
  --tm-muted:   #6c6b8a;
  --tm-muted2:  #9897b2;
  --tm-border:  #e6e4f4;
  --tm-border2: #d4d0f0;
  --tm-sh-sm:   0 2px 12px rgba(61,50,200,.07);
  --tm-sh-md:   0 6px 28px rgba(61,50,200,.10);
  --tm-sh-lg:   0 16px 60px rgba(61,50,200,.13);
  --tm-sh-xl:   0 28px 90px rgba(61,50,200,.18);

  --ff-head: 'Sora', system-ui, sans-serif;
  --ff-body: 'DM Sans', system-ui, sans-serif;
  --ease:    cubic-bezier(0.25, 1, 0.5, 1);
  --r:       8px;
  --r-lg:    16px;
  --r-xl:    24px;
  --r-2xl:   36px;
  --r-pill:  100px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth}
body{font-family:var(--ff-body);background:var(--tm-white);color:var(--tm-ink);line-height:1.68;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}
ul,ol{list-style:none}
input,textarea,select{font-family:inherit;font-size:inherit}
p{margin-bottom:1rem}
p:last-child{margin-bottom:0}
h1,h2,h3,h4{font-family:var(--ff-head);line-height:1;font-weight:700}

/* ── Labels ── */
.tm-eyebrow{font-family:var(--ff-body);font-size:.58rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--tm-muted);display:block}
.tm-eyebrow--violet{color:var(--tm-violet)}
.tm-eyebrow--orange{color:var(--tm-orange)}

/* ── Buttons ── */
.tm-btn-violet{display:inline-flex;align-items:center;gap:.45rem;background:var(--tm-violet);color:#fff;font-family:var(--ff-head);font-size:.82rem;font-weight:700;padding:.82rem 2rem;border-radius:var(--r-pill);border:none;transition:all .2s;white-space:nowrap;cursor:pointer}
.tm-btn-violet:hover{background:var(--tm-violet2);box-shadow:0 8px 28px rgba(61,50,200,.25);transform:translateY(-2px)}
.tm-btn-orange{display:inline-flex;align-items:center;gap:.45rem;background:var(--tm-orange);color:#fff;font-family:var(--ff-head);font-size:.82rem;font-weight:700;padding:.82rem 2rem;border-radius:var(--r-pill);border:none;transition:all .2s;white-space:nowrap;cursor:pointer}
.tm-btn-orange:hover{background:var(--tm-orange2);box-shadow:0 8px 28px rgba(240,78,27,.25);transform:translateY(-2px)}
.tm-btn-outline{display:inline-flex;align-items:center;gap:.45rem;background:transparent;color:var(--tm-violet);font-family:var(--ff-head);font-size:.82rem;font-weight:700;padding:.8rem 2rem;border-radius:var(--r-pill);border:1.5px solid var(--tm-violet);transition:all .2s;white-space:nowrap;cursor:pointer}
.tm-btn-outline:hover{background:var(--tm-soft);border-color:var(--tm-violet2)}
.tm-btn-outline--white{color:#fff;border-color:rgba(255,255,255,.35)}
.tm-btn-outline--white:hover{background:rgba(255,255,255,.1);border-color:#fff}
.tm-arr{display:inline-flex;align-items:center;gap:.3rem;font-family:var(--ff-head);font-size:.78rem;font-weight:700;color:var(--tm-violet);transition:gap .2s}
.tm-arr:hover{gap:.55rem}
.tm-arr--orange{color:var(--tm-orange)}

/* ═══════════════════════════════════════════════════════════
   FLOATING PILL NAV — unique in series
   Centered glass pill floating 20px from top
   ═══════════════════════════════════════════════════════════ */
.tm-pill-wrap{position:fixed;top:18px;left:50%;transform:translateX(-50%);z-index:100;display:flex;justify-content:center}
.tm-pill{display:flex;align-items:center;gap:0;background:rgba(250,250,250,.85);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--tm-border2);border-radius:var(--r-pill);padding:.42rem .6rem;box-shadow:var(--tm-sh-md);transition:box-shadow .2s,background .2s}
.tm-pill.tm-pill-solid{background:rgba(250,250,250,.97);box-shadow:var(--tm-sh-lg)}
.tm-pill-logo{font-family:var(--ff-head);font-size:.88rem;font-weight:800;color:var(--tm-violet);padding:.35rem .9rem .35rem .6rem;border-right:1px solid var(--tm-border);margin-right:.5rem;white-space:nowrap;letter-spacing:-.02em}
.tm-pill-logo em{color:var(--tm-orange);font-style:normal}
.tm-pill-link{font-family:var(--ff-body);font-size:.76rem;font-weight:500;color:var(--tm-muted);padding:.38rem .72rem;border-radius:var(--r-pill);transition:color .15s,background .15s;white-space:nowrap}
.tm-pill-link:hover{color:var(--tm-ink);background:var(--tm-soft)}
.tm-pill-link.tm-nav-on{color:var(--tm-violet)}
.tm-pill-cta{font-family:var(--ff-head);font-size:.76rem;font-weight:700;background:var(--tm-violet);color:#fff;padding:.38rem 1.1rem;border-radius:var(--r-pill);border:none;cursor:pointer;transition:background .2s;white-space:nowrap;margin-left:.5rem}
.tm-pill-cta:hover{background:var(--tm-violet2)}

/* Dropdown in pill */
.tm-pill-drop-wrap{position:relative}
.tm-pill-drop-btn{font-family:var(--ff-body);font-size:.76rem;font-weight:500;color:var(--tm-muted);padding:.38rem .72rem;border-radius:var(--r-pill);transition:color .15s,background .15s;white-space:nowrap;cursor:pointer;display:flex;align-items:center;gap:.2rem;background:none;border:none}
.tm-pill-drop-btn:hover{color:var(--tm-ink);background:var(--tm-soft)}
.tm-pill-drop{position:absolute;top:calc(100%+8px);left:50%;transform:translateX(-50%);background:#fff;border:1px solid var(--tm-border2);border-radius:var(--r-xl);box-shadow:var(--tm-sh-xl);opacity:0;pointer-events:none;transition:opacity .18s,transform .18s;transform:translateX(-50%) translateY(6px);min-width:240px;padding:.6rem}
.tm-pill-drop-wrap:hover .tm-pill-drop,.tm-pill-drop-wrap:focus-within .tm-pill-drop{opacity:1;pointer-events:auto;transform:translateX(-50%) translateY(0)}
.tm-pill-drop-link{display:block;font-size:.78rem;color:var(--tm-ink);padding:.55rem .9rem;border-radius:var(--r);transition:background .12s;font-weight:500}
.tm-pill-drop-link:hover{background:var(--tm-soft);color:var(--tm-violet)}

/* Mobile nav burger */
.tm-mob-toggle{display:none;position:fixed;top:16px;right:1.2rem;z-index:101;width:42px;height:42px;background:var(--tm-violet);border-radius:50%;align-items:center;justify-content:center;flex-direction:column;gap:5px;border:none;cursor:pointer}
.tm-mob-toggle span{width:18px;height:1.5px;background:#fff;border-radius:2px;transition:transform .25s,opacity .25s}
.tm-mob-toggle.tm-burg-on span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.tm-mob-toggle.tm-burg-on span:nth-child(2){opacity:0}
.tm-mob-toggle.tm-burg-on span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
.tm-mob-nav{position:fixed;inset:0;z-index:99;background:var(--tm-white);padding:5rem 2rem 2rem;display:flex;flex-direction:column;gap:.4rem;opacity:0;pointer-events:none;transition:opacity .25s}
.tm-mob-nav.tm-mob-on{opacity:1;pointer-events:auto}
.tm-mob-lnk{font-family:var(--ff-head);font-size:1.6rem;font-weight:700;color:var(--tm-ink);padding:.2rem 0;border-bottom:1px solid var(--tm-border);transition:color .15s}
.tm-mob-lnk:hover{color:var(--tm-violet)}

/* ═══════════════════════════════════════════════════════════
   HERO — BENTO GRID
   Asymmetric grid of tiles forming the hero
   ═══════════════════════════════════════════════════════════ */
.tm-hero-shell{padding:6.5rem 1.5rem 3rem;background:var(--tm-white)}
.tm-bento-outer{max-width:1400px;margin:0 auto}
.tm-bento-grid{display:grid;grid-template-columns:repeat(12,1fr);grid-template-rows:auto;gap:1rem}

/* Tile styles */
.tm-tile{border-radius:var(--r-2xl);overflow:hidden;position:relative}
/* Tile A — big headline tile */
.tm-tile-a{grid-column:1/8;grid-row:1/3;background:var(--tm-soft);padding:3.5rem 3rem;display:flex;flex-direction:column;justify-content:space-between;min-height:320px}
.tm-tile-a-tag{font-size:.58rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--tm-violet);background:var(--tm-soft2);display:inline-flex;align-items:center;gap:.4rem;padding:.28rem .75rem;border-radius:var(--r-pill);margin-bottom:1.2rem;width:fit-content}
.tm-tile-a-h1{font-size:clamp(2.8rem,5.5vw,6rem);color:var(--tm-ink);line-height:.9;letter-spacing:-.03em;margin-bottom:1.2rem}
.tm-tile-a-h1 span{color:var(--tm-violet)}
.tm-tile-a-sub{font-size:.92rem;color:var(--tm-muted);max-width:42ch;line-height:1.82;margin-bottom:2rem}
.tm-tile-a-btns{display:flex;gap:.75rem;flex-wrap:wrap}
/* Tile B — image tile */
.tm-tile-b{grid-column:8/13;grid-row:1/3;background:var(--tm-violet);overflow:hidden;position:relative;min-height:320px}
.tm-tile-b-img{width:100%;height:100%;object-fit:cover;opacity:.85;mix-blend-mode:multiply}
.tm-tile-b-badge{position:absolute;bottom:1.5rem;left:1.5rem;background:#fff;border-radius:var(--r-xl);padding:.7rem 1.1rem}
.tm-tile-b-badge-n{font-family:var(--ff-head);font-size:2rem;font-weight:800;color:var(--tm-violet);line-height:1}
.tm-tile-b-badge-l{font-size:.52rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--tm-muted);margin-top:.08rem}
/* Tile C — stat tile */
.tm-tile-c{background:var(--tm-orange);padding:1.8rem 2rem;display:flex;flex-direction:column;justify-content:space-between;grid-column:1/5;grid-row:3}
.tm-tile-c-n{font-family:var(--ff-head);font-size:3.5rem;font-weight:800;color:#fff;line-height:1}
.tm-tile-c-l{font-size:.62rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.6);margin-top:.15rem}
/* Tile D — service chip tile */
.tm-tile-d{background:var(--tm-ink);padding:1.8rem 2rem;grid-column:5/9;grid-row:3;display:flex;flex-direction:column;gap:.55rem;justify-content:center}
.tm-tile-d-label{font-size:.6rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.25);margin-bottom:.2rem}
.tm-tile-d-chip{display:inline-flex;align-items:center;gap:.4rem;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);border-radius:var(--r-pill);padding:.28rem .75rem;font-size:.72rem;font-weight:600;color:rgba(255,255,255,.7);width:fit-content;transition:all .2s}
.tm-tile-d-chip:hover{background:rgba(61,50,200,.4);border-color:var(--tm-violet3);color:#fff}
/* Tile E — CTA tile */
.tm-tile-e{background:var(--tm-violet3);padding:1.8rem 2rem;grid-column:9/13;grid-row:3;display:flex;flex-direction:column;justify-content:center;gap:.6rem}
.tm-tile-e-h{font-family:var(--ff-head);font-size:1.1rem;font-weight:700;color:#fff;margin-bottom:.1rem}
.tm-tile-e-p{font-size:.74rem;color:rgba(255,255,255,.55);line-height:1.6}

/* ═══════════════════════════════════════════════════════════
   TICKER STRIP
   ═══════════════════════════════════════════════════════════ */
.tm-ticker-shell{background:var(--tm-violet);overflow:hidden;white-space:nowrap;padding:.7rem 0;margin-top:3rem}
.tm-ticker-track{display:inline-flex;animation:tm-scroll 32s linear infinite}
@keyframes tm-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.tm-ticker-item{font-family:var(--ff-head);font-size:.82rem;font-weight:600;color:rgba(255,255,255,.28);padding:0 2.5rem;display:inline-flex;align-items:center;gap:2.5rem}
.tm-ticker-hi{color:var(--tm-orange);font-size:.58rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase}

/* ═══════════════════════════════════════════════════════════
   SERVICES — HORIZONTAL CARD ROW
   ═══════════════════════════════════════════════════════════ */
.tm-svc-shell{padding:8rem 1.5rem;background:var(--tm-white)}
.tm-svc-outer{max-width:1400px;margin:0 auto}
.tm-svc-hdr{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:3.5rem;flex-wrap:wrap;gap:2rem}
.tm-svc-h2{font-size:clamp(2.5rem,5vw,5.5rem);color:var(--tm-ink);letter-spacing:-.025em}
.tm-svc-h2 span{color:var(--tm-violet)}
.tm-svc-row{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem}
.tm-svc-card{background:#fff;border:1.5px solid var(--tm-border);border-radius:var(--r-xl);padding:1.8rem;cursor:pointer;text-decoration:none;display:flex;flex-direction:column;transition:all .22s;position:relative;overflow:hidden}
.tm-svc-card::before{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--tm-violet);transform:scaleX(0);transform-origin:left;transition:transform .25s}
.tm-svc-card:hover{border-color:var(--tm-violet);transform:translateY(-4px);box-shadow:var(--tm-sh-md)}
.tm-svc-card:hover::before{transform:scaleX(1)}
.tm-svc-ico{width:44px;height:44px;background:var(--tm-soft);border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;font-size:1.15rem;margin-bottom:1.2rem;flex-shrink:0;color:var(--tm-violet)}
.tm-svc-num{font-family:var(--ff-head);font-size:.62rem;font-weight:700;color:var(--tm-soft2);margin-bottom:.4rem;letter-spacing:.1em}
.tm-svc-name{font-family:var(--ff-head);font-size:1.05rem;font-weight:700;color:var(--tm-ink);margin-bottom:.4rem;line-height:1.2;letter-spacing:-.01em}
.tm-svc-brief{font-size:.74rem;color:var(--tm-muted);line-height:1.6;flex:1;margin-bottom:1rem}
.tm-svc-price{font-family:var(--ff-head);font-size:1.2rem;font-weight:700;color:var(--tm-violet)}
.tm-svc-arrow{font-size:.7rem;color:var(--tm-muted);transition:color .2s,transform .2s}
.tm-svc-card:hover .tm-svc-arrow{color:var(--tm-violet);transform:translateX(4px)}

/* ═══════════════════════════════════════════════════════════
   WORK — MASONRY IRREGULAR GRID
   ═══════════════════════════════════════════════════════════ */
.tm-work-shell{padding:8rem 1.5rem;background:var(--tm-soft)}
.tm-work-outer{max-width:1400px;margin:0 auto}
.tm-work-hdr{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:3.5rem;flex-wrap:wrap;gap:2rem}
.tm-work-h2{font-size:clamp(2.5rem,5vw,5.5rem);color:var(--tm-ink);letter-spacing:-.025em}
.tm-work-grid{display:grid;grid-template-columns:repeat(12,1fr);grid-template-rows:auto;gap:1rem}
.tm-work-item{border-radius:var(--r-2xl);overflow:hidden;background:#fff;position:relative;cursor:pointer;display:block}
.tm-work-item:nth-child(1){grid-column:1/8;grid-row:1}
.tm-work-item:nth-child(2){grid-column:8/13;grid-row:1}
.tm-work-item:nth-child(3){grid-column:1/5;grid-row:2}
.tm-work-img{aspect-ratio:16/10;overflow:hidden;background:var(--tm-soft2)}
.tm-work-item:nth-child(2) .tm-work-img{aspect-ratio:4/5}
.tm-work-item:nth-child(3) .tm-work-img{aspect-ratio:1}
.tm-work-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s var(--ease)}
.tm-work-item:hover .tm-work-img img{transform:scale(1.04)}
.tm-work-meta{padding:1.5rem}
.tm-work-sector{font-size:.56rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--tm-orange);display:block;margin-bottom:.2rem}
.tm-work-client{font-family:var(--ff-head);font-size:1.15rem;font-weight:700;color:var(--tm-ink);letter-spacing:-.01em;margin-bottom:.2rem}
.tm-work-svc{font-size:.7rem;color:var(--tm-muted)}
.tm-work-result{display:flex;align-items:baseline;gap:.4rem;margin-top:.8rem;padding-top:.8rem;border-top:1px solid var(--tm-border)}
.tm-work-result-n{font-family:var(--ff-head);font-size:1.8rem;font-weight:700;color:var(--tm-violet)}
.tm-work-result-l{font-size:.62rem;color:var(--tm-muted);max-width:14ch;line-height:1.4}
/* Add right sidebar card for case 2 on row 2 */
.tm-work-story-card{grid-column:5/13;grid-row:2;background:var(--tm-violet);border-radius:var(--r-2xl);padding:3rem;display:flex;flex-direction:column;justify-content:space-between}
.tm-work-story-q{font-family:var(--ff-head);font-size:1.2rem;font-weight:400;color:#fff;font-style:italic;line-height:1.5;margin-bottom:1.5rem;max-width:46ch}
.tm-work-story-author{font-family:var(--ff-body);font-size:.78rem;font-weight:600;color:rgba(255,255,255,.5)}
.tm-work-story-role{font-size:.64rem;color:rgba(255,255,255,.3)}

/* ═══════════════════════════════════════════════════════════
   PROCESS — TAB STEPS (unique in series)
   ═══════════════════════════════════════════════════════════ */
.tm-proc-shell{padding:8rem 1.5rem;background:var(--tm-white);border-top:1px solid var(--tm-border)}
.tm-proc-outer{max-width:1400px;margin:0 auto}
.tm-proc-hdr{text-align:center;margin-bottom:3.5rem}
.tm-proc-h2{font-size:clamp(2.5rem,5vw,5.5rem);color:var(--tm-ink);letter-spacing:-.025em;margin-bottom:.5rem}
.tm-proc-sub{font-size:.9rem;color:var(--tm-muted);max-width:48ch;margin:0 auto;line-height:1.82}
.tm-proc-tabs{display:flex;gap:.5rem;justify-content:center;margin-bottom:3rem;flex-wrap:wrap}
.tm-proc-tab{font-family:var(--ff-head);font-size:.78rem;font-weight:600;padding:.55rem 1.3rem;border-radius:var(--r-pill);border:1.5px solid var(--tm-border);color:var(--tm-muted);cursor:pointer;transition:all .2s;background:none}
.tm-proc-tab:hover{border-color:var(--tm-violet3);color:var(--tm-violet)}
.tm-proc-tab.tm-tab-on{background:var(--tm-violet);border-color:var(--tm-violet);color:#fff}
.tm-proc-panels{}
.tm-proc-panel{display:none;animation:tm-fade .3s ease}
.tm-proc-panel.tm-panel-on{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
@keyframes tm-fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.tm-panel-n{font-family:var(--ff-head);font-size:8rem;font-weight:800;color:var(--tm-soft2);line-height:1;margin-bottom:-.5rem}
.tm-panel-title{font-size:2.5rem;font-weight:700;color:var(--tm-ink);margin-bottom:.5rem;letter-spacing:-.02em}
.tm-panel-time{font-size:.6rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--tm-orange);margin-bottom:.8rem}
.tm-panel-body{font-size:.9rem;color:var(--tm-muted);line-height:1.88;max-width:50ch}
.tm-panel-img{border-radius:var(--r-2xl);overflow:hidden;background:var(--tm-soft);aspect-ratio:4/3}
.tm-panel-img img{width:100%;height:100%;object-fit:cover}

/* ═══════════════════════════════════════════════════════════
   TESTIMONIALS — HORIZONTAL CARDS
   ═══════════════════════════════════════════════════════════ */
.tm-tmon-shell{padding:8rem 1.5rem;background:var(--tm-ink)}
.tm-tmon-outer{max-width:1400px;margin:0 auto}
.tm-tmon-hdr{margin-bottom:3.5rem;display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:2rem}
.tm-tmon-h2{font-size:clamp(2.5rem,5vw,5.5rem);color:#fff;letter-spacing:-.025em}
.tm-tmon-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.tm-tmon-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);border-radius:var(--r-xl);padding:1.8rem;transition:background .2s}
.tm-tmon-card:hover{background:rgba(255,255,255,.07)}
.tm-tmon-card:first-child{background:var(--tm-violet);border-color:var(--tm-violet3)}
.tm-tmon-q{font-family:var(--ff-head);font-size:.95rem;font-weight:400;color:rgba(255,255,255,.75);font-style:italic;line-height:1.65;margin-bottom:1.5rem}
.tm-tmon-q::before{content:'\201C';color:var(--tm-orange);font-size:1.2em;line-height:0;vertical-align:-.2em;margin-right:.06em}
.tm-tmon-card:first-child .tm-tmon-q{color:#fff}
.tm-tmon-attr{display:flex;align-items:center;gap:.7rem}
.tm-tmon-av{width:40px;height:40px;border-radius:50%;overflow:hidden;background:rgba(255,255,255,.1);flex-shrink:0}
.tm-tmon-av img{width:100%;height:100%;object-fit:cover}
.tm-tmon-name{font-family:var(--ff-head);font-size:.82rem;font-weight:600;color:#fff}
.tm-tmon-role{font-size:.62rem;color:rgba(255,255,255,.3)}

/* ═══════════════════════════════════════════════════════════
   PRICING — HYBRID TABLE
   ═══════════════════════════════════════════════════════════ */
.tm-price-shell{padding:8rem 1.5rem;background:var(--tm-white);border-top:1px solid var(--tm-border)}
.tm-price-outer{max-width:1400px;margin:0 auto}
.tm-price-hdr{text-align:center;margin-bottom:3.5rem}
.tm-price-h2{font-size:clamp(2.5rem,5vw,5.5rem);color:var(--tm-ink);letter-spacing:-.025em;margin-bottom:.5rem}
.tm-price-sub{font-size:.9rem;color:var(--tm-muted);max-width:50ch;margin:0 auto;line-height:1.82}
.tm-tier-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:3rem}
.tm-tier-card{background:#fff;border:1.5px solid var(--tm-border);border-radius:var(--r-xl);padding:2rem;transition:border-color .2s;position:relative}
.tm-tier-card--pop{border-color:var(--tm-violet);background:var(--tm-soft)}
.tm-tier-pop-tag{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--tm-violet);color:#fff;font-family:var(--ff-head);font-size:.56rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;padding:.22rem .75rem;border-radius:var(--r-pill)}
.tm-tier-name{font-family:var(--ff-head);font-size:1rem;font-weight:700;color:var(--tm-ink);margin-bottom:.15rem;letter-spacing:-.01em}
.tm-tier-ideal{font-size:.66rem;color:var(--tm-muted);margin-bottom:1.2rem;line-height:1.5}
.tm-tier-price{font-family:var(--ff-head);font-size:2.5rem;font-weight:800;color:var(--tm-ink);line-height:1;margin-bottom:.1rem;letter-spacing:-.02em}
.tm-tier-card--pop .tm-tier-price{color:var(--tm-violet)}
.tm-tier-scope{font-size:.58rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--tm-muted);margin-bottom:1.2rem}
.tm-tier-list{display:flex;flex-direction:column;gap:.28rem;margin-bottom:1.5rem}
.tm-tier-li{display:flex;gap:.4rem;font-size:.72rem;color:var(--tm-muted);line-height:1.5;align-items:flex-start}
.tm-tier-chk{color:var(--tm-violet);flex-shrink:0;font-size:.72rem;margin-top:.05rem}
.tm-tier-btn{display:block;text-align:center;font-family:var(--ff-head);font-size:.8rem;font-weight:700;padding:.75rem;border-radius:var(--r-pill);border:none;cursor:pointer;transition:all .2s;text-decoration:none}
.tm-tier-btn--violet{background:var(--tm-violet);color:#fff}
.tm-tier-btn--violet:hover{background:var(--tm-violet2)}
.tm-tier-btn--outline{background:transparent;color:var(--tm-violet);border:1.5px solid var(--tm-violet)}
.tm-tier-btn--outline:hover{background:var(--tm-soft)}
/* Modules section */
.tm-mod-band{background:var(--tm-soft);border-radius:var(--r-2xl);padding:2rem;margin-bottom:1.5rem}
.tm-mod-h{font-family:var(--ff-head);font-size:1rem;font-weight:700;color:var(--tm-ink);margin-bottom:.75rem}
.tm-mod-row{display:grid;grid-template-columns:repeat(4,1fr);gap:.85rem}
.tm-mod-item{background:#fff;border:1px solid var(--tm-border);border-radius:var(--r-lg);padding:1rem 1.2rem}
.tm-mod-name{font-size:.8rem;font-weight:600;color:var(--tm-ink);margin-bottom:.15rem}
.tm-mod-price{font-family:var(--ff-head);font-size:1.1rem;font-weight:700;color:var(--tm-orange)}

/* ═══════════════════════════════════════════════════════════
   TEAM
   ═══════════════════════════════════════════════════════════ */
.tm-team-shell{padding:8rem 1.5rem;background:var(--tm-soft);border-top:1px solid var(--tm-border)}
.tm-team-outer{max-width:1400px;margin:0 auto}
.tm-team-h2{font-size:clamp(2.5rem,5vw,5.5rem);color:var(--tm-ink);letter-spacing:-.025em;margin-bottom:3.5rem}
.tm-team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.tm-team-card{background:#fff;border:1.5px solid var(--tm-border);border-radius:var(--r-2xl);overflow:hidden;transition:border-color .25s,box-shadow .25s}
.tm-team-card:hover{border-color:var(--tm-violet);box-shadow:var(--tm-sh-md)}
.tm-team-photo{aspect-ratio:4/5;overflow:hidden;background:var(--tm-soft2)}
.tm-team-photo img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease);filter:saturate(.85)}
.tm-team-card:hover .tm-team-photo img{transform:scale(1.04);filter:saturate(1)}
.tm-team-body{padding:1.5rem}
.tm-team-role{font-size:.56rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--tm-orange);margin-bottom:.2rem}
.tm-team-name{font-family:var(--ff-head);font-size:1.05rem;font-weight:700;color:var(--tm-ink);margin-bottom:.35rem;letter-spacing:-.01em}
.tm-team-bio{font-size:.74rem;color:var(--tm-muted);line-height:1.7}

/* ═══════════════════════════════════════════════════════════
   FAQ — ACCORDION
   ═══════════════════════════════════════════════════════════ */
.tm-faq-shell{padding:8rem 1.5rem;background:var(--tm-white);border-top:1px solid var(--tm-border)}
.tm-faq-outer{max-width:1400px;margin:0 auto;display:grid;grid-template-columns:1fr 1.6fr;gap:8rem;align-items:start}
.tm-faq-lhs{}
.tm-faq-h2{font-size:clamp(2.5rem,5vw,5.5rem);color:var(--tm-ink);letter-spacing:-.025em;margin-bottom:.8rem}
.tm-faq-sub{font-size:.9rem;color:var(--tm-muted);max-width:28ch;line-height:1.82;margin-bottom:2rem}
.tm-faq-items{}
.tm-faq-entry{border-top:1.5px solid var(--tm-border)}
.tm-faq-entry:last-child{border-bottom:1.5px solid var(--tm-border)}
.tm-faq-toggle{width:100%;display:flex;justify-content:space-between;align-items:center;gap:2rem;padding:1.1rem 0;background:none;border:none;cursor:pointer;text-align:left}
.tm-faq-toggle:hover .tm-faq-q{color:var(--tm-violet)}
.tm-faq-q{font-family:var(--ff-head);font-size:.9rem;font-weight:700;color:var(--tm-ink);transition:color .15s;line-height:1.3}
.tm-faq-icon{width:28px;height:28px;border-radius:50%;border:1.5px solid var(--tm-border2);display:flex;align-items:center;justify-content:center;color:var(--tm-muted);flex-shrink:0;transition:all .2s;font-size:.75rem}
.tm-faq-entry.tm-faq-open .tm-faq-icon{background:var(--tm-violet);border-color:var(--tm-violet);color:#fff;transform:rotate(45deg)}
.tm-faq-ans{max-height:0;overflow:hidden;transition:max-height .38s ease}
.tm-faq-ans-in{padding:0 0 1.1rem;font-size:.82rem;color:var(--tm-muted);line-height:1.88}
.tm-faq-entry.tm-faq-open .tm-faq-ans{max-height:260px}

/* ═══════════════════════════════════════════════════════════
   CTA — SPLIT 50/50
   ═══════════════════════════════════════════════════════════ */
.tm-cta-shell{display:grid;grid-template-columns:1fr 1fr;min-height:480px}
.tm-cta-lhs{background:var(--tm-violet);padding:6rem clamp(2rem,4vw,5rem);display:flex;flex-direction:column;justify-content:center}
.tm-cta-rhs{background:var(--tm-ink);overflow:hidden;position:relative}
.tm-cta-rhs img{width:100%;height:100%;object-fit:cover;opacity:.6;display:block}
.tm-cta-h2{font-size:clamp(2.5rem,5vw,5.5rem);color:#fff;letter-spacing:-.025em;margin-bottom:.8rem;line-height:.95}
.tm-cta-h2 em{font-style:italic;font-weight:300;color:rgba(255,255,255,.45)}
.tm-cta-sub{font-size:.9rem;color:rgba(255,255,255,.5);max-width:38ch;line-height:1.82;margin-bottom:2.5rem}
.tm-cta-btns{display:flex;gap:.75rem;flex-wrap:wrap}

/* ═══════════════════════════════════════════════════════════
   INNER PAGE MASTHEAD
   ═══════════════════════════════════════════════════════════ */
.tm-mast-shell{background:var(--tm-soft);padding:6rem 1.5rem 4rem;border-bottom:1px solid var(--tm-border)}
.tm-mast-outer{max-width:1400px;margin:0 auto}
.tm-mast-h1{font-size:clamp(2.8rem,7vw,8rem);color:var(--tm-ink);letter-spacing:-.03em;margin-bottom:.6rem;line-height:.9}
.tm-mast-h1 span{color:var(--tm-violet)}
.tm-mast-sub{font-size:.92rem;color:var(--tm-muted);max-width:52ch;line-height:1.82}
.tm-mast-btns{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:2rem}

/* ═══════════════════════════════════════════════════════════
   SERVICE PAGES
   ═══════════════════════════════════════════════════════════ */
.tm-svc-body-shell{padding:5rem 1.5rem;background:var(--tm-white)}
.tm-svc-body-cols{max-width:1400px;margin:0 auto;display:grid;grid-template-columns:1.8fr 1fr;gap:6rem;align-items:start}
.tm-svc-copy p{font-size:.9rem;color:var(--tm-muted);line-height:1.94;margin-bottom:1.1rem}
.tm-svc-copy h3{font-family:var(--ff-head);font-size:1.15rem;font-weight:700;color:var(--tm-ink);margin:2.5rem 0 .5rem;letter-spacing:-.01em}
.tm-result-card{border-left:3px solid var(--tm-orange);padding:.8rem 1.2rem;background:rgba(240,78,27,.04);border-radius:0 var(--r) var(--r) 0;margin-bottom:.75rem}
.tm-result-card p{font-size:.8rem;color:var(--tm-ink);margin:0;line-height:1.65}
.tm-svc-faq-item{padding:1rem 0;border-bottom:1px solid var(--tm-border)}
.tm-svc-faq-q{font-family:var(--ff-head);font-size:.88rem;font-weight:700;color:var(--tm-ink);margin-bottom:.3rem;letter-spacing:-.01em}
.tm-svc-faq-a{font-size:.8rem;color:var(--tm-muted);line-height:1.78}
.tm-svc-side-img{border-radius:var(--r-xl);overflow:hidden;background:var(--tm-soft);margin-bottom:1.2rem}
.tm-svc-side-img img{width:100%;height:260px;object-fit:cover}
.tm-svc-incl-box{background:var(--tm-soft);border:1px solid var(--tm-border);border-top:3px solid var(--tm-violet);border-radius:var(--r-xl);padding:1.8rem;margin-bottom:1.2rem}
.tm-svc-incl-h{font-family:var(--ff-head);font-size:.9rem;font-weight:700;color:var(--tm-ink);margin-bottom:.9rem;letter-spacing:-.01em}
.tm-svc-incl-row{display:flex;gap:.5rem;font-size:.76rem;color:var(--tm-muted);padding:.28rem 0;border-bottom:1px solid rgba(61,50,200,.05)}
.tm-svc-incl-chk{color:var(--tm-violet);flex-shrink:0;font-weight:700}
.tm-svc-buy-box{background:var(--tm-violet);border-radius:var(--r-xl);padding:2rem}
.tm-svc-buy-label{font-size:.56rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.35);margin-bottom:.15rem}
.tm-svc-buy-price{font-family:var(--ff-head);font-size:3.5rem;font-weight:800;color:#fff;line-height:1;margin-bottom:.1rem;letter-spacing:-.02em}
.tm-svc-buy-scope{font-size:.58rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.35);margin-bottom:1.2rem}

/* ═══════════════════════════════════════════════════════════
   BUILDER
   ═══════════════════════════════════════════════════════════ */
.tm-build-shell{min-height:100vh;padding:6rem 1.5rem 5rem;background:var(--tm-soft)}
.tm-build-outer{max-width:1320px;margin:0 auto}
.tm-build-h{font-size:clamp(2.5rem,7vw,8rem);color:var(--tm-ink);letter-spacing:-.03em;margin-bottom:.3rem}
.tm-build-cols{display:grid;grid-template-columns:1.6fr 1fr;gap:4rem;margin-top:3rem}
.tm-build-step{margin-bottom:2.2rem}
.tm-build-step-h{font-family:var(--ff-head);font-size:.92rem;font-weight:700;color:var(--tm-ink);margin-bottom:.9rem;display:flex;align-items:center;gap:.6rem;letter-spacing:-.01em}
.tm-step-num{width:24px;height:24px;background:var(--tm-violet);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.58rem;font-weight:800;color:#fff;flex-shrink:0}
/* Tier picks */
.tm-tier-picks{display:flex;flex-direction:column;gap:.45rem}
.tm-tier-pick{background:#fff;border:1.5px solid var(--tm-border);border-radius:var(--r-lg);padding:1rem 1.3rem;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:2rem;transition:all .2s;user-select:none}
.tm-tier-pick:hover{border-color:var(--tm-border2)}
.tm-tier-pick.tm-pick-sel{border-color:var(--tm-violet);background:#fff}
.tm-pick-lhs{display:flex;align-items:center;gap:.7rem}
.tm-pick-radio{width:16px;height:16px;border:1.5px solid var(--tm-border2);border-radius:50%;flex-shrink:0;transition:all .2s;display:flex;align-items:center;justify-content:center;background:#fff}
.tm-tier-pick.tm-pick-sel .tm-pick-radio{border-color:var(--tm-violet);background:var(--tm-violet)}
.tm-tier-pick.tm-pick-sel .tm-pick-radio::after{content:'';width:5px;height:5px;background:#fff;border-radius:50%}
.tm-pick-name{font-family:var(--ff-head);font-size:.88rem;font-weight:700;color:var(--tm-ink);letter-spacing:-.01em}
.tm-pick-scope{font-size:.62rem;color:var(--tm-muted)}
.tm-pick-price{font-family:var(--ff-head);font-size:1.05rem;font-weight:700;color:var(--tm-muted);white-space:nowrap;transition:color .2s}
.tm-tier-pick.tm-pick-sel .tm-pick-price{color:var(--tm-violet)}
/* Module checkboxes */
.tm-mod-picks{display:flex;flex-direction:column;gap:.4rem}
.tm-mod-pick{background:#fff;border:1.5px solid var(--tm-border);border-radius:var(--r);padding:.7rem 1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:1rem;transition:all .2s;user-select:none}
.tm-mod-pick:hover{border-color:var(--tm-border2)}
.tm-mod-pick.tm-mod-sel{border-color:var(--tm-orange);background:rgba(240,78,27,.03)}
.tm-mod-pick-lhs{display:flex;align-items:center;gap:.6rem}
.tm-mod-chk{width:15px;height:15px;border:1.5px solid var(--tm-border2);border-radius:3px;flex-shrink:0;transition:all .2s;display:flex;align-items:center;justify-content:center;background:#fff}
.tm-mod-pick.tm-mod-sel .tm-mod-chk{background:var(--tm-orange);border-color:var(--tm-orange)}
.tm-mod-pick.tm-mod-sel .tm-mod-chk::after{content:'✓';font-size:.44rem;color:#fff;font-weight:900}
.tm-mod-pick-name{font-size:.82rem;font-weight:600;color:var(--tm-ink)}
.tm-mod-pick-price{font-family:var(--ff-head);font-size:.9rem;font-weight:700;color:var(--tm-muted);white-space:nowrap}
/* Hours */
.tm-hrs-block{background:#fff;border:1.5px solid var(--tm-border);border-radius:var(--r-lg);padding:1.3rem}
.tm-hrs-h{font-family:var(--ff-head);font-size:.88rem;font-weight:700;color:var(--tm-ink);margin-bottom:.15rem;letter-spacing:-.01em}
.tm-hrs-note{font-size:.68rem;color:var(--tm-muted);margin-bottom:.8rem}
.tm-hrs-row{display:flex;align-items:center;gap:1.2rem}
.tm-hrs-count{font-family:var(--ff-head);font-size:2.2rem;font-weight:800;color:var(--tm-ink);min-width:2.5ch;text-align:center}
.tm-hrs-slider{-webkit-appearance:none;appearance:none;flex:1;height:4px;background:var(--tm-soft2);border-radius:4px;cursor:pointer;outline:none}
.tm-hrs-slider::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:var(--tm-violet);cursor:pointer;box-shadow:0 2px 8px rgba(61,50,200,.25)}
.tm-hrs-rate strong{font-family:var(--ff-head);font-size:.88rem;font-weight:700;color:var(--tm-ink);display:block}
.tm-hrs-rate span{font-size:.62rem;color:var(--tm-muted)}
/* Summary */
.tm-sum-panel{background:var(--tm-ink);border-radius:var(--r-2xl);padding:2rem;position:sticky;top:6.5rem}
.tm-sum-hd{font-size:.56rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.25);padding-bottom:.9rem;border-bottom:1px solid rgba(255,255,255,.06);margin-bottom:1rem}
.tm-sum-body{min-height:52px;margin-bottom:1rem}
.tm-sum-row{display:flex;justify-content:space-between;gap:1rem;font-size:.78rem;color:rgba(255,255,255,.4);padding:.3rem 0;border-bottom:1px solid rgba(255,255,255,.04)}
.tm-sum-row-name{flex:1}
.tm-sum-row-val{font-weight:700;color:#fff;white-space:nowrap;font-family:var(--ff-head);font-size:.88rem}
.tm-sum-empty{font-size:.75rem;color:rgba(255,255,255,.2);font-style:italic}
.tm-sum-total-row{display:flex;justify-content:space-between;align-items:baseline;border-top:1px solid rgba(255,255,255,.08);padding-top:1rem}
.tm-sum-total-lbl{font-size:.56rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.25)}
.tm-sum-total-n{font-family:var(--ff-head);font-size:3rem;font-weight:800;color:var(--tm-orange);letter-spacing:-.02em}
.tm-sum-submit{width:100%;background:var(--tm-orange);color:#fff;font-family:var(--ff-head);font-size:.88rem;font-weight:700;padding:.95rem;border-radius:var(--r-pill);border:none;cursor:pointer;transition:all .2s;margin-top:1.2rem}
.tm-sum-submit:hover{background:var(--tm-orange2);box-shadow:0 8px 24px rgba(240,78,27,.3)}
.tm-sum-submit:disabled{opacity:.18;pointer-events:none}

/* Checkout */
.tm-co-shell{min-height:100vh;padding:6rem 1.5rem 5rem;background:var(--tm-white)}
.tm-co-outer{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1.5fr 1fr;gap:5rem;align-items:start}
.tm-co-h{font-size:clamp(2.5rem,6vw,7rem);color:var(--tm-ink);letter-spacing:-.03em;margin-bottom:.3rem}
.tm-field{display:flex;flex-direction:column;gap:.22rem;margin-bottom:.85rem}
.tm-field-pair{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.tm-field-lbl{font-size:.58rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--tm-muted)}
.tm-inp,.tm-sel,.tm-txta{background:#fff;border:1.5px solid var(--tm-border2);border-radius:var(--r);padding:.78rem 1rem;color:var(--tm-ink);font-size:.88rem;outline:none;width:100%;transition:border-color .2s}
.tm-inp:focus,.tm-sel:focus,.tm-txta:focus{border-color:var(--tm-violet)}
.tm-inp::placeholder,.tm-txta::placeholder{color:var(--tm-muted2)}
.tm-tos-row{display:flex;gap:.7rem;align-items:flex-start;font-size:.78rem;color:var(--tm-muted);cursor:pointer;margin-bottom:1.5rem;line-height:1.6}
.tm-tos-row a{color:var(--tm-violet)}
.tm-tos-row input{accent-color:var(--tm-violet);flex-shrink:0;margin-top:2px}
.tm-pay-btn{width:100%;background:var(--tm-violet);color:#fff;font-family:var(--ff-head);font-size:.92rem;font-weight:700;padding:1rem 1.5rem;border-radius:var(--r-pill);border:none;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:space-between}
.tm-pay-btn:hover{background:var(--tm-violet2)}
.tm-order-box{background:var(--tm-ink);border-radius:var(--r-2xl);padding:2rem;position:sticky;top:6.5rem}
.tm-order-hd{font-size:.56rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.25);padding-bottom:.9rem;border-bottom:1px solid rgba(255,255,255,.06);margin-bottom:1rem}
.tm-order-line{display:flex;justify-content:space-between;gap:1rem;font-size:.78rem;color:rgba(255,255,255,.4);padding:.3rem 0}
.tm-order-val{color:#fff;font-weight:700;font-family:var(--ff-head)}
.tm-order-total{font-family:var(--ff-head);font-size:3rem;font-weight:800;color:var(--tm-orange);letter-spacing:-.02em}

/* Misc */
.tm-page-body{padding:5rem 1.5rem;background:var(--tm-white)}
.tm-contact-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1.4fr;gap:6rem;align-items:start}
.tm-det-item{display:flex;gap:.75rem;align-items:flex-start;margin-bottom:.9rem}
.tm-det-ico{width:32px;height:32px;background:var(--tm-soft);border-radius:var(--r);display:flex;align-items:center;justify-content:center;color:var(--tm-violet);flex-shrink:0;font-size:.9rem}
.tm-det-lbl{font-size:.56rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--tm-muted)}
.tm-det-val{font-size:.84rem;color:var(--tm-muted)}
.tm-form-box{background:#fff;border:1.5px solid var(--tm-border);border-top:3px solid var(--tm-orange);border-radius:var(--r-2xl);padding:2.5rem;box-shadow:var(--tm-sh-md)}
.tm-confirm-shell{min-height:100vh;display:flex;align-items:center;padding:5rem 2rem;background:var(--tm-soft)}
.tm-confirm-card{max-width:520px;margin:0 auto;background:var(--tm-violet);border-radius:var(--r-2xl);padding:3rem;text-align:center;box-shadow:var(--tm-sh-xl)}
.tm-legal-shell{padding:6rem 1.5rem 5rem;background:var(--tm-white)}
.tm-legal-doc{max-width:760px;margin:0 auto}
.tm-legal-doc h2{font-family:var(--ff-head);font-size:1.1rem;font-weight:700;color:var(--tm-ink);margin:2.5rem 0 .6rem;padding-top:2rem;border-top:1px solid var(--tm-border);letter-spacing:-.01em}
.tm-legal-doc h2:first-child{margin-top:0;padding-top:0;border-top:none}
.tm-legal-doc p{font-size:.86rem;color:var(--tm-muted);line-height:1.82;margin-bottom:1rem}
.tm-legal-doc ul{font-size:.86rem;color:var(--tm-muted);padding-left:1.2rem;margin-bottom:1rem;line-height:1.78;list-style:disc}
.tm-legal-doc a{color:var(--tm-violet)}
.tm-legal-meta{font-size:.76rem;color:var(--tm-muted2);margin-bottom:2.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--tm-border)}
.tm-legal-tbl{width:100%;border-collapse:collapse;margin:1.5rem 0;font-size:.8rem}
.tm-legal-tbl th{background:var(--tm-soft);color:var(--tm-ink);padding:.6rem 1rem;text-align:left;font-family:var(--ff-head);font-weight:700}
.tm-legal-tbl td{padding:.5rem 1rem;border-bottom:1px solid var(--tm-border);color:var(--tm-muted)}

/* ═══════════════════════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════════════════════ */
.tm-footer{background:var(--tm-ink);padding:6rem 1.5rem 3rem}
.tm-footer-outer{max-width:1400px;margin:0 auto}
.tm-footer-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;padding-bottom:4rem;border-bottom:1px solid rgba(255,255,255,.05);margin-bottom:2.5rem}
.tm-footer-brand{font-family:var(--ff-head);font-size:1.1rem;font-weight:800;color:#fff;margin-bottom:.3rem;letter-spacing:-.02em}
.tm-footer-brand em{color:var(--tm-orange);font-style:normal}
.tm-footer-tag{font-size:.74rem;color:rgba(255,255,255,.2);max-width:22ch;line-height:1.7;margin-bottom:.8rem}
.tm-footer-biz{font-size:.68rem;color:rgba(255,255,255,.1);line-height:1.85}
.tm-footer-biz a:hover{color:rgba(255,255,255,.3)}
.tm-footer-col-h{font-size:.52rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.1);margin-bottom:1.2rem}
.tm-footer-nav{display:flex;flex-direction:column;gap:.55rem}
.tm-footer-nav a{font-size:.76rem;color:rgba(255,255,255,.18);transition:color .15s}
.tm-footer-nav a:hover{color:#fff}
.tm-footer-btm{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}
.tm-footer-copy{font-size:.64rem;color:rgba(255,255,255,.07)}
.tm-footer-dig{font-size:.62rem;color:rgba(255,255,255,.05);font-style:italic}
.tm-footer-legal{display:flex;gap:1.5rem}
.tm-footer-legal a{font-size:.62rem;color:rgba(255,255,255,.09);transition:color .15s}
.tm-footer-legal a:hover{color:rgba(255,255,255,.3)}

/* ═══════════════════════════════════════════════════════════
   COOKIE + CHAT
   ═══════════════════════════════════════════════════════════ */
.tm-cookie{position:fixed;bottom:1.5rem;left:50%;transform:translateX(-50%);z-index:200;background:#fff;border:1.5px solid var(--tm-border2);border-top:3px solid var(--tm-violet);border-radius:var(--r-2xl);box-shadow:var(--tm-sh-xl);padding:1.1rem 1.8rem;max-width:540px;width:calc(100% - 3rem);display:flex;align-items:center;gap:1.5rem;transition:opacity .3s,transform .3s}
.tm-cookie.tm-ck-gone{opacity:0;pointer-events:none;transform:translateX(-50%) translateY(12px)}
.tm-ck-txt{font-size:.75rem;color:var(--tm-muted);flex:1;line-height:1.6}
.tm-ck-txt a{color:var(--tm-violet)}
.tm-ck-y{background:var(--tm-violet);color:#fff;font-family:var(--ff-head);font-size:.74rem;font-weight:700;padding:.42rem 1.1rem;border-radius:var(--r-pill);border:none;cursor:pointer;white-space:nowrap}
.tm-ck-n{background:transparent;color:var(--tm-muted);font-size:.74rem;padding:.4rem .8rem;border:1px solid var(--tm-border2);border-radius:var(--r-pill);cursor:pointer;white-space:nowrap}
.tm-chat-fab{position:fixed;bottom:2rem;right:2rem;z-index:199;width:52px;height:52px;background:var(--tm-orange);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 20px rgba(240,78,27,.3);border:none;transition:transform .2s,background .2s}
.tm-chat-fab:hover{transform:scale(1.1);background:var(--tm-orange2)}
.tm-chat-win{position:fixed;bottom:5.2rem;right:2rem;z-index:199;width:300px;background:#fff;border:1.5px solid var(--tm-border2);border-top:3px solid var(--tm-orange);border-radius:var(--r-2xl);box-shadow:var(--tm-sh-xl);opacity:0;pointer-events:none;transform:translateY(10px) scale(.96);transform-origin:bottom right;transition:opacity .25s,transform .25s var(--ease)}
.tm-chat-win.tm-chat-on{opacity:1;pointer-events:auto;transform:none}
.tm-chat-hd{padding:.9rem 1.2rem;border-bottom:1px solid var(--tm-border);display:flex;align-items:center;justify-content:space-between}
.tm-chat-title{font-family:var(--ff-head);font-size:.88rem;font-weight:700;color:var(--tm-ink);display:flex;align-items:center;gap:.35rem}
.tm-chat-title::before{content:'';width:7px;height:7px;border-radius:50%;background:var(--tm-orange);flex-shrink:0}
.tm-chat-cls{background:none;border:none;color:var(--tm-muted);cursor:pointer}
.tm-chat-msgs{padding:.9rem;height:190px;overflow-y:auto;display:flex;flex-direction:column;gap:.55rem}
.tm-chat-bubble{max-width:90%;padding:.5rem .85rem;border-radius:var(--r-lg);font-size:.73rem;line-height:1.55}
.tm-chat-bubble--studio{background:var(--tm-soft);color:var(--tm-muted);align-self:flex-start}
.tm-chat-bubble--visitor{background:var(--tm-violet);color:#fff;align-self:flex-end}
.tm-chat-row{display:flex;border-top:1px solid var(--tm-border)}
.tm-chat-inp{flex:1;background:none;border:none;padding:.6rem .9rem;font-size:.74rem;color:var(--tm-ink);outline:none}
.tm-chat-inp::placeholder{color:var(--tm-muted2)}
.tm-chat-send{background:var(--tm-orange);color:#fff;border:none;padding:0 1rem;font-family:var(--ff-head);font-size:.66rem;font-weight:700;cursor:pointer;border-radius:0 0 var(--r-2xl) 0}

/* ═══════════════════════════════════════════════════════════
   REVEALS + MISC
   ═══════════════════════════════════════════════════════════ */
.tm-reveal{opacity:0;transform:translateY(18px);transition:opacity .55s ease,transform .55s ease}
.tm-reveal.tm-vis{opacity:1;transform:none}
.tm-d1{transition-delay:.06s}.tm-d2{transition-delay:.12s}.tm-d3{transition-delay:.18s}

/* Nav offset for floating pill */
.tm-page-top{padding-top:5.5rem}

/* ═══════════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════════ */
@media(max-width:1100px){
  .tm-pill-wrap{display:none}
  .tm-mob-toggle{display:flex}
  .tm-bento-grid{grid-template-columns:1fr 1fr}
  .tm-tile-a,.tm-tile-b{grid-column:auto;grid-row:auto}
  .tm-tile-c,.tm-tile-d,.tm-tile-e{grid-column:auto;grid-row:auto}
  .tm-svc-row{grid-template-columns:1fr 1fr}
  .tm-tier-row{grid-template-columns:1fr 1fr}
  .tm-tmon-grid{grid-template-columns:1fr 1fr}
  .tm-team-grid{grid-template-columns:1fr 1fr}
  .tm-work-grid{grid-template-columns:1fr 1fr}
  .tm-work-item:nth-child(1),.tm-work-item:nth-child(2),.tm-work-item:nth-child(3){grid-column:auto;grid-row:auto}
  .tm-work-story-card{grid-column:auto;grid-row:auto}
  .tm-proc-panel.tm-panel-on{grid-template-columns:1fr}
  .tm-faq-outer{grid-template-columns:1fr}
  .tm-cta-shell{grid-template-columns:1fr}
  .tm-cta-rhs{display:none}
  .tm-co-outer,.tm-build-cols,.tm-contact-grid,.tm-svc-body-cols{grid-template-columns:1fr}
  .tm-footer-top{grid-template-columns:1fr 1fr}
  .tm-mod-row{grid-template-columns:1fr 1fr}
}
@media(max-width:720px){
  .tm-svc-row{grid-template-columns:1fr}
  .tm-tier-row{grid-template-columns:1fr}
  .tm-tmon-grid{grid-template-columns:1fr}
  .tm-team-grid{grid-template-columns:1fr}
  .tm-footer-top{grid-template-columns:1fr}
  .tm-field-pair{grid-template-columns:1fr}
  .tm-bento-grid{grid-template-columns:1fr}
  .tm-mod-row{grid-template-columns:1fr}
}
