/* =====================================================================
   Arobot Studio — design system v3
   Font: Kanit (Thai + Latin). Premium production studio theme.
   Dark = default. Light theme via [data-theme="light"].
   ===================================================================== */

:root {
  /* ---- DARK THEME (default) ---- */
  --bg:        #0c0b0e;
  --bg-2:      #110f13;
  --surface:   #17151b;
  --surface-2: #1f1c24;
  --surface-3: #262230;
  --line:      rgba(255,255,255,0.09);
  --line-2:    rgba(255,255,255,0.16);
  --text:      #f4f1ea;
  --text-2:    #cbc7bf;
  --muted:     #908c84;

  --gold:      #dcbd6e;
  --gold-soft: #ecd089;
  --gold-deep: #b88f3c;
  --gold-rgb:  220,189,110;
  --gold-on:   #1c1606;       /* text on gold buttons */

  --shadow-sm: 0 4px 14px -6px rgba(0,0,0,.55);
  --shadow-md: 0 18px 44px -22px rgba(0,0,0,.85);
  --shadow-lg: 0 40px 90px -45px rgba(0,0,0,.9);
  --glow:      0 0 0 1px rgba(var(--gold-rgb),.0), 0 22px 50px -26px rgba(var(--gold-rgb),.35);

  --hero-grad: radial-gradient(70vw 70vw at 82% -8%, rgba(var(--gold-rgb),.10), transparent 58%),
               radial-gradient(60vw 60vw at -8% 108%, rgba(255,255,255,.035), transparent 60%);

  --font: 'Kanit', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  --maxw: 1200px;
  --pad: clamp(1.25rem, 5vw, 4rem);
  --radius: 14px;
  --radius-lg: 22px;
  --ease: cubic-bezier(0.22, 1, 0.36, 1);

  color-scheme: dark;
}

[data-theme="light"] {
  --bg:        #f6f2ea;
  --bg-2:      #efeae0;
  --surface:   #ffffff;
  --surface-2: #fbf8f2;
  --surface-3: #f3eee4;
  --line:      rgba(28,22,12,0.12);
  --line-2:    rgba(28,22,12,0.22);
  --text:      #1d1a14;
  --text-2:    #4a463d;
  --muted:     #7a756a;

  --gold:      #a9802f;
  --gold-soft: #c9a24a;
  --gold-deep: #8a6420;
  --gold-rgb:  169,128,47;
  --gold-on:   #fffaf0;

  --shadow-sm: 0 4px 14px -8px rgba(60,45,15,.25);
  --shadow-md: 0 18px 40px -24px rgba(60,45,15,.35);
  --shadow-lg: 0 36px 80px -46px rgba(60,45,15,.40);
  --glow:      0 22px 48px -28px rgba(var(--gold-rgb),.45);

  --hero-grad: radial-gradient(70vw 70vw at 84% -10%, rgba(var(--gold-rgb),.12), transparent 58%),
               radial-gradient(55vw 55vw at -6% 110%, rgba(120,90,30,.06), transparent 60%);

  color-scheme: light;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; scroll-padding-top: 92px; -webkit-text-size-adjust: 100%; }

body {
  background: var(--bg);
  color: var(--text);
  font-family: var(--font);
  font-weight: 300;
  line-height: 1.7;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  transition: background .4s var(--ease), color .4s var(--ease);
}

body::before {
  content:""; position: fixed; inset:0; z-index:-2; background: var(--hero-grad), var(--bg);
  transition: background .4s var(--ease);
}
::selection { background: rgba(var(--gold-rgb),.3); color: var(--text); }
::-webkit-scrollbar { width: 10px; }
::-webkit-scrollbar-track { background: var(--bg); }
::-webkit-scrollbar-thumb { background: rgba(var(--gold-rgb),.35); border-radius:6px; border:2px solid var(--bg); }

img, svg, video, iframe { display:block; max-width:100%; }
a { color: inherit; text-decoration: none; transition: color .25s var(--ease); }

/* Type ------------------------------------------------------------- */
h1,h2,h3,h4 { color: var(--text); font-weight: 600; line-height: 1.16; letter-spacing: -0.01em; }
h1 { font-weight: 700; font-size: clamp(2.2rem, 5vw, 3.7rem); line-height: 1.1; }
h2 { font-weight: 600; font-size: clamp(1.7rem, 3.3vw, 2.5rem); }
h3 { font-size: 1.2rem; font-weight: 600; }
p  { color: var(--text-2); }
strong { font-weight: 600; }

.gold { color: var(--gold); }
.gold-text {
  color: var(--gold-soft);
}

.eyebrow {
  display:inline-flex; align-items:center; gap:.6rem;
  font-size:.78rem; font-weight:600; letter-spacing:.04em;
  color: var(--gold); margin-bottom:1.1rem;
}
.eyebrow::before { content:""; width:26px; height:1px; background: linear-gradient(90deg,var(--gold),transparent); }

.sr-only { position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); border:0; }
.skip-link { position:absolute; top:-120px; left:16px; z-index:9999; background:var(--gold); color:var(--gold-on); padding:10px 18px; border-radius:8px; font-weight:600; transition:top .3s; }
.skip-link:focus { top:16px; }

/* Layout ----------------------------------------------------------- */
.section { padding: clamp(4.5rem,9vw,7.5rem) var(--pad); }
.wrap { max-width: var(--maxw); margin:0 auto; }
.section-head { max-width: 680px; margin:0 auto clamp(2.4rem,5vw,3.8rem); text-align:center; }
.section-head.left { margin-left:0; text-align:left; }
.section-head p { color: var(--muted); font-size:1.05rem; margin-top:.9rem; }
.hr-line { height:1px; background: var(--line); border:0; max-width:var(--maxw); margin:0 auto; }

