/*
Theme Name: THETNM 2026
Theme URI: https://thetnm.com
Author: Touch New Media
Author URI: https://thetnm.com
Description: Editorial, bold, playful FSE block theme for Touch New Media — a Thailand visual production studio (photography, film, web, AI visual). Syne display type with Instrument Serif italic accents, bright yellow accents and scrolling marquee bands. Dark-only.
Version: 1.0.0
Requires at least: 6.7
Tested up to: 7.0
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: thetnm-2026
Tags: full-site-editing, block-patterns, editorial, dark, custom-colors, custom-menu, portfolio
*/

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#0A0908;--surface:#141210;--border:#1f1c18;
  --text:#F4EFE6;--muted:#8a857a;
  --yellow:#F5D547;--yellow-hot:#FACC15;
  --font:'IBM Plex Sans Thai',sans-serif;
  --font-syne:'Syne','Syne Fallback',sans-serif;
  --font-serif:'Instrument Serif',serif;
  --t:0.25s ease;
}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:var(--font);-webkit-font-smoothing:antialiased;overflow-x:hidden}
img,video{max-width:100%;height:auto;display:block}

/* italic accent — using Instrument Serif Italic */
.it{font-family:var(--font-serif);font-style:italic;font-weight:400;letter-spacing:-.01em;text-transform:none}

/* ── NAV ── */
nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;justify-content:space-between;align-items:center;
  padding:1rem clamp(1.5rem,3vw,2.5rem);
  background:rgba(10,9,8,0.92);backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);
}
.logo-wrap{display:flex;align-items:center;gap:.6rem}
.logo-mark{
  width:32px;height:32px;border-radius:50%;
  background:var(--yellow);color:var(--bg);
  display:flex;align-items:center;justify-content:center;
  font-size:1.2rem;font-weight:900;line-height:0;
}
.logo-text{display:flex;flex-direction:column;line-height:1.15}
.logo-name{font-family:var(--font-syne);font-size:.8rem;font-weight:700;color:var(--text)}
.logo-tag{font-size:.5rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}

.nav-links{display:flex;gap:2rem;list-style:none}
.nav-links a{font-family:var(--font-syne);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--text);text-decoration:none;font-weight:500;transition:color var(--t)}
.nav-links a:hover{color:var(--yellow)}

.nav-right{display:flex;align-items:center;gap:1.25rem}
.nav-time{font-family:var(--font-syne);font-size:.65rem;letter-spacing:.12em;color:var(--muted);text-transform:uppercase}
.nav-cta{
  display:inline-flex;align-items:center;gap:.4rem;
  background:var(--yellow);color:var(--bg);
  padding:.6rem 1.1rem;border-radius:40px;
  font-family:var(--font-syne);font-size:.66rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  text-decoration:none;transition:all var(--t);
}
.nav-cta:hover{background:var(--yellow-hot);transform:translateX(2px)}
.nav-cta::after{content:'›';font-size:1.1rem;line-height:0}

/* ── HERO ── */
.hero{
  min-height:100svh;
  padding:6rem clamp(1.5rem,3vw,2.5rem) 2rem;
  position:relative;
  /* overflow clipping moved to the glow layer only (.hero-glow / ::before / ::after)
     so it can NEVER clip the hero title text */
  border-bottom:1px solid var(--border);
  display:flex;flex-direction:column;
}
/* glow layer: clips ONLY the blurred glows, not the title */
.hero::before,.hero::after{pointer-events:none}
.hero::before{
  content:'';position:absolute;top:-10%;left:30%;width:60%;height:60%;
  max-width:100%;
  background:radial-gradient(ellipse at center,rgba(245,213,71,0.18) 0%,transparent 60%);
  filter:blur(40px);
}
.hero::after{
  content:'';position:absolute;bottom:5%;right:0;width:50%;height:50%;
  max-width:100%;
  background:radial-gradient(ellipse at center,rgba(60,80,200,0.22) 0%,transparent 60%);
  filter:blur(60px);
}

