/* =========================================================
   Viva Grafix — site stylesheet
   Design system: "Voltage Editorial" (per brand book §08)
   ========================================================= */

:root{
  --ink:        #0B1020;
  --ink-2:      #161B2E;
  --paper:      #F6F4EE;
  --paper-2:    #EFEBE0;
  --line:       #1f2540;
  --line-soft:  rgba(11,16,32,0.10);
  --mute:       #5B6075;
  --blue:       #1A4BFF;
  --blue-2:     #2E6BFF;
  --indigo:     #4B2BCB;
  --magenta:    #C3268A;
  --hot:        #FF3D7F;
  --lime:       #D8F26B;
  --amber:      #FFB547;

  --grad: linear-gradient(110deg, #1A4BFF 0%, #4B2BCB 45%, #C3268A 100%);
  --grad-soft: linear-gradient(110deg, rgba(26,75,255,.12), rgba(195,38,138,.12));

  --r-s: 10px; --r-m: 18px; --r-l: 28px;
  --shadow-1: 0 1px 0 rgba(11,16,32,.06), 0 8px 24px -16px rgba(11,16,32,.18);
  --shadow-2: 0 30px 60px -30px rgba(11,16,32,.35);

  --pad: 56px;
}
@media (max-width: 720px){ :root{ --pad: 24px; } }

*{ box-sizing:border-box; }
html{ scroll-behavior: smooth; }
html,body{ margin:0; padding:0; }
body{
  background: var(--paper);
  color: var(--ink);
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
  font-size: 16px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
::selection{ background: var(--ink); color: var(--paper); }

/* ---------- typography ---------- */
h1,h2,h3,h4{ font-family: 'Space Grotesk', system-ui, sans-serif; font-weight: 700; letter-spacing: -0.02em; margin:0; color: var(--ink); }
h1{ font-size: clamp(56px, 9vw, 144px); line-height: 0.92; letter-spacing: -0.04em; }
h2{ font-size: clamp(36px, 5vw, 76px); line-height: 0.96; letter-spacing: -0.03em; }
h3{ font-size: clamp(22px, 2.4vw, 32px); line-height: 1.1; }
h4{ font-size: 18px; line-height: 1.3; letter-spacing: -0.01em; }
p{ margin: 0 0 1em; max-width: 64ch; }
a{ color: inherit; text-decoration: none; }
a.underline{ background-image: linear-gradient(currentColor, currentColor); background-size: 100% 1px; background-repeat: no-repeat; background-position: 0 100%; }

.mono{ font-family:'JetBrains Mono', ui-monospace, monospace; font-size:11.5px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--mute); }
.tag{ display:inline-flex; align-items:center; gap:.5em; padding: 4px 10px; border:1px solid var(--line-soft); border-radius: 999px; font-family:'JetBrains Mono', monospace; font-size:11px; letter-spacing:.1em; text-transform: uppercase; color: var(--ink); background: rgba(255,255,255,.6); }
.tag .dot{ width:6px; height:6px; border-radius:50%; background: var(--grad); }
.lead{ font-size: clamp(18px, 1.5vw, 22px); line-height: 1.5; max-width: 56ch; color: var(--ink-2); }
.muted{ color: var(--mute); }

/* ---------- layout ---------- */
.page{ max-width: 1440px; margin: 0 auto; padding: 0 var(--pad); }
section{ padding: clamp(72px, 10vw, 120px) 0; border-top: 1px solid var(--line-soft); position: relative; }
section.flush-top{ border-top: 0; padding-top: 0; }

.grid{ display:grid; gap: 24px; }
.g-2{ grid-template-columns: repeat(2, minmax(0,1fr)); }
.g-3{ grid-template-columns: repeat(3, minmax(0,1fr)); }
.g-4{ grid-template-columns: repeat(4, minmax(0,1fr)); }
.g-12{ grid-template-columns: repeat(12, minmax(0,1fr)); gap: 24px; }
@media (max-width: 900px){ .g-2,.g-3,.g-4{ grid-template-columns: 1fr; } .g-12{ grid-template-columns: repeat(6,1fr); } }
.col-span-7{ grid-column: span 7; } .col-span-5{ grid-column: span 5; } .col-span-6{ grid-column: span 6; }
.col-span-8{ grid-column: span 8; } .col-span-4{ grid-column: span 4; }
@media (max-width: 900px){ .col-span-7,.col-span-5,.col-span-6,.col-span-8,.col-span-4{ grid-column: span 6; } }

.section-head{ display:flex; align-items:flex-end; justify-content:space-between; gap: 32px; margin-bottom: 56px; flex-wrap: wrap; }
.section-head .meta{ font-family:'JetBrains Mono', monospace; font-size: 11px; color: var(--mute); text-align: right; max-width: 280px; }

.stack-8{ display:flex; flex-direction:column; gap: 8px; }
.stack-12{ display:flex; flex-direction:column; gap: 12px; }
.stack-20{ display:flex; flex-direction:column; gap: 20px; }
.stack-32{ display:flex; flex-direction:column; gap: 32px; }
.row-12{ display:flex; gap: 12px; flex-wrap:wrap; }
.row-20{ display:flex; gap: 20px; flex-wrap:wrap; align-items:center; }
hr.soft{ border:0; border-top: 1px solid var(--line-soft); margin: 32px 0; }

/* ---------- card ---------- */
.card{ background: #fff; border-radius: var(--r-m); border: 1px solid var(--line-soft); padding: 28px; box-shadow: var(--shadow-1); }
.card.dark{ background: var(--ink); color: var(--paper); border-color: rgba(255,255,255,.08); }
.card.dark h3, .card.dark h4{ color: #fff; }
.card.dark .mono{ color: rgba(255,255,255,.6); }
.card.tinted{ background: var(--paper-2); }

/* ---------- buttons ---------- */
.btn{ display:inline-flex; align-items:center; gap: 8px; padding: 14px 22px; border-radius: 999px; font-weight: 500; font-size: 14.5px; text-decoration:none; transition: transform .15s ease, box-shadow .2s ease; cursor: pointer; border: 0; font-family: inherit; }
.btn:hover{ transform: translateY(-1px); }
.btn:focus-visible{ outline: 2px solid var(--blue); outline-offset: 3px; }
.btn-primary{ background: var(--ink); color:#fff; }
.btn-primary .arrow{ width: 18px; height: 18px; background: var(--grad); border-radius:50%; display:inline-block; }
.btn-ghost{ background: transparent; border:1px solid var(--ink); color: var(--ink); padding: 13px 21px; }
.btn-grad{ background: var(--grad); color:#fff; }
.btn-lime{ background: var(--lime); color: var(--ink); }

/* ---------- nav ---------- */
.site-nav-wrap{ position: sticky; top: 0; z-index: 60; padding: 18px var(--pad); pointer-events: none; }
.site-nav-wrap.scrolled{ padding-top: 16px; }
.site-nav{
  display:flex; align-items:center; justify-content:space-between; gap: 24px;
  padding: 10px 18px 10px 22px;
  border:1px solid var(--line-soft); border-radius: 100px;
  background: rgba(246,244,238,0.78); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
  max-width: 1180px; margin: 0 auto;
  pointer-events: auto;
  transition: box-shadow .2s ease, background .2s ease;
}
.site-nav-wrap.scrolled .site-nav{ background: rgba(246,244,238,0.92); box-shadow: var(--shadow-1); }
.site-nav .brand{ display:flex; align-items:center; gap: 10px; font-family:'Space Grotesk', sans-serif; font-weight: 700; font-size: 16px; letter-spacing: -0.02em; color: var(--ink); }
.site-nav .brand .mark{ width: 22px; height: 22px; border-radius: 6px; background: var(--grad); display:block; }
.brand-logo{ height: 40px; width: auto; display: block; image-rendering: auto; }
@media (max-width: 540px){ .brand-logo{ height: 32px; } }
.site-nav ul{ list-style:none; display:flex; gap: 28px; padding:0; margin:0; font-size: 14px; font-weight: 500; }
.site-nav ul a{ color: var(--ink); padding: 6px 2px; position: relative; }
.site-nav ul a[aria-current="page"]::after,
.site-nav ul a:hover::after{ content:''; position:absolute; left:0; right:0; bottom: -2px; height: 2px; background: var(--grad); border-radius: 2px; }
.site-nav .cta{ background: var(--ink); color:#fff; padding: 9px 14px; border-radius: 999px; font-size: 13px; font-weight: 500; }
.site-nav .cta:hover{ transform: translateY(-1px); transition: transform .15s ease; }

.menu-toggle{ display:none; background:transparent; border:0; padding: 6px; cursor: pointer; color: var(--ink); }
.menu-toggle svg{ width: 24px; height: 24px; }

/* language toggle */
.lang-switch{ display:flex; align-items:center; gap: 4px; font-family:'JetBrains Mono', monospace; font-size: 11px; letter-spacing: .12em; text-transform: uppercase; padding-left: 14px; margin-left: 4px; border-left: 1px solid var(--line-soft); }
.lang-switch a{ color: var(--mute); padding: 4px 6px; border-radius: 6px; transition: color .15s ease, background .15s ease; }
.lang-switch a[aria-current="true"]{ color: var(--ink); font-weight: 600; }
.lang-switch a:hover{ color: var(--ink); }
.lang-switch .sep{ color: var(--line-soft); }
@media (max-width: 820px){ .site-nav .lang-switch{ display: none; } }

.mobile-lang{ margin-top: 20px; padding-top: 20px; border-top: 1px solid var(--line-soft); display:flex; gap: 16px; align-items: center; }
.mobile-lang .lbl{ font-family:'JetBrains Mono', monospace; font-size: 11px; letter-spacing: .12em; text-transform: uppercase; color: var(--mute); }
.mobile-lang a{ font-family:'Space Grotesk', sans-serif; font-weight: 600; font-size: 18px; padding: 4px 10px; border-radius: 6px; color: var(--mute); }
.mobile-lang a[aria-current="true"]{ color: var(--ink); background: rgba(255,255,255,.5); }

@media (max-width: 820px){
  .site-nav ul, .site-nav .cta-desktop{ display: none; }
  .menu-toggle{ display:inline-flex; }
}

/* mobile fullscreen menu */
.mobile-menu{
  position: fixed; inset: 0; background: var(--paper); z-index: 70;
  display: none; flex-direction: column; padding: 24px var(--pad);
}
.mobile-menu.open{ display: flex; }
.mobile-menu .top{ display:flex; justify-content:space-between; align-items:center; }
.mobile-menu nav{ margin-top: auto; margin-bottom: auto; }
.mobile-menu nav ul{ list-style: none; padding: 0; margin: 0; display:flex; flex-direction: column; gap: 6px; }
.mobile-menu nav a{ font-family:'Space Grotesk', sans-serif; font-weight: 600; font-size: clamp(36px, 8vw, 56px); letter-spacing: -0.03em; line-height: 1.05; color: var(--ink); display:block; padding: 6px 0; }
.mobile-menu nav a .grad{ background: var(--grad); -webkit-background-clip:text; background-clip:text; color: transparent; }
.mobile-menu .foot{ display:flex; justify-content:space-between; align-items:end; gap: 24px; padding-top: 24px; border-top: 1px solid var(--line-soft); }

/* ---------- hero ---------- */
.hero{ padding-top: 24px; padding-bottom: clamp(56px, 8vw, 96px); position: relative; overflow: hidden; }
.hero h1{ max-width: 16ch; }
.hero h1 .gx{ background: var(--grad); -webkit-background-clip:text; background-clip:text; color: transparent; }
.hero h1 .it{ font-style: italic; font-weight: 500; color: var(--mute); }
.hero .sub{ display:grid; grid-template-columns: minmax(0, 1fr) auto; gap: 32px 48px; margin-top: 36px; align-items: end; }
@media (max-width: 760px){ .hero .sub{ grid-template-columns: 1fr; } }
.hero .sub p{ font-size: clamp(16px, 1.5vw, 19px); color: var(--ink-2); max-width: 44ch; margin:0; }
.hero .actions{ display:flex; gap: 10px; flex-wrap: wrap; }
.hero-art{
  position: absolute; top: 0; right: -120px; width: clamp(280px, 38vw, 520px);
  aspect-ratio: 1; border-radius: 50%;
  background: var(--grad);
  filter: blur(2px); opacity: 0.92;
  z-index: -1;
  animation: drift 16s ease-in-out infinite alternate;
}
.hero-art::after{ content:''; position:absolute; inset: 8%; border-radius: 50%; background: radial-gradient(120% 80% at 30% 20%, rgba(255,255,255,.25), transparent 60%); }
@keyframes drift {
  0%   { transform: translate(0,0) scale(1); }
  100% { transform: translate(-30px, 30px) scale(1.04); }
}
@media (prefers-reduced-motion: reduce){
  .hero-art{ animation: none; }
  html{ scroll-behavior: auto; }
}

/* ---------- featured strip ---------- */
.strip{ display:grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
@media (max-width: 900px){ .strip{ grid-template-columns: repeat(2,1fr); } }
.strip .item{ aspect-ratio: 4/3; border-radius: 14px; background:#fff; border:1px solid var(--line-soft); position:relative; overflow:hidden; transition: transform .25s ease; }
.strip .item:hover{ transform: translateY(-3px); }
.strip .item .label{ position:absolute; left: 14px; bottom: 12px; font-family:'JetBrains Mono', monospace; font-size: 10.5px; letter-spacing: .1em; text-transform: uppercase; color: var(--ink); z-index: 2; }
.strip .item.a{ background: var(--ink); }
.strip .item.a .label{ color:#fff; }
.strip .item.a::before{ content:''; position:absolute; inset: 22%; border-radius: 50%; background: var(--grad); filter: blur(20px); }
.strip .item.b{ background: var(--lime); }
.strip .item.c{ background: var(--paper); background-image: repeating-linear-gradient(-45deg, var(--ink) 0 1px, transparent 1px 10px); }
.strip .item.d{ background: var(--grad); }
.strip .item.d .label{ color:#fff; }

/* ---------- services strip on home ---------- */
.svc-grid{ display:grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
@media (max-width: 900px){ .svc-grid{ grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px){ .svc-grid{ grid-template-columns: 1fr; } }
.svc{ background: #fff; border:1px solid var(--line-soft); border-radius: var(--r-m); padding: 24px; transition: transform .25s ease, border-color .25s ease; }
.svc:hover{ transform: translateY(-3px); border-color: rgba(11,16,32,.2); }
.svc .num{ font-family:'JetBrains Mono', monospace; font-size: 11px; letter-spacing: .12em; color: var(--mute); }
.svc h4{ font-family:'Space Grotesk'; font-size: 22px; margin: 10px 0 10px; }
.svc p{ font-size: 14.5px; color: var(--ink-2); margin: 0; }

/* ---------- pillars / why ---------- */
.pillar{ display:flex; flex-direction:column; gap:8px; padding: 24px; border-radius: var(--r-m); background:#fff; border:1px solid var(--line-soft); }
.pillar .num{ font-family:'JetBrains Mono', monospace; font-size: 11px; color: var(--mute); letter-spacing: .15em; }
.pillar h4{ font-family:'Space Grotesk'; font-size: 22px; }
.pillar p{ margin:0; font-size: 14.5px; color: var(--ink-2); }
.stat{ display:flex; flex-direction:column; gap: 4px; padding: 22px; border-radius: var(--r-m); background: var(--paper-2); border:1px solid var(--line-soft); }
.stat .num{ font-family:'Space Grotesk'; font-weight: 700; font-size: clamp(40px, 5vw, 64px); line-height: 1; letter-spacing: -0.03em; }
.stat .num .grad{ background: var(--grad); -webkit-background-clip:text; background-clip:text; color: transparent; }
.stat .lbl{ font-family:'JetBrains Mono', monospace; font-size: 11px; letter-spacing: .12em; text-transform: uppercase; color: var(--mute); margin-top: 4px; }

/* ---------- testimonials ---------- */
.quote-box{ position: relative; background: var(--ink); color: var(--paper); border-radius: var(--r-l); padding: clamp(32px, 4vw, 56px); overflow: hidden; }
.quote-box::before{ content:''; position:absolute; inset: 0; background: var(--grad); opacity: 0.18; mix-blend-mode: screen; }
.quote-box .q{ font-family:'Space Grotesk'; font-size: clamp(22px, 2.6vw, 36px); line-height: 1.15; letter-spacing: -0.02em; max-width: 28ch; position:relative; }
.quote-box .attr{ position:relative; margin-top: 24px; font-family:'JetBrains Mono', monospace; font-size: 12px; letter-spacing:.12em; text-transform: uppercase; color: rgba(255,255,255,.7); }

/* ---------- CTA section (full-bleed dark) ---------- */
.cta-section{ background: var(--ink); color: var(--paper); border-radius: 0; padding: clamp(72px, 10vw, 128px) var(--pad); position: relative; overflow: hidden; }
.cta-section::before{ content:''; position:absolute; right: -160px; top: -160px; width: 520px; height: 520px; border-radius: 50%; background: var(--grad); filter: blur(30px); opacity: .55; }
.cta-section .inner{ max-width: 1440px; margin: 0 auto; position: relative; }
.cta-section h2{ color:#fff; max-width: 14ch; }
.cta-section h2 .grad{ background: var(--grad); -webkit-background-clip:text; background-clip:text; color: transparent; }
.cta-section p{ color: rgba(255,255,255,.85); max-width: 52ch; margin-top: 18px; font-size: clamp(16px, 1.4vw, 19px); }
.cta-form{ display:flex; gap: 8px; margin-top: 32px; max-width: 520px; flex-wrap: wrap; }
.cta-form input{
  flex: 1 1 240px; min-width: 0; padding: 16px 18px;
  font: 500 15px/1.4 'Inter', sans-serif; color: #fff;
  background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.18);
  border-radius: 999px;
}
.cta-form input::placeholder{ color: rgba(255,255,255,.5); }
.cta-form input:focus{ outline:0; border-color: var(--lime); background: rgba(255,255,255,.10); }
.cta-form .btn{ padding: 16px 22px; }

/* ---------- footer ---------- */
.site-foot{ padding: 80px 0 48px; border-top: 1px solid var(--line-soft); margin-top: 0; }
.site-foot .foot-grid{ display:grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 32px; }
@media (max-width: 900px){ .site-foot .foot-grid{ grid-template-columns: 1fr 1fr; } }
@media (max-width: 540px){ .site-foot .foot-grid{ grid-template-columns: 1fr; } }
.site-foot h3{ font-size: clamp(40px, 5vw, 64px); line-height: 0.95; letter-spacing: -0.03em; max-width: 12ch; }
.site-foot h3 .grad{ background: var(--grad); -webkit-background-clip:text; background-clip:text; color: transparent; }
.site-foot ul{ list-style: none; padding: 0; margin: 0; display:flex; flex-direction: column; gap: 8px; }
.site-foot ul li a{ font-size: 14.5px; color: var(--ink); }
.site-foot ul li a:hover{ color: var(--magenta); }
.site-foot .colophon{ display:flex; justify-content:space-between; align-items: center; gap: 24px; flex-wrap: wrap; padding-top: 56px; margin-top: 56px; border-top: 1px solid var(--line-soft); font-family:'JetBrains Mono', monospace; font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--mute); }

/* ---------- forms ---------- */
.form-mock{ background:#fff; border:1px solid var(--line-soft); border-radius: var(--r-m); padding: clamp(24px, 3vw, 36px); max-width: 640px; }
.field{ margin-bottom: 22px; }
.field label{ display:block; font-family:'JetBrains Mono', monospace; font-size: 11px; letter-spacing:.12em; text-transform: uppercase; color: var(--mute); margin-bottom: 8px; }
.field input, .field textarea, .field select{ width:100%; border:0; border-bottom: 1.5px solid var(--ink); padding: 10px 0; font-family: inherit; font-size: 16px; background:transparent; color: var(--ink); transition: border-color .2s ease; }
.field input:focus, .field textarea:focus, .field select:focus{ outline:0; border-color: var(--magenta); }
.field input::placeholder, .field textarea::placeholder{ color: var(--mute); }
.field textarea{ min-height: 120px; resize: vertical; }
.chip-row{ display:flex; flex-wrap: wrap; gap: 8px; }
.chip{ font-family:'JetBrains Mono', monospace; font-size: 11px; letter-spacing:.1em; text-transform: uppercase; padding: 8px 14px; border-radius: 999px; border:1px solid var(--line-soft); background: rgba(255,255,255,.6); cursor: pointer; user-select: none; transition: background .15s ease, color .15s ease, border-color .15s ease; }
.chip:hover{ border-color: rgba(11,16,32,.28); }
.chip.active{ background: var(--ink); color:#fff; border-color: var(--ink); }
.chip input{ position:absolute; opacity: 0; pointer-events: none; }

/* ---------- portfolio cards ---------- */
.work-grid{ display:grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
@media (max-width: 900px){ .work-grid{ grid-template-columns:repeat(2,1fr); gap: 16px; } }
@media (max-width: 600px){ .work-grid{ grid-template-columns: 1fr; } }
.work{ border-radius: var(--r-m); overflow:hidden; background:#fff; border:1px solid var(--line-soft); display:flex; flex-direction:column; transition: transform .25s ease; }
.work:hover{ transform: translateY(-4px); }
.work .cover{ aspect-ratio: 4/3; display:flex; align-items:center; justify-content:center; padding:0; min-height: 0; position: relative; overflow: hidden; }
.work .cover.a{ background: var(--grad); }
.work .cover.b{ background: var(--ink); }
.work .cover.b::before{ content:''; position:absolute; inset: 14%; border-radius: 50%; background: var(--lime); filter: blur(8px); opacity:.85; }
.work .cover.c{ background: var(--lime); }
.work .cover.c::after{ content:''; position:absolute; left:14%; top:14%; width:40%; height:40%; background: var(--ink); border-radius: 4px; transform: rotate(-8deg); }
.work .cover.d{ background: var(--paper-2); background-image: repeating-linear-gradient(45deg, var(--ink) 0 1px, transparent 1px 8px); }
.work .cover.e{ background: var(--magenta); }
.work .cover.e::before{ content:''; position:absolute; inset: 22%; background: var(--lime); border-radius: 50%; }
.work .cover.f{ background: var(--ink-2); }
.work .cover.f::after{ content:'VG'; position:absolute; font-family:'Space Grotesk'; font-weight:700; font-size: 96px; letter-spacing:-0.05em; background: var(--grad); -webkit-background-clip:text; background-clip:text; color: transparent; }
.work .cover.g{ background: var(--paper); }
.work .cover.g::before{ content:''; position:absolute; left: 12%; right: 12%; top: 18%; bottom: 18%; background: var(--ink); border-radius: 4px; }
.work .cover.g::after{ content:''; position:absolute; left: 22%; top: 32%; width: 56%; height: 36%; background: var(--grad); border-radius: 50%; filter: blur(6px); opacity:.9; }
.work .cover.h{ background: var(--blue); }
.work .cover.h::after{ content:''; position:absolute; inset: 24%; border-radius: 50%; border: 4px solid var(--lime); }
.work .meta{ padding: 18px 22px; display:flex; flex-direction:column; gap: 4px; }
.work .cat{ font-family:'JetBrains Mono', monospace; font-size: 10.5px; letter-spacing: .12em; text-transform: uppercase; color: var(--mute); }
.work .ttl{ font-family:'Space Grotesk'; font-weight: 600; font-size: 18px; letter-spacing: -0.01em; }
.work .yr{ font-size: 12px; color: var(--mute); margin-top: 4px; }

/* portfolio filters */
.filters{ display:flex; gap: 8px; flex-wrap: wrap; margin-bottom: 32px; }

/* services packages */
.pkg{ background:#fff; border:1px solid var(--line-soft); border-radius: var(--r-l); padding: clamp(28px, 3vw, 40px); display:flex; flex-direction:column; gap: 14px; position: relative; overflow: hidden; }
.pkg.featured{ background: var(--ink); color: var(--paper); border-color: rgba(255,255,255,.08); }
.pkg.featured h3{ color: #fff; }
.pkg.featured .price{ color: #fff; }
.pkg.featured .label{ color: rgba(255,255,255,.6); }
.pkg.featured::before{ content:''; position:absolute; right:-100px; top:-100px; width: 280px; height: 280px; border-radius: 50%; background: var(--grad); filter: blur(20px); opacity:.45; }
.pkg .label{ font-family:'JetBrains Mono', monospace; font-size: 11px; letter-spacing: .12em; text-transform: uppercase; color: var(--mute); position: relative; }
.pkg h3{ font-size: clamp(26px, 2.6vw, 34px); position: relative; }
.pkg .price{ font-family:'Space Grotesk'; font-size: clamp(22px, 2.2vw, 28px); font-weight: 600; letter-spacing: -0.02em; position: relative; }
.pkg .price small{ font-family:'JetBrains Mono', monospace; font-size: 11px; letter-spacing: .12em; text-transform: uppercase; color: var(--mute); margin-left: 8px; font-weight: 400; }
.pkg.featured .price small{ color: rgba(255,255,255,.6); }
.pkg .price .was{ color: var(--mute); text-decoration: line-through; font-weight: 400; font-size: 0.6em; margin-right: 10px; vertical-align: 2px; }
.pkg.featured .price .was{ color: rgba(255,255,255,.5); }
.promo-tag{ display:inline-flex; align-items:center; gap: 6px; background: var(--lime); color: var(--ink); padding: 4px 10px; border-radius: 999px; font-family:'JetBrains Mono', monospace; font-size: 10px; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; margin-left: 10px; vertical-align: 2px; }
.pkg.featured .promo-tag{ background: var(--lime); color: var(--ink); }

.promo-banner{ background: var(--ink); color: var(--paper); border-radius: var(--r-l); padding: 22px 28px; display:flex; align-items:center; justify-content: space-between; gap: 24px; flex-wrap: wrap; position: relative; overflow: hidden; margin-bottom: 40px; }
.promo-banner::before{ content:''; position: absolute; left:-80px; top: 50%; transform: translateY(-50%); width: 220px; height: 220px; border-radius: 50%; background: var(--grad); filter: blur(40px); opacity: .55; }
.promo-banner .left{ position: relative; display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.promo-banner .badge{ background: var(--lime); color: var(--ink); padding: 6px 12px; border-radius: 999px; font-family:'JetBrains Mono', monospace; font-size: 10.5px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; }
.promo-banner .msg{ font-family:'Space Grotesk', sans-serif; font-weight: 600; font-size: clamp(15px, 1.4vw, 18px); letter-spacing: -0.01em; }
.promo-banner .right{ position: relative; font-family:'JetBrains Mono', monospace; font-size: 11px; letter-spacing: .12em; text-transform: uppercase; color: rgba(255,255,255,.65); }
.pkg ul{ list-style: none; padding: 0; margin: 8px 0 0; display:flex; flex-direction:column; gap: 8px; position: relative; }
.pkg li{ font-size: 14.5px; padding-left: 22px; position: relative; }
.pkg li::before{ content: ''; position: absolute; left: 0; top: 8px; width: 12px; height: 2px; background: var(--grad); }
.pkg.featured li{ color: rgba(255,255,255,.92); }
.pkg .pkg-cta{ margin-top: 16px; align-self: flex-start; position: relative; }

/* price table (print on demand) */
.price-table-wrap{ overflow-x: auto; margin-top: 14px; }
.price-table{ width: 100%; border-collapse: collapse; min-width: 460px; }
.price-table caption{ caption-side: top; text-align: left; padding-bottom: 12px; font-family:'JetBrains Mono', monospace; font-size: 10.5px; letter-spacing: .12em; text-transform: uppercase; color: var(--mute); }
.price-table th, .price-table td{ padding: 12px 12px; border-bottom: 1px solid var(--line-soft); }
.price-table thead th{ font-family:'JetBrains Mono', monospace; font-size: 10.5px; letter-spacing: .12em; text-transform: uppercase; color: var(--mute); font-weight: 500; text-align: right; }
.price-table thead th:first-child{ text-align: left; }
.price-table tbody th{ font-family:'Space Grotesk', sans-serif; font-weight: 500; font-size: 14.5px; color: var(--ink); text-align: left; letter-spacing: -0.005em; }
.price-table tbody td{ font-family:'JetBrains Mono', monospace; font-size: 13.5px; color: var(--ink); text-align: right; }
.price-table tbody tr:last-child th, .price-table tbody tr:last-child td{ border-bottom: 0; }
.price-table tbody tr:hover{ background: var(--paper-2); }

.addons{ display:grid; grid-template-columns: repeat(2, 1fr); gap: 10px 24px; margin-top: 16px; padding-top: 16px; border-top: 1px dashed var(--line-soft); font-size: 13.5px; }
@media (max-width: 540px){ .addons{ grid-template-columns: 1fr; } }
.addons div{ display:flex; align-items:baseline; gap: 10px; }
.addons .lbl{ font-family:'JetBrains Mono', monospace; font-size: 10.5px; letter-spacing: .12em; text-transform: uppercase; color: var(--mute); flex-shrink: 0; }
.addons .val{ color: var(--ink); font-family:'JetBrains Mono', monospace; font-size: 13px; }

.on-request{ margin-top: 16px; padding: 12px 16px; background: var(--paper-2); border-radius: var(--r-s); display:flex; align-items:baseline; gap: 12px; flex-wrap: wrap; font-size: 13.5px; }
.on-request .badge{ font-family:'JetBrains Mono', monospace; font-size: 10.5px; letter-spacing: .12em; text-transform: uppercase; color: var(--ink); background: var(--lime); padding: 3px 8px; border-radius: 999px; flex-shrink: 0; }
.on-request strong{ font-family:'JetBrains Mono', monospace; font-weight: 600; }

.commission-list{ list-style: none; padding: 0; margin: 14px 0 0; display:grid; grid-template-columns: repeat(2,1fr); gap: 8px 16px; }
@media (max-width: 540px){ .commission-list{ grid-template-columns: 1fr; } }
.commission-list li{ font-size: 14px; color: var(--ink-2); padding-left: 18px; position: relative; }
.commission-list li::before{ content: ''; position: absolute; left: 0; top: 9px; width: 10px; height: 2px; background: var(--grad); }

/* package grid — 4 across, 2x2 on tablet, 1 col on phones */
.pkg-grid{ display:grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 18px; }
@media (max-width: 1100px){ .pkg-grid{ grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px){ .pkg-grid{ grid-template-columns: 1fr; } }

/* process steps */
.process{ display:grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
@media (max-width: 900px){ .process{ grid-template-columns: repeat(2,1fr); } }
@media (max-width: 540px){ .process{ grid-template-columns: 1fr; } }
.step{ background: var(--paper-2); border:1px solid var(--line-soft); border-radius: var(--r-m); padding: 24px; }
.step .step-num{ font-family:'Space Grotesk'; font-weight: 700; font-size: 56px; line-height: 0.9; letter-spacing: -0.03em; background: var(--grad); -webkit-background-clip: text; background-clip: text; color: transparent; }
.step h4{ margin: 16px 0 6px; }
.step p{ font-size: 14px; color: var(--ink-2); margin: 0; }
.step .dur{ display:block; margin-top: 10px; font-family:'JetBrains Mono', monospace; font-size: 10.5px; letter-spacing: .12em; text-transform: uppercase; color: var(--mute); }

/* faq */
.faq details{ border-bottom: 1px solid var(--line-soft); padding: 22px 0; }
.faq details:first-child{ border-top: 1px solid var(--line-soft); }
.faq summary{ list-style: none; cursor: pointer; display:flex; justify-content: space-between; align-items: center; gap: 24px; font-family: 'Space Grotesk'; font-weight: 600; font-size: clamp(18px, 1.8vw, 22px); letter-spacing: -0.01em; }
.faq summary::-webkit-details-marker{ display: none; }
.faq summary::after{ content: '+'; font-weight: 400; font-size: 28px; color: var(--mute); transition: transform .2s ease; }
.faq details[open] summary::after{ transform: rotate(45deg); }
.faq .body{ margin-top: 14px; max-width: 64ch; color: var(--ink-2); font-size: 15px; }

/* about page bits */
.principles{ counter-reset: pr; }
.principle{ display:grid; grid-template-columns: 80px 1fr; gap: 24px; padding: 28px 0; border-top: 1px solid var(--line-soft); }
.principle:first-child{ border-top: 0; }
@media (max-width: 600px){ .principle{ grid-template-columns: 1fr; } }
.principle .n{ counter-increment: pr; font-family:'JetBrains Mono', monospace; font-size: 13px; letter-spacing: .15em; color: var(--mute); }
.principle .n::before{ content: '0' counter(pr); }
.principle h4{ font-size: clamp(20px, 2vw, 26px); margin-bottom: 8px; }
.principle p{ color: var(--ink-2); font-size: 15.5px; max-width: 60ch; margin: 0; }

.client-wall{ display:grid; grid-template-columns: repeat(6, 1fr); gap: 0; border-top: 1px solid var(--line-soft); border-left: 1px solid var(--line-soft); }
@media (max-width: 900px){ .client-wall{ grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 540px){ .client-wall{ grid-template-columns: repeat(2, 1fr); } }
.client-wall .cl{ aspect-ratio: 3/2; display:flex; align-items:center; justify-content:center; border-right: 1px solid var(--line-soft); border-bottom: 1px solid var(--line-soft); font-family:'Space Grotesk'; font-weight: 600; font-size: 16px; letter-spacing: -0.02em; color: var(--mute); transition: color .2s ease, background .2s ease; }
.client-wall .cl:hover{ color: var(--ink); background: rgba(255,255,255,.4); }

/* contact page */
.contact-grid{ display:grid; grid-template-columns: 1.2fr 1fr; gap: 48px; align-items: start; }
@media (max-width: 900px){ .contact-grid{ grid-template-columns: 1fr; gap: 32px; } }
.info-row{ display:grid; grid-template-columns: 110px 1fr; gap: 18px; padding: 18px 0; border-top: 1px solid var(--line-soft); align-items: baseline; }
.info-row:first-child{ border-top: 0; padding-top: 0; }
.info-row .k{ font-family:'JetBrains Mono', monospace; font-size: 11px; letter-spacing: .12em; text-transform: uppercase; color: var(--mute); }
.info-row .v{ font-size: 15px; }
.info-row .v a{ color: var(--ink); }
.info-row .v a:hover{ color: var(--magenta); }

/* fade-up scroll anims */
.fade-up{ opacity: 0; transform: translateY(16px); transition: opacity .7s ease, transform .7s ease; }
.fade-up.in{ opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce){
  .fade-up{ opacity: 1; transform: none; transition: none; }
}

/* sticky bottom CTA on long pages */
.sticky-cta{ position: fixed; left: 50%; bottom: 18px; transform: translate(-50%, 80px); z-index: 50; opacity: 0; transition: transform .3s ease, opacity .3s ease; }
.sticky-cta.show{ opacity: 1; transform: translate(-50%, 0); }
.sticky-cta .btn{ box-shadow: var(--shadow-2); }

/* misc */
img{ max-width: 100%; height: auto; display:block; }
.logo-img{ height: 64px; width: auto; }