/* Buttons ---------------------------------------------------------- */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:.55rem;
  padding:.95rem 1.8rem; border-radius:999px; font-size:.98rem; font-weight:600;
  cursor:pointer; border:1px solid transparent;
  transition: transform .3s var(--ease), box-shadow .3s var(--ease), background .3s var(--ease), border-color .3s var(--ease), color .3s var(--ease);
}
.btn svg { width:18px; height:18px; }
.btn-primary { background: var(--gold); color: var(--gold-on); box-shadow: 0 14px 32px -14px rgba(var(--gold-rgb),.75); }
.btn-primary:hover { transform: translateY(-2px); box-shadow: 0 20px 40px -14px rgba(var(--gold-rgb),.7); filter: brightness(1.05); }
.btn-ghost { background: transparent; color: var(--text); border-color: var(--line-2); }
.btn-ghost:hover { border-color: var(--gold); color: var(--gold); transform: translateY(-2px); }

/* Header ----------------------------------------------------------- */
.site-header {
  position: fixed; inset:0 0 auto 0; z-index:1000;
  display:flex; align-items:center; justify-content:space-between; gap:1rem;
  padding:1rem var(--pad);
  background: transparent; border-bottom:1px solid transparent;
  transition: background .4s var(--ease), border-color .4s var(--ease), padding .4s var(--ease), backdrop-filter .4s var(--ease);
}
.site-header.scrolled {
  background: color-mix(in srgb, var(--bg) 86%, transparent);
  backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
  border-bottom-color: var(--line); padding-top:.7rem; padding-bottom:.7rem;
}
.brand { display:inline-flex; align-items:center; gap:.62rem; }
.brand-mark { height:40px; width:auto; display:block; transition: filter .3s var(--ease); }
[data-theme="light"] .brand-mark { filter: invert(1); }
.brand-word { font-family:var(--font); font-weight:600; font-size:1.18rem; letter-spacing:.01em; line-height:1; color:var(--text); white-space:nowrap; }
.brand-word b { font-weight:300; color:var(--gold); margin-left:.16em; }

.nav { display:flex; align-items:center; gap:1.9rem; }
.nav a { font-size:.95rem; color: var(--text-2); position:relative; padding:.2rem 0; }
.nav a::after { content:""; position:absolute; left:0; bottom:-3px; height:1.5px; width:0; background:var(--gold); transition:width .3s var(--ease); }
.nav a:hover { color: var(--text); }
.nav a:hover::after { width:100%; }

.header-tools { display:flex; align-items:center; gap:.7rem; }
.theme-toggle {
  width:40px; height:40px; border-radius:999px; border:1px solid var(--line-2);
  background: var(--surface); color: var(--text); cursor:pointer;
  display:flex; align-items:center; justify-content:center; transition: all .3s var(--ease);
}
.theme-toggle:hover { border-color: var(--gold); color: var(--gold); transform: translateY(-1px); }
.theme-toggle svg { width:18px; height:18px; }
.theme-toggle .ico-sun { display:none; }
[data-theme="light"] .theme-toggle .ico-sun { display:block; }
[data-theme="light"] .theme-toggle .ico-moon { display:none; }

.header-cta { display:inline-flex; align-items:center; gap:.5rem; padding:.55rem 1.2rem; border-radius:999px; border:1px solid var(--line-2); color:var(--text); font-size:.9rem; font-weight:500; }
.header-cta svg { width:16px; height:16px; color:var(--gold); }
.header-cta:hover { border-color:var(--gold); color:var(--gold); }

.nav-toggle { display:none; background:none; border:0; cursor:pointer; padding:.4rem; z-index:1100; }
.hamburger, .hamburger::before, .hamburger::after { display:block; width:24px; height:2px; background:var(--text); border-radius:2px; transition:transform .3s var(--ease), opacity .3s var(--ease); }
.hamburger { position:relative; }
.hamburger::before,.hamburger::after { content:""; position:absolute; left:0; }
.hamburger::before { top:-7px; } .hamburger::after { top:7px; }

/* Hero ------------------------------------------------------------- */
.hero {
  padding: clamp(7.5rem,13vh,10.5rem) var(--pad) clamp(3.5rem,7vw,5.5rem);
  display:grid; grid-template-columns: 1.05fr .95fr; gap: clamp(2rem,5vw,4rem);
  align-items:center; max-width:var(--maxw); margin:0 auto;
}
.hero-eyebrow { display:inline-flex; align-items:center; gap:.6rem; font-size:.78rem; letter-spacing:.03em; color:var(--muted); margin-bottom:1.3rem; }
.hero-eyebrow .dot { width:7px; height:7px; border-radius:50%; background:var(--gold); box-shadow:0 0 10px rgba(var(--gold-rgb),.9); }
.hero h1 { margin-bottom:1.4rem; }
.hero h1 em { font-style:italic; }
.hero-copy { font-size: clamp(1.02rem,1.5vw,1.18rem); color:var(--text-2); max-width:34em; margin-bottom:2rem; }
.hero-actions { display:flex; flex-wrap:wrap; gap:1rem; margin-bottom:2.2rem; }
.hero-trust { display:flex; align-items:flex-start; gap:.7rem; font-size:.88rem; color:var(--muted); max-width:36em; }
.hero-trust svg { width:18px; height:18px; color:var(--gold); flex-shrink:0; margin-top:3px; }