.hero-eyebrow-row{
  position:relative;z-index:2;
  display:flex;justify-content:space-between;align-items:flex-start;
  margin-bottom:1rem;flex-wrap:wrap;gap:1rem;
}
.eyebrow-left{display:flex;flex-direction:column;gap:.2rem}
.eyebrow-pill{display:flex;align-items:center;gap:.6rem;font-family:var(--font-syne);font-size:.65rem;letter-spacing:.14em;text-transform:uppercase;color:var(--text);font-weight:600}
.dot-ring{width:12px;height:12px;border-radius:50%;border:1.5px solid var(--yellow);display:inline-block;position:relative}
.dot-ring::after{content:'';position:absolute;inset:2px;background:var(--yellow);border-radius:50%;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
.eyebrow-sub{font-family:var(--font-syne);font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);padding-left:1.4rem}
.eyebrow-right{text-align:right;font-family:var(--font-syne);font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);line-height:1.6}
.eyebrow-coords{color:var(--text);font-weight:600;margin-bottom:.15rem}

/* ★ HERO TITLE ★ */
.hero-title-wrap{position:relative;z-index:2;flex:1;display:flex;flex-direction:column;justify-content:center;margin:.5rem 0;width:100%;max-width:100%;min-width:0}
.hero-title{
  font-family:var(--font-syne);
  /* size scales with the smaller of viewport width / a per-letter cap so the
     longest line ("WE SHOOT" = 8 glyphs incl. space) always fits the padding box.
     12vw keeps the wide-screen cap from overflowing; 11rem max is reachable only
     when the line still fits. width/max-width guarantee no horizontal escape. */
  font-size:clamp(3.25rem,min(12vw,12.5vh),11rem);
  line-height:.86;letter-spacing:-.035em;
  font-weight:800;text-transform:uppercase;
  width:100%;max-width:100%;
}
/* keep "WE SHOOT" on ONE line; never wrap, never clip */
.hero-line{display:flex;align-items:center;gap:.18em;white-space:nowrap;max-width:100%}
.hero-line.line-1 span:first-child{color:var(--text)}
.hero-line.line-1 .word-shoot{color:var(--yellow)}
/* ── HERO ENTRANCE ANIMATION (plays once on load) ── */
/* line 1 "WE SHOOT": clip-path wipe in from left + slight translateX */
.hero-line.line-1{
  animation:heroWipeIn .9s cubic-bezier(.22,1,.36,1) both;
  animation-delay:.15s;
}
/* line 2 "we BUILD": cross-fade up, staggered after line 1 */
.hero-line.line-2{
  animation:heroFadeUp .9s cubic-bezier(.22,1,.36,1) both;
  animation-delay:.5s;
}
@keyframes heroWipeIn{
  from{clip-path:inset(0 100% 0 0);transform:translateX(-3%);opacity:.001}
  to{clip-path:inset(0 0 0 0);transform:translateX(0);opacity:1}
}
@keyframes heroFadeUp{
  from{opacity:0;transform:translateY(32px)}
  to{opacity:1;transform:translateY(0)}
}
.hero-line.line-2{margin-top:-.04em;gap:.1em}
.hero-line.line-2 .word-script{
  font-family:var(--font-serif);font-style:italic;font-weight:400;
  font-size:.55em;line-height:1;color:var(--text);
  letter-spacing:-.02em;text-transform:none;
  transform:translateY(.04em);display:inline-block;
}
.hero-line.line-2 .word-build{
  color:transparent;-webkit-text-stroke:1.5px var(--text);
}
/* a11y: reduced-motion users see the title fully + instantly, no animation */
@media (prefers-reduced-motion: reduce){
  .hero-line.line-1,.hero-line.line-2{
    animation:none;
    opacity:1;
    transform:none;
    clip-path:none;
  }
}

/* hero meta row */
.hero-meta-row{
  position:relative;z-index:2;
  display:grid;grid-template-columns:1.1fr 1.4fr auto;
  gap:2.5rem;align-items:end;
  padding-top:1.5rem;border-top:1px solid var(--border);margin-top:1rem;
}
@media(max-width:900px){.hero-meta-row{grid-template-columns:1fr;gap:1.5rem}}
.studio-label{font-family:var(--font-syne);font-size:.55rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:.5rem;font-weight:600}
.studio-text{font-size:.82rem;color:var(--text);line-height:1.65;max-width:32ch}
.studio-text-th{font-size:.78rem;color:var(--muted);line-height:1.7;margin-top:.4rem}
.stats-row{display:flex;gap:2.5rem}
.stat-num{font-family:var(--font-syne);font-size:clamp(2rem,3.5vw,3rem);line-height:1;font-weight:700;letter-spacing:-.02em}
.stat-num em{font-style:normal;color:var(--yellow)}
.stat-lbl{font-family:var(--font-syne);font-size:.55rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-top:.4rem;line-height:1.3;font-weight:500}
.hero-cta-block{display:flex;flex-direction:column;align-items:flex-end;gap:.5rem}
.cta-reel{
  display:inline-flex;align-items:center;gap:.6rem;
  background:var(--yellow);color:var(--bg);
  padding:.75rem 1.2rem .75rem 1.4rem;border-radius:40px;
  font-family:var(--font-syne);font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  text-decoration:none;transition:all var(--t);
}
.cta-reel:hover{background:var(--yellow-hot);transform:translateX(3px)}
.cta-reel-arrow{width:26px;height:26px;border-radius:50%;background:var(--bg);color:var(--yellow);display:flex;align-items:center;justify-content:center;font-size:.85rem}
.cta-th{font-size:.62rem;color:var(--muted);letter-spacing:.05em}

/* ── MARQUEE BANDS ── */
.marquee{
  border-top:1px solid var(--border);border-bottom:1px solid var(--border);
  overflow:hidden;padding:1.5rem 0;background:var(--bg);
  position:relative;
}
.marquee.yellow{background:var(--yellow);color:var(--bg);border-color:var(--yellow)}
.marquee-track{
  display:flex;gap:3rem;width:max-content;
  animation:scroll 30s linear infinite;
}
@keyframes scroll{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}
.marquee-item{
  display:flex;align-items:center;gap:3rem;
  font-family:var(--font-syne);
  font-size:clamp(1.75rem,4vw,3rem);
  font-weight:700;text-transform:uppercase;
  letter-spacing:-.02em;line-height:1;
  white-space:nowrap;
}
.marquee-item .it{font-family:var(--font-serif);font-style:italic;font-weight:400;text-transform:none;letter-spacing:-.01em}
.marquee-item::after{content:'+';font-weight:400;opacity:.7}

/* ── SECTION ── */
.section{padding:clamp(4rem,7vw,7rem) clamp(1.5rem,3vw,2.5rem);border-bottom:1px solid var(--border)}
.section-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:clamp(2.5rem,4vw,3.5rem);gap:2rem;flex-wrap:wrap}
.section-label{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--font-syne);font-size:.58rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--yellow);font-weight:600;margin-bottom:.7rem;
}
.section-label::before{content:'';width:6px;height:6px;background:var(--yellow);border-radius:50%}
.section-title{
  font-family:var(--font-syne);font-weight:700;
  font-size:clamp(2.5rem,6vw,5.5rem);
  line-height:.92;letter-spacing:-.025em;text-transform:uppercase;
}
.section-title .it{font-size:.85em;color:var(--text)}
.section-title-th{font-family:var(--font);font-weight:300;font-size:clamp(.95rem,1.4vw,1.15rem);color:var(--muted);margin-top:.4rem}
.section-meta{font-family:var(--font-syne);font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}

.btn-pill{
  display:inline-flex;align-items:center;gap:.5rem;
  background:transparent;color:var(--text);
  padding:.65rem 1.2rem;border:1px solid var(--border);border-radius:40px;
  font-family:var(--font-syne);font-size:.62rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  text-decoration:none;transition:all var(--t);
}
.btn-pill:hover{border-color:var(--yellow);color:var(--yellow)}

/* ── PORTFOLIO GRID ── */
.projects-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:1px;background:var(--border);border:1px solid var(--border);
}
@media(max-width:1024px){.projects-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.projects-grid{grid-template-columns:1fr}}