/* Hero image stack (replaces hologram) */
.hero-visual { position:relative; }
.hero-photo {
  position:relative; border-radius:var(--radius-lg); overflow:hidden;
  border:1px solid var(--line); box-shadow: var(--shadow-lg); aspect-ratio: 4/3;
}
.hero-photo img { width:100%; height:100%; object-fit:cover; }
.hero-photo::after { content:""; position:absolute; inset:0; background: linear-gradient(180deg, transparent 55%, rgba(0,0,0,.5)); }
.hero-badge {
  position:absolute; left:18px; bottom:16px; z-index:2; display:flex; align-items:center; gap:.6rem;
  background: color-mix(in srgb, var(--bg) 70%, transparent); backdrop-filter: blur(10px);
  border:1px solid var(--line-2); border-radius:999px; padding:.5rem .95rem; font-size:.8rem; color:var(--text);
}
.hero-badge .pip { width:8px; height:8px; border-radius:50%; background:var(--gold); }
.hero-float {
  position:absolute; top:-14px; right:-14px; z-index:3;
  background: var(--surface-2); border:1px solid var(--line-2); border-radius:14px;
  padding:.7rem 1rem; box-shadow: var(--shadow-md); display:flex; flex-direction:column; gap:.1rem;
}
.hero-float strong { color: #ffffff; font-size:1.15rem; font-weight:700; }
.hero-float span { font-size:.72rem; color:#f7f3ec; letter-spacing:.04em; font-weight:600; }

/* Trust band / clients --------------------------------------------- */
.trust-band { border-top:1px solid var(--line); border-bottom:1px solid var(--line); background: var(--surface); }
.trust-band .wrap { display:grid; grid-template-columns: 0.9fr 1.1fr; gap: clamp(1.6rem,4vw,3rem); align-items:center; padding: clamp(2.4rem,5vw,3.4rem) 0; }
.trust-copy .eyebrow { margin-bottom:.7rem; }
.trust-copy h2 { font-size: clamp(1.4rem,2.4vw,1.9rem); margin-bottom:.6rem; }
.trust-copy p { color: var(--muted); font-size:.98rem; }
.clients-frame { border:1px solid var(--line); border-radius: var(--radius); overflow:hidden; background:#fff; box-shadow: var(--shadow-sm); }
.clients-frame img { width:100%; height:auto; display:block; }

/* Stats ------------------------------------------------------------ */
.stats { display:grid; grid-template-columns:repeat(4,1fr); gap:1.4rem; max-width:var(--maxw); margin:0 auto; }
.stat { text-align:center; padding:1.4rem 1rem; border:1px solid var(--line); border-radius:var(--radius); background: var(--surface); box-shadow: var(--shadow-sm); }
.stat dt { font-size: clamp(1.6rem,3vw,2.4rem); font-weight:700; color:var(--gold); line-height:1; }
.stat dd { font-size:.82rem; color:var(--muted); letter-spacing:.02em; margin-top:.45rem; }

/* Intro ------------------------------------------------------------ */
.intro .wrap { display:grid; grid-template-columns:.9fr 1.1fr; gap: clamp(2rem,5vw,4.5rem); align-items:start; }
.intro-copy p { font-size:1.08rem; line-height:1.85; color:var(--text-2); }
.intro-copy p + p { margin-top:1.4rem; }

/* Services --------------------------------------------------------- */
.service-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.3rem; max-width:var(--maxw); margin:0 auto; }
.service-card {
  position:relative; background: linear-gradient(180deg, var(--surface-2), var(--surface));
  border:1px solid var(--line); border-radius:var(--radius); padding:2.1rem 1.85rem; overflow:hidden;
  transition: transform .4s var(--ease), border-color .4s var(--ease), box-shadow .4s var(--ease);
}
.service-card::before { content:""; position:absolute; left:0; top:0; height:3px; width:0; background:linear-gradient(90deg,var(--gold-soft),var(--gold-deep)); transition: width .45s var(--ease); }
.service-card:hover { transform: translateY(-6px); border-color: rgba(var(--gold-rgb),.4); box-shadow: var(--glow); }
.service-card:hover::before { width:100%; }
.service-icon { width:50px; height:50px; border-radius:13px; display:flex; align-items:center; justify-content:center; border:1px solid rgba(var(--gold-rgb),.3); background: rgba(var(--gold-rgb),.08); margin-bottom:1.3rem; }
.service-icon svg { width:24px; height:24px; color:var(--gold); }
.service-num { position:absolute; top:1.6rem; right:1.7rem; font-size:.85rem; color:var(--muted); font-weight:500; }
.service-card h3 { margin-bottom:.55rem; }
.service-card p { font-size:.92rem; color:var(--muted); line-height:1.65; }

/* Portfolio gallery ------------------------------------------------ */
.gallery { display:grid; grid-template-columns:repeat(4, 1fr); grid-auto-rows: 200px; gap:1rem; max-width:var(--maxw); margin:0 auto; }
.tile { position:relative; overflow:hidden; border-radius:var(--radius); border:1px solid var(--line); cursor:pointer; background:var(--surface); box-shadow: var(--shadow-sm); }
.tile img { width:100%; height:100%; object-fit:cover; transition: transform .7s var(--ease), filter .5s var(--ease); }
.tile::after { content:""; position:absolute; inset:0; background: linear-gradient(180deg, transparent 45%, rgba(0,0,0,.72)); opacity:.85; transition: opacity .4s var(--ease); }
.tile-cap { position:absolute; left:0; right:0; bottom:0; z-index:2; padding:1rem 1.1rem; transform: translateY(6px); opacity:.95; transition: transform .4s var(--ease); }
.tile-cap .cat { font-size:.66rem; letter-spacing:.12em; text-transform:uppercase; color:var(--gold-soft); font-weight:600; }
.tile-cap .name { display:block; color:#fff; font-size:.98rem; font-weight:500; margin-top:.15rem; }
.tile:hover img { transform: scale(1.07); }
.tile:hover::after { opacity:1; }
.tile:hover .tile-cap { transform: translateY(0); }
.tile.wide { grid-column: span 2; }
.tile.tall { grid-row: span 2; }
.gallery-foot { text-align:center; margin-top:2rem; display:flex; flex-wrap:wrap; gap:1rem; justify-content:center; }

/* Lightbox */
.lightbox { position:fixed; inset:0; z-index:2000; background:rgba(0,0,0,.92); display:none; align-items:center; justify-content:center; padding:2rem; }
.lightbox.open { display:flex; }
.lightbox img { max-width:92vw; max-height:86vh; border-radius:10px; box-shadow:0 30px 80px -20px #000; }
.lightbox-close { position:absolute; top:1.2rem; right:1.4rem; width:46px; height:46px; border-radius:999px; border:1px solid rgba(255,255,255,.3); background:rgba(0,0,0,.4); color:#fff; font-size:1.6rem; cursor:pointer; line-height:1; }
.lightbox-cap { position:absolute; bottom:1.4rem; left:0; right:0; text-align:center; color:#eee; font-size:.95rem; }
.lightbox-cap b { color:var(--gold-soft); }

/* Showreel / video ------------------------------------------------- */
.reel { max-width: 980px; margin:0 auto; }
.reel-frame { position:relative; border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--line); box-shadow: var(--shadow-lg); aspect-ratio:16/9; background:#000; }
.reel-frame iframe { position:absolute; inset:0; width:100%; height:100%; border:0; }
.reel-poster { position:absolute; inset:0; cursor:pointer; }
.reel-poster img { width:100%; height:100%; object-fit:cover; opacity:.78; transition: opacity .4s var(--ease), transform .6s var(--ease); }
.reel-poster:hover img { opacity:.92; transform: scale(1.03); }
.reel-play { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; }
.reel-play span { width:78px; height:78px; border-radius:50%; background: rgba(var(--gold-rgb),.92); display:flex; align-items:center; justify-content:center; box-shadow:0 12px 40px rgba(0,0,0,.5); transition: transform .3s var(--ease); }
.reel-poster:hover .reel-play span { transform: scale(1.08); }
.reel-play svg { width:30px; height:30px; color:var(--gold-on); margin-left:4px; }
.reel-meta { display:flex; flex-wrap:wrap; justify-content:space-between; gap:1rem; margin-top:1.1rem; color:var(--muted); font-size:.9rem; }
.reel-meta a { color:var(--gold); }

/* VIP -------------------------------------------------------------- */
.vip .wrap { display:grid; grid-template-columns:.95fr 1.05fr; gap:clamp(2rem,5vw,4.5rem); align-items:center; }
.vip-panel { border:1px solid rgba(var(--gold-rgb),.28); border-radius:var(--radius-lg); background: linear-gradient(160deg, rgba(var(--gold-rgb),.08), var(--surface)); padding:clamp(1.7rem,3vw,2.5rem); box-shadow: var(--shadow-md); }
.vip-points { list-style:none; display:grid; gap:1.25rem; }
.vip-points li { display:flex; gap:1rem; align-items:flex-start; }
.vip-points .vp-ic { width:42px; height:42px; flex-shrink:0; border-radius:11px; display:flex; align-items:center; justify-content:center; border:1px solid rgba(var(--gold-rgb),.3); background: rgba(var(--gold-rgb),.08); }
.vip-points .vp-ic svg { width:21px; height:21px; color:var(--gold); }
.vip-points strong { display:block; color:var(--text); font-size:1.02rem; margin-bottom:.15rem; }
.vip-points span { font-size:.9rem; color:var(--muted); }

/* Process ---------------------------------------------------------- */
.process-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:1.1rem; max-width:var(--maxw); margin:0 auto; counter-reset:step; }
.step { position:relative; padding:1.8rem 1.3rem; border:1px solid var(--line); border-radius:var(--radius); background:var(--surface); box-shadow: var(--shadow-sm); transition: transform .35s var(--ease), border-color .35s var(--ease); }
.step:hover { transform: translateY(-5px); border-color: rgba(var(--gold-rgb),.4); }
.step::before { counter-increment:step; content:"0" counter(step); font-size:1.5rem; font-weight:700; color:var(--gold); display:block; margin-bottom:.7rem; }
.step h3 { font-size:1.02rem; margin-bottom:.35rem; }
.step p { font-size:.86rem; color:var(--muted); line-height:1.6; }

/* Channels --------------------------------------------------------- */
.channel-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1rem; max-width:var(--maxw); margin:0 auto; }
.channel-card { display:flex; align-items:center; gap:1rem; padding:1.2rem 1.35rem; background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); box-shadow: var(--shadow-sm); transition: transform .35s var(--ease), border-color .35s var(--ease); }
.channel-card:hover { transform: translateY(-4px); border-color: rgba(var(--gold-rgb),.4); }
.channel-card .ch-ic { width:40px; height:40px; flex-shrink:0; border-radius:10px; display:flex; align-items:center; justify-content:center; border:1px solid var(--line); background: var(--surface-3); }
.channel-card .ch-ic svg { width:20px; height:20px; color:var(--text-2); }
.channel-card strong { display:block; font-size:.97rem; color:var(--text); }
.channel-card .sub { font-size:.82rem; color:var(--muted); }

/* Packages --------------------------------------------------------- */
.pricing-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1.3rem; max-width:var(--maxw); margin:0 auto; align-items:stretch; }
.price-card { background: var(--surface); border:1px solid var(--line); border-radius:var(--radius-lg); padding:2.3rem 1.9rem; display:flex; flex-direction:column; position:relative; box-shadow: var(--shadow-sm); transition: transform .4s var(--ease), border-color .4s var(--ease); }
.price-card:hover { transform: translateY(-5px); border-color: rgba(var(--gold-rgb),.4); }
.price-card.featured { border-color: rgba(var(--gold-rgb),.6); background: linear-gradient(180deg, rgba(var(--gold-rgb),.08), var(--surface)); box-shadow: var(--glow); }
.featured-badge { position:absolute; top:1.3rem; right:1.3rem; font-size:.64rem; letter-spacing:.08em; text-transform:uppercase; font-weight:700; color:var(--gold-on); background: var(--gold); padding:.3rem .7rem; border-radius:999px; }
.price-tag { font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); font-weight:600; margin-bottom:.6rem; }
.price-card h3 { font-size:1.4rem; margin-bottom:1.1rem; }
.price-amount { font-size:1.7rem; font-weight:700; color:var(--gold); margin-bottom:1.6rem; display:flex; align-items:baseline; gap:.35rem; }
.price-amount small { font-size:.82rem; font-weight:300; color:var(--muted); }
.price-card ul { list-style:none; display:grid; gap:.8rem; margin-top:auto; }
.price-card li { display:flex; gap:.7rem; font-size:.92rem; color:var(--text-2); }
.price-card li svg { width:18px; height:18px; color:var(--gold); flex-shrink:0; margin-top:3px; }

/* FAQ -------------------------------------------------------------- */
.faq-list { max-width:820px; margin:0 auto; display:grid; gap:.85rem; }
.faq-item { border:1px solid var(--line); border-radius:var(--radius); background:var(--surface); overflow:hidden; box-shadow: var(--shadow-sm); transition: border-color .3s var(--ease); }
.faq-item[aria-expanded="true"] { border-color: rgba(var(--gold-rgb),.4); }
.faq-trigger { width:100%; background:none; border:0; cursor:pointer; text-align:left; padding:1.35rem 1.6rem; display:flex; justify-content:space-between; align-items:center; gap:1rem; color:var(--text); }
.faq-trigger h3 { font-size:1.04rem; font-weight:500; }
.faq-trigger:hover h3 { color:var(--gold); }
.faq-ic { position:relative; width:16px; height:16px; flex-shrink:0; }
.faq-ic::before,.faq-ic::after { content:""; position:absolute; background:var(--gold); transition: transform .3s var(--ease), opacity .3s var(--ease); }
.faq-ic::before { top:7px; left:0; width:16px; height:2px; }
.faq-ic::after { left:7px; top:0; width:2px; height:16px; }
.faq-item[aria-expanded="true"] .faq-ic::after { transform: scaleY(0); opacity:0; }
.faq-body { max-height:0; overflow:hidden; transition: max-height .4s var(--ease); }
.faq-body p { padding:0 1.6rem 1.4rem; color:var(--text-2); font-size:.95rem; }

/* Contact ---------------------------------------------------------- */
.contact-panel { max-width:920px; margin:0 auto; text-align:center; border-radius:var(--radius-lg); border:1px solid var(--line); background: radial-gradient(circle at 50% 0%, rgba(var(--gold-rgb),.12), transparent 60%), var(--surface); padding: clamp(2.5rem,6vw,4.2rem) clamp(1.4rem,5vw,3.5rem); box-shadow: var(--shadow-md); }
.contact-panel h2 { max-width:18em; margin:0 auto 1.1rem; line-height:1.3; }
.contact-panel > p { max-width:40em; margin:0 auto 2.2rem; color:var(--muted); font-size:1.02rem; }
.contact-actions { display:flex; flex-wrap:wrap; justify-content:center; gap:1rem; }
.contact-meta { margin-top:1.8rem; font-size:.85rem; color:var(--muted); }
.contact-meta a { color:var(--gold); }

/* Footer ----------------------------------------------------------- */
.site-footer { border-top:1px solid var(--line); background: var(--bg-2); padding:3rem var(--pad); }
.footer-wrap { max-width:var(--maxw); margin:0 auto; display:flex; flex-wrap:wrap; gap:1.4rem; justify-content:space-between; align-items:center; }
.site-footer p { font-size:.85rem; color:var(--muted); }
.footer-links { display:flex; flex-wrap:wrap; gap:1.4rem; }
.footer-links a { font-size:.85rem; color:var(--muted); }
.footer-links a:hover { color:var(--gold); }

/* Reveal ----------------------------------------------------------- */
.reveal { opacity:0; transform: translateY(26px); transition: opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.in { opacity:1; transform:none; }
.reveal[data-d="1"]{ transition-delay:.07s; } .reveal[data-d="2"]{ transition-delay:.14s; } .reveal[data-d="3"]{ transition-delay:.21s; }

@media (prefers-reduced-motion: reduce) {
  *{ animation:none !important; transition:none !important; scroll-behavior:auto !important; }
  .reveal{ opacity:1; transform:none; }
}

/* Responsive ------------------------------------------------------- */
@media (max-width:1024px) {
  .hero{ grid-template-columns:1fr; } .hero-visual{ max-width:560px; }
  .trust-band .wrap, .intro .wrap, .vip .wrap{ grid-template-columns:1fr; gap:2rem; }
  .service-grid, .pricing-grid{ grid-template-columns:repeat(2,1fr); }
  .process-grid{ grid-template-columns:repeat(3,1fr); gap:1rem; }
  .channel-grid{ grid-template-columns:repeat(2,1fr); }
  .stats{ grid-template-columns:repeat(2,1fr); }
  .gallery{ grid-template-columns:repeat(3,1fr); grid-auto-rows:180px; }
  .nav{ gap:1.4rem; }
}
@media (max-width:680px) {
  .nav-toggle{ display:block; } .header-cta{ display:none; }
  .nav{ position:fixed; inset:0 0 0 auto; width:min(82%,320px); flex-direction:column; justify-content:center; gap:2rem; background:var(--bg-2); border-left:1px solid var(--line); transform:translateX(100%); transition:transform .4s var(--ease); }
  .nav.open{ transform:none; }
  .nav-toggle[aria-expanded="true"] .hamburger{ background:transparent; }
  .nav-toggle[aria-expanded="true"] .hamburger::before{ transform:translateY(7px) rotate(45deg); }
  .nav-toggle[aria-expanded="true"] .hamburger::after{ transform:translateY(-7px) rotate(-45deg); }
  .service-grid, .pricing-grid, .channel-grid, .process-grid{ grid-template-columns:1fr; }
  .stats{ grid-template-columns:1fr 1fr; }
  .gallery{ grid-template-columns:repeat(2,1fr); grid-auto-rows:150px; }
  .tile.wide{ grid-column:span 2; } .tile.tall{ grid-row:span 1; }
  .hero-actions .btn{ flex:1; }
}

/* =====================================================================
   v4 Production Dossier Theme
   A sharper image-led system: black/white/red, flat production sheets,
   fewer soft cards, stronger photographic hierarchy.
   ===================================================================== */

:root {
  --bg:        #050505;
  --bg-2:      #0b0b0b;
  --surface:   #101010;
  --surface-2: #161616;
  --surface-3: #202020;
  --line:      rgba(255,255,255,0.14);
  --line-2:    rgba(255,255,255,0.28);
  --text:      #f7f3ec;
  --text-2:    #d8d2c8;
  --muted:     #9b958b;

  --gold:      #ff3b2f;
  --gold-soft: #ff675d;
  --gold-deep: #b51e17;
  --gold-rgb:  255,59,47;
  --gold-on:   #fff7f4;

  --shadow-sm: none;
  --shadow-md: none;
  --shadow-lg: 0 42px 110px -60px rgba(0,0,0,.95);
  --glow: none;
  --hero-grad: linear-gradient(180deg, #050505 0%, #0b0b0b 55%, #050505 100%);

  --maxw: 1360px;
  --radius: 4px;
  --radius-lg: 6px;
}

[data-theme="light"] {
  --bg:        #f2f0ea;
  --bg-2:      #e7e3da;
  --surface:   #fffdf8;
  --surface-2: #f8f4ec;
  --surface-3: #e7e0d5;
  --line:      rgba(20,18,14,0.15);
  --line-2:    rgba(20,18,14,0.28);
  --text:      #11100d;
  --text-2:    #38342e;
  --muted:     #6c655b;
  --gold:      #d12b22;
  --gold-soft: #ef3d32;
  --gold-deep: #8f1f18;
  --gold-rgb:  209,43,34;
  --gold-on:   #fff7f4;
  --hero-grad: linear-gradient(180deg, #f2f0ea 0%, #fffdf8 54%, #ece7dd 100%);
}

html { scroll-padding-top: 78px; }

body {
  background: var(--bg);
  font-weight: 300;
}

body::before { background: var(--hero-grad); }

h1,h2,h3,h4 {
  letter-spacing: 0;
  text-wrap: balance;
}

h1 {
  font-size: clamp(2.65rem, 7vw, 5.65rem);
  line-height: .98;
  max-width: 10.5em;
}

h2 {
  font-size: clamp(1.85rem, 4vw, 4rem);
  line-height: 1.02;
}

p { text-wrap: pretty; }

.gold-text {
  color: var(--text);
  font-style: normal;
}

.eyebrow,
.hero-eyebrow,
.price-tag,
.tile-cap .cat {
  color: var(--gold);
  font-size: .76rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.eyebrow::before { display:none; }
.hero-eyebrow .dot { background:var(--gold); box-shadow:none; }

.section {
  padding: clamp(4.8rem,9vw,8rem) var(--pad);
  border-top: 1px solid var(--line);
}

.wrap,
.section-head,
.stats,
.service-grid,
.gallery,
.reel,
.process-grid,
.channel-grid,
.pricing-grid,
.faq-list,
.footer-wrap {
  max-width: var(--maxw);
}

.section-head {
  display:grid;
  grid-template-columns: minmax(160px,.32fr) minmax(0,.68fr);
  gap: clamp(1rem,4vw,4rem);
  align-items:end;
  text-align:left;
  margin:0 auto clamp(2.4rem,5vw,4.5rem);
}

.section-head .eyebrow { margin:0; align-self:start; }
.section-head h2 { grid-column:2; margin:0; }
.section-head > p:not(.eyebrow) {
  grid-column:2;
  max-width: 58em;
  margin-top:.2rem;
  color: var(--text-2);
}

.btn,
.header-cta,
.theme-toggle {
  border-radius: 4px;
}

.btn {
  padding: .9rem 1.25rem;
  box-shadow:none;
}

.btn-primary {
  background: var(--gold);
  color: var(--gold-on);
  box-shadow:none;
}

.btn-primary:hover {
  transform: translateY(-1px);
  box-shadow:none;
  filter:none;
  background: var(--gold-soft);
}

.btn-ghost {
  border-color: var(--line-2);
  color: var(--text);
}

.site-header {
  padding:.85rem var(--pad);
  background: color-mix(in srgb, var(--bg) 92%, transparent);
  border-bottom-color: var(--line);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.site-header.scrolled { padding:.62rem var(--pad); }

.brand-word b,
.header-cta svg,
.nav a:hover,
.nav a:hover::after {
  color: var(--gold);
}

.nav { gap: clamp(1rem,2vw,1.65rem); }
.nav a { color: var(--muted); font-size:.88rem; }
.nav a::after { background:var(--gold); }

.theme-toggle {
  background:transparent;
}

.hero {
  max-width: min(1680px, 100%);
  min-height: 92vh;
  grid-template-columns: minmax(0,.82fr) minmax(0,1.18fr);
  padding-top: clamp(7rem, 12vh, 9.5rem);
  padding-bottom: clamp(2.5rem, 5vw, 4rem);
  gap: clamp(1.5rem,4vw,5rem);
}

.hero-copy {
  max-width: 40em;
  font-size: clamp(1rem, 1.25vw, 1.12rem);
  line-height: 1.82;
}

.hero-trust {
  border-left: 3px solid var(--gold);
  padding-left: .9rem;
  max-width: 42em;
}

.hero-trust svg { display:none; }

.hero-photo {
  border-radius: 0;
  border: 0;
  box-shadow: none;
  aspect-ratio: 16/11;
}

.hero-photo::after {
  background:
    linear-gradient(180deg, transparent 50%, rgba(0,0,0,.58)),
    linear-gradient(90deg, rgba(0,0,0,.16), transparent 40%);
}

.hero-badge,
.hero-float {
  border-radius: 4px;
  background: rgba(5,5,5,.94);
  border:1px solid rgba(255,255,255,.34);
  box-shadow:none;
}

.hero-badge {
  color: #fffaf2;
}

.hero-float strong { color:var(--text); }
.hero-float { right:20px; top:20px; }
.hero-float {
  background: #050505;
  border-color: rgba(255,255,255,.55);
  box-shadow: 0 10px 30px rgba(0,0,0,.45);
}
.hero-float strong,
.hero-float span {
  color: #fffaf2;
}

.trust-band {
  background: var(--bg);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}

.trust-band .wrap {
  max-width:var(--maxw);
  padding: clamp(3rem,5vw,4.5rem) var(--pad);
  grid-template-columns: .42fr .58fr;
}

.clients-frame {
  border-radius:0;
  border:0;
  box-shadow:none;
}

.stats {
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap:0;
  border-top:1px solid var(--line);
  border-left:1px solid var(--line);
}

.stat {
  border:0;
  border-right:1px solid var(--line);
  border-bottom:1px solid var(--line);
  border-radius:0;
  background:transparent;
  padding:1.65rem 1.15rem;
}

.stat dt {
  color:var(--text);
  font-size: clamp(1.45rem,3.3vw,3rem);
}

.intro .wrap,
.vip .wrap {
  grid-template-columns: minmax(220px,.38fr) minmax(0,.62fr);
}

.intro-copy p {
  font-size: clamp(1.05rem,1.6vw,1.32rem);
  line-height:1.75;
}

.service-grid {
  grid-template-columns: 1fr;
  gap:0;
  border-top:1px solid var(--line);
}

.service-card {
  display:grid;
  grid-template-columns: 4.5rem minmax(180px,.35fr) minmax(0,.65fr);
  align-items:start;
  gap: clamp(1rem,3vw,2.5rem);
  background:transparent;
  border:0;
  border-bottom:1px solid var(--line);
  border-radius:0;
  padding: clamp(1.35rem,3vw,2.4rem) 0;
  box-shadow:none;
}

.service-card::before,
.service-icon {
  display:none;
}

.service-card:hover {
  transform:none;
  border-color:var(--line);
  box-shadow:none;
}

.service-num {
  position:static;
  color:var(--gold);
  font-weight:700;
  font-size:.92rem;
}

.service-card h3 {
  font-size: clamp(1.25rem,2vw,1.85rem);
  margin:0;
}

.service-card p {
  color:var(--text-2);
  font-size: clamp(.98rem,1.25vw,1.08rem);
  line-height:1.72;
}

.gallery {
  grid-template-columns: repeat(12, 1fr);
  grid-auto-rows: clamp(120px, 15vw, 220px);
  gap:.55rem;
}

.tile {
  border-radius:0;
  border:0;
  box-shadow:none;
}

.tile.wide { grid-column: span 5; }
.tile.tall { grid-row: span 2; }
.tile:not(.wide) { grid-column: span 3; }

.tile::after { background: linear-gradient(180deg, transparent 42%, rgba(0,0,0,.82)); }
.tile-cap { padding:.85rem; }
.tile-cap .cat { color:var(--gold-soft); }

.reel-frame {
  border-radius:0;
  border:0;
  box-shadow:none;
}

.reel-play span {
  border-radius:4px;
  background:var(--gold);
  box-shadow:none;
}

.vip-panel {
  border-radius:0;
  background:transparent;
  border:0;
  border-top:1px solid var(--line);
  box-shadow:none;
  padding:0;
}

.vip-points {
  gap:0;
}

.vip-points li {
  border-bottom:1px solid var(--line);
  padding:1.2rem 0;
}

.vip-points .vp-ic {
  border-radius:4px;
  border-color:var(--line-2);
  background:transparent;
}

.vip-points .vp-ic svg,
.price-card li svg {
  color:var(--gold);
}

.process-grid {
  grid-template-columns: repeat(5,1fr);
  gap:0;
  border-top:1px solid var(--line);
  border-left:1px solid var(--line);
}

.step {
  border:0;
  border-right:1px solid var(--line);
  border-bottom:1px solid var(--line);
  border-radius:0;
  background:transparent;
  box-shadow:none;
}

.step:hover {
  transform:none;
  border-color:var(--line);
}

.step::before {
  color:var(--gold);
}

.channel-grid {
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap:0;
  border-top:1px solid var(--line);
  border-left:1px solid var(--line);
}

.channel-card {
  border:0;
  border-right:1px solid var(--line);
  border-bottom:1px solid var(--line);
  border-radius:0;
  background:transparent;
  box-shadow:none;
}

.channel-card:hover {
  transform:none;
  border-color:var(--line);
  background:var(--surface);
}

.channel-card .ch-ic {
  border-radius:4px;
  background:transparent;
}

.pricing-grid {
  gap:0;
  border-top:1px solid var(--line);
  border-left:1px solid var(--line);
}

.price-card,
.price-card.featured {
  border:0;
  border-right:1px solid var(--line);
  border-bottom:1px solid var(--line);
  border-radius:0;
  background:transparent;
  box-shadow:none;
}

.price-card:hover {
  transform:none;
  border-color:var(--line);
}

.featured-badge {
  border-radius:4px;
  background:var(--gold);
}

.price-amount {
  color:var(--text);
}

.faq-list {
  max-width: 980px;
  border-top:1px solid var(--line);
}

.faq-item {
  border:0;
  border-bottom:1px solid var(--line);
  border-radius:0;
  background:transparent;
  box-shadow:none;
}

.faq-item[aria-expanded="true"] {
  border-color:var(--line);
}

.faq-trigger {
  padding:1.25rem 0;
}

.faq-body p {
  padding:0 0 1.35rem;
}

.contact-panel {
  border-radius:0;
  border:1px solid var(--line);
  background:var(--surface);
  box-shadow:none;
}

.site-footer {
  background:var(--bg);
}

@media (max-width:1024px) {
  .hero {
    min-height:auto;
    grid-template-columns:1fr;
  }

  .section-head,
  .intro .wrap,
  .vip .wrap,
  .trust-band .wrap {
    grid-template-columns:1fr;
  }

  .section-head h2,
  .section-head > p:not(.eyebrow) {
    grid-column:1;
  }

  .service-card {
    grid-template-columns: 3rem 1fr;
  }

  .service-card p {
    grid-column:2;
  }

  .process-grid,
  .pricing-grid {
    grid-template-columns: repeat(2,1fr);
  }

  .gallery {
    grid-template-columns: repeat(6, 1fr);
  }

  .tile,
  .tile:not(.wide),
  .tile.wide {
    grid-column: span 3;
  }
}

@media (max-width:680px) {
  .section { padding-left:1.05rem; padding-right:1.05rem; }
  .hero { padding-left:1.05rem; padding-right:1.05rem; }
  .trust-band .wrap { padding-left:1.05rem; padding-right:1.05rem; }

  h1 { font-size: clamp(2.25rem, 13vw, 3.6rem); }
  h2 { font-size: clamp(1.85rem, 10vw, 2.8rem); }

  .service-card,
  .process-grid,
  .pricing-grid,
  .stats {
    grid-template-columns:1fr;
  }

  .service-card {
    gap:.45rem;
  }

  .service-card p {
    grid-column:1;
  }

  .service-num {
    margin-bottom:.2rem;
  }

  .gallery {
    grid-template-columns: repeat(2, 1fr);
    grid-auto-rows:150px;
  }

  .tile,
  .tile:not(.wide),
  .tile.wide {
    grid-column:span 1;
  }

  .tile.tall {
    grid-row:span 2;
  }
}

/* ===== Conversion add-ons (2026-07) =========================== */

.packages-note {
  margin: 1.6rem auto 0;
  max-width: 760px;
  text-align: center;
  font-size: .92rem;
  color: var(--muted);
  border-top: 1px solid var(--line);
  padding-top: 1.2rem;
}

.reply-promise {
  margin-top: 1rem;
  font-size: .88rem;
  color: var(--gold);
  letter-spacing: .02em;
}

.mobile-cta {
  display: none;
  position: fixed;
  left: 0; right: 0; bottom: 0;
  z-index: 60;
  padding: .7rem var(--pad) calc(.7rem + env(safe-area-inset-bottom));
  background: rgba(12, 11, 14, .88);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-top: 1px solid var(--line-2);
}
[data-theme="light"] .mobile-cta { background: rgba(246, 242, 234, .9); }
.mobile-cta .btn {
  width: 100%;
  justify-content: center;
  display: inline-flex;
  align-items: center;
  gap: .5rem;
}

@media (max-width: 720px) {
  .mobile-cta { display: block; }
  body { padding-bottom: 76px; }
}