.project-card{background:var(--bg);display:block;text-decoration:none;overflow:hidden;transition:background var(--t)}
.project-card:hover{background:var(--surface)}
.proj-img{width:100%;aspect-ratio:3/2;background:var(--surface);position:relative;overflow:hidden}
.proj-img-inner{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;transition:transform .7s ease,opacity .4s ease;opacity:.85}
img.proj-img-inner{width:100%;height:100%;object-fit:cover;object-position:center}
.proj-img img{width:100%;height:100%;object-fit:cover;object-position:center}
.project-card:hover .proj-img-inner{transform:scale(1.05);opacity:1}
/* gradient art per card */
.gradient-1{background:radial-gradient(circle at 50% 70%,#D4621E 0%,#3D1810 50%,#0A0908 100%)}
.gradient-2{background:radial-gradient(circle at 30% 50%,#5A3D1C 0%,#2A1810 60%,#0A0908 100%)}
.gradient-3{background:radial-gradient(circle at 60% 40%,#2D4A6B 0%,#152535 60%,#0A0908 100%)}
.gradient-4{background:radial-gradient(circle at 40% 60%,#5A2E1A 0%,#2A150C 60%,#0A0908 100%)}
.proj-img-num{
  position:absolute;top:.7rem;left:.85rem;z-index:2;
  font-family:var(--font-syne);font-size:.6rem;color:var(--yellow);
  letter-spacing:.06em;font-weight:600;
}
.proj-body{padding:1rem 1.1rem 1.4rem;display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}
.proj-title{font-family:var(--font-syne);font-size:.9rem;font-weight:700;line-height:1.1;letter-spacing:-.01em;text-transform:uppercase;margin-bottom:.2rem}
.proj-title-th{font-size:.72rem;color:var(--muted);margin-bottom:.5rem}
.proj-tags{display:flex;flex-wrap:wrap;gap:.2rem}
.tag{font-family:var(--font-syne);font-size:.5rem;letter-spacing:.1em;text-transform:uppercase;font-weight:600;padding:.15rem .4rem;border:1px solid var(--border);color:var(--muted);border-radius:20px}
.proj-year{font-family:var(--font-syne);font-size:.6rem;color:var(--muted);letter-spacing:.05em;flex-shrink:0}

/* ── SERVICES — alternating layout ── */
.svc-row{
  display:grid;grid-template-columns:1fr 1fr;gap:0;
  border-bottom:1px solid var(--border);min-height:520px;
}
@media(max-width:900px){.svc-row{grid-template-columns:1fr;min-height:auto}}
.svc-content{
  padding:clamp(2.5rem,5vw,4rem);
  display:flex;flex-direction:column;justify-content:space-between;gap:2rem;
  border-right:1px solid var(--border);
}
.svc-content.reverse{order:2;border-right:none;border-left:1px solid var(--border)}
@media(max-width:900px){.svc-content.reverse{order:0;border-left:none}}
.svc-art{position:relative;overflow:hidden;background:var(--surface);min-height:300px}
/* Yellow card variant */
.svc-row.yellow{background:var(--yellow);color:var(--bg);border-color:var(--yellow)}
.svc-row.yellow .svc-content{border-color:rgba(10,9,8,0.15)}
.svc-row.yellow .svc-num{color:var(--bg)}
.svc-row.yellow .svc-num::before{background:var(--bg)}
.svc-row.yellow .svc-desc{color:var(--bg);opacity:.75}
.svc-row.yellow .tag{border-color:rgba(10,9,8,0.2);color:var(--bg)}
.svc-row.yellow .svc-stat-num{color:var(--bg)}
.svc-row.yellow .svc-stat-lbl{color:var(--bg);opacity:.6}

.svc-num{
  display:inline-flex;align-items:center;gap:.4rem;
  font-family:var(--font-syne);font-size:.58rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--yellow);font-weight:600;
}
.svc-num::before{content:'';width:6px;height:6px;background:var(--yellow);border-radius:50%}
.svc-title{
  font-family:var(--font-syne);font-weight:700;
  font-size:clamp(2.5rem,4.5vw,4.5rem);
  line-height:.92;letter-spacing:-.025em;text-transform:uppercase;
  margin-top:1rem;
}
.svc-title-th{font-size:.85rem;color:var(--muted);margin-top:.5rem;font-weight:300}
.svc-row.yellow .svc-title-th{color:var(--bg);opacity:.6}
.svc-desc{font-size:.82rem;color:var(--text);line-height:1.7;opacity:.85;max-width:42ch}

.svc-bottom{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;flex-wrap:wrap}
.svc-stats{display:flex;gap:2rem}
.svc-stat-num{font-family:var(--font-syne);font-size:1.75rem;font-weight:700;line-height:1;letter-spacing:-.02em;color:var(--text)}
.svc-stat-lbl{font-family:var(--font-syne);font-size:.55rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-top:.3rem;font-weight:500}
.svc-tags{display:flex;flex-wrap:wrap;gap:.3rem}

/* Service art treatments */
.art-photo{background:radial-gradient(ellipse at 50% 70%,#E85D1C 0%,#5A2210 50%,#0A0908 100%)}
.art-film{background:radial-gradient(ellipse at 50% 50%,#3D5BA8 0%,#1A2548 60%,#0A0908 100%)}
.art-web{background:linear-gradient(180deg,#1a1814 0%,#0e0c0a 100%);display:flex;align-items:center;justify-content:center;padding:2rem}
.art-web-window{
  width:90%;max-width:380px;background:#F4EFE6;border-radius:6px;overflow:hidden;
  box-shadow:0 30px 80px rgba(0,0,0,0.5);
}
.art-web-bar{background:#e0dbd0;padding:.5rem .75rem;display:flex;gap:.3rem;align-items:center}
.art-web-dot{width:8px;height:8px;border-radius:50%;background:#bbb}
.art-web-content{padding:1.25rem;color:#0A0908;font-family:var(--font-syne);font-weight:700}
.art-web-title{font-size:1.1rem;text-transform:uppercase}
.art-web-sub{font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;color:#777;margin-top:.5rem;font-weight:500}
.art-web-img{margin-top:.75rem;height:120px;background:linear-gradient(135deg,#D4621E,#3D1810);border-radius:3px;position:relative}
.art-web-img::after{content:'';position:absolute;right:8px;bottom:8px;width:24px;height:24px;background:var(--yellow);border-radius:50%}
.art-ai{
  background:
    radial-gradient(circle at 30% 30%,rgba(232,93,28,0.6),transparent 50%),
    radial-gradient(circle at 70% 70%,rgba(61,91,168,0.7),transparent 50%),
    radial-gradient(circle at 50% 50%,rgba(20,18,16,1),rgba(10,9,8,1));
}

/* ── STUDIO NOTE ── */
.studio-note-section{
  padding:clamp(5rem,8vw,7rem) clamp(1.5rem,3vw,2.5rem);
  border-bottom:1px solid var(--border);
}
.studio-note-label{font-family:var(--font-syne);font-size:.58rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:1.5rem;font-weight:600}
.studio-note-text{
  font-family:var(--font-syne);font-weight:600;
  font-size:clamp(1.5rem,3vw,2.5rem);
  line-height:1.25;letter-spacing:-.01em;
  max-width:64ch;
}
.studio-note-text .it{color:var(--yellow);font-weight:400}
.studio-note-th{font-size:.95rem;color:var(--muted);margin-top:1.5rem;max-width:60ch;line-height:1.65;font-weight:300}

/* ── PROCESS ── */
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);border:1px solid var(--border)}
@media(max-width:900px){.process-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:500px){.process-grid{grid-template-columns:1fr}}
.proc-step{background:var(--bg);padding:2.5rem 1.75rem;position:relative;overflow:hidden}
.proc-step::before{content:'';position:absolute;top:-35%;right:-25%;width:80%;height:80%;border-radius:50%;filter:blur(55px);opacity:.5;pointer-events:none;z-index:0;transition:opacity .4s ease,transform .6s ease}
.proc-step:nth-child(1)::before{background:radial-gradient(circle,#E85D1C 0%,transparent 70%)}
.proc-step:nth-child(2)::before{background:radial-gradient(circle,#3D5BA8 0%,transparent 70%)}
.proc-step:nth-child(3)::before{background:radial-gradient(circle,#D4621E 0%,transparent 70%)}
.proc-step:nth-child(4)::before{background:radial-gradient(circle,#F5D547 0%,transparent 70%)}
.proc-step:hover::before{opacity:.7;transform:scale(1.1)}
.proc-step>*{position:relative;z-index:1}
.proc-num{
  font-family:var(--font-syne);font-weight:700;
  font-size:2rem;color:var(--yellow);
  line-height:1;letter-spacing:-.02em;
  margin-bottom:1.5rem;
}
.proc-title{font-family:var(--font-syne);font-size:1.3rem;font-weight:700;letter-spacing:-.01em;text-transform:uppercase;margin-bottom:.25rem;line-height:1}
.proc-title-th{font-size:.78rem;color:var(--muted);margin-bottom:.85rem}
.proc-desc{font-size:.8rem;color:var(--text);line-height:1.7;opacity:.85}

/* ── CONTACT — MASSIVE ── */
.contact{
  padding:clamp(7rem,12vw,12rem) clamp(1.5rem,3vw,2.5rem);
  text-align:center;border-bottom:1px solid var(--border);
  position:relative;overflow:hidden;
}
.contact-inner{position:relative;z-index:1;max-width:1400px;margin:0 auto}
.contact-label{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--font-syne);font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--yellow);font-weight:600;margin-bottom:2.5rem;
}
.contact-label::before{content:'';width:6px;height:6px;background:var(--yellow);border-radius:50%}

.contact-heading{
  font-family:var(--font-syne);font-weight:700;
  font-size:clamp(4rem,13vw,13rem);
  line-height:.86;letter-spacing:-.035em;text-transform:uppercase;
}
.contact-heading .it{
  font-family:var(--font-serif);font-style:italic;font-weight:400;
  text-transform:none;color:var(--yellow);font-size:.95em;letter-spacing:-.02em;
}
.contact-heading .outline{
  color:transparent;-webkit-text-stroke:1.5px var(--text);
}
.contact-sub-th{color:var(--muted);margin:2.5rem auto 2.5rem;font-size:.95rem;line-height:1.7;max-width:48ch}
.contact-actions{display:flex;justify-content:center;gap:.75rem;flex-wrap:wrap;margin-bottom:3rem}
.cta-large{
  display:inline-flex;align-items:center;gap:.75rem;
  background:var(--yellow);color:var(--bg);
  padding:1rem 1.6rem 1rem 1.9rem;border-radius:50px;
  font-family:var(--font-syne);font-size:.72rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  text-decoration:none;transition:all var(--t);
}
.cta-large:hover{background:var(--yellow-hot);transform:translateY(-2px)}
.cta-large-arrow{width:30px;height:30px;border-radius:50%;background:var(--bg);color:var(--yellow);display:flex;align-items:center;justify-content:center;font-size:.95rem}
.cta-ghost{
  display:inline-flex;align-items:center;gap:.5rem;
  border:1px solid var(--border);color:var(--text);
  padding:1rem 1.6rem;border-radius:50px;
  font-family:var(--font-syne);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;
  text-decoration:none;transition:all var(--t);
}
.cta-ghost:hover{border-color:var(--yellow);color:var(--yellow)}
.contact-meta{
  display:flex;justify-content:center;gap:3rem;flex-wrap:wrap;
  padding-top:2rem;border-top:1px solid var(--border);max-width:600px;margin:0 auto;
}
.contact-meta-item{font-family:var(--font-syne);font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.contact-meta-item strong{color:var(--text);font-weight:700;display:block;margin-top:.3rem}

/* ── FOOTER ── */
footer{padding:3rem clamp(1.5rem,3vw,2.5rem);background:var(--bg)}
.footer-grid{display:grid;grid-template-columns:1.5fr repeat(4,1fr);gap:2.5rem;margin-bottom:2.5rem}
@media(max-width:900px){.footer-grid{grid-template-columns:1fr 1fr;gap:2rem}}
@media(max-width:500px){.footer-grid{grid-template-columns:1fr}}
.footer-col-title{font-family:var(--font-syne);font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:1rem;font-weight:600}
.footer-about{font-size:.82rem;color:var(--text);line-height:1.7;opacity:.85;max-width:34ch}
.footer-col ul{list-style:none}
.footer-col a{font-family:var(--font-syne);font-size:.72rem;color:var(--text);text-decoration:none;display:block;padding:.3rem 0;letter-spacing:-.005em;transition:color var(--t)}
.footer-col a:hover{color:var(--yellow)}
.footer-bottom{
  padding-top:2rem;border-top:1px solid var(--border);
  display:flex;justify-content:space-between;align-items:center;gap:2rem;flex-wrap:wrap;
}
.footer-copy{font-family:var(--font-syne);font-size:.6rem;color:var(--muted);letter-spacing:.12em;text-transform:uppercase}

@media(max-width:768px){
  nav{padding:.85rem 1.5rem}
  .nav-links,.nav-time{display:none}
  /* Stack hero title words (WE / SHOOT / we / BUILD) so it always fits the
     viewport — prevents horizontal overflow that makes mobile Safari zoom out. */
  .hero-title{font-size:clamp(2.25rem,13.5vw,5rem);line-height:.96;letter-spacing:-.035em}
  .hero-line{flex-direction:column;align-items:flex-start;gap:0}
  .hero-line>span{max-width:100%}
  .hero-line.line-2{margin-top:0;gap:0}
  .hero-line.line-2 .word-script{font-size:.42em;transform:none;margin-bottom:.05em}
}
/* Hard guard against any element forcing horizontal scroll on small screens. */
html{overflow-x:hidden}

/* ── WORDPRESS INTEGRATION (minimal, design-preserving) ── */
.wp-site-blocks{display:block}
/* Neutralize default block layout constraints so bespoke full-width sections render edge to edge */
.wp-site-blocks > *{margin-block:0}
body .is-layout-flow > *{margin-block-start:0}
/* Admin bar offset for fixed nav */
.admin-bar nav{top:32px}
@media(max-width:782px){.admin-bar nav{top:46px}}
/* Single project content width helper */
.single-project-wrap{max-width:1400px;margin:0 auto}
.single-project-content{font-size:.95rem;line-height:1.8;color:var(--text);opacity:.9;max-width:64ch}
.single-project-content p{margin-bottom:1.2rem}
.single-project-content a{color:var(--yellow)}
.proj-meta-row{display:flex;flex-wrap:wrap;gap:2.5rem;margin:2rem 0;padding:1.5rem 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.proj-meta-item{font-family:var(--font-syne);font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.proj-meta-item strong{color:var(--text);font-weight:700;display:block;margin-top:.3rem;font-size:.85rem;letter-spacing:0}
.back-link{display:inline-flex;align-items:center;gap:.5rem;margin-top:3rem;font-family:var(--font-syne);font-size:.65rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);text-decoration:none;transition:color var(--t)}
.back-link:hover{color:var(--yellow)}
.single-featured{width:100%;margin:2.5rem 0;border:1px solid var(--border);overflow:hidden}
.single-featured img{width:100%;height:auto;display:block}

/* Accessibility */
.screen-reader-text{
  border:0;clip:rect(1px,1px,1px,1px);clip-path:inset(50%);
  height:1px;width:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;word-wrap:normal !important;
}
.skip-link:focus{
  display:block;position:fixed;top:8px;left:8px;z-index:1000;
  background:var(--yellow);color:var(--bg);padding:.6rem 1rem;border-radius:6px;
  font-family:var(--font-syne);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;
}

/* Reduced motion — disable marquee + decorative animations */
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important;scroll-behavior:auto !important}
  .marquee-track{animation:none;transform:none}
}
