/* NOUWA STUDIO — Stage 5: execution-platform positioning
   AI Agents grid · Mission Compiler · Output Gallery · refined hero       */

/* ---------- Hero rewrite ---------- */
.hero h1.exec{
  font-size:78px;font-weight:600;line-height:1.04;letter-spacing:-.035em;margin:0 0 22px;color:var(--ink);
}
.hero h1.exec em{
  font-style:normal;background:var(--grad);-webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;display:inline-block;
}
.hero h1.exec.hero-pillars{display:flex;flex-direction:column;gap:14px;line-height:1.02;}
.hero h1.exec.hero-pillars span{display:block;}
.hero h1.exec .h-think {color:var(--ink);}
.hero h1.exec .h-create{color:var(--red);}
.hero h1.exec .h-work  {color:var(--violet);}
@media (max-width:1080px){ .hero h1.exec.hero-pillars{gap:10px;} }
@media (max-width:680px){  .hero h1.exec.hero-pillars{gap:8px;} }
/* Hero strap pill — transparent fill, black text, animated spectrum border */
@property --strap-angle {
  syntax: '<angle>';
  initial-value: 0deg;
  inherits: false;
}
.hero .strap{
  position:relative;
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:7px 16px;
  border-radius:999px;
  background:transparent;
  color:var(--ink);
  font-size:11.5px;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  margin-bottom:22px;
  isolation:isolate;
}
/* Spectrum border — conic-gradient masked to border-only via padding+mask trick */
.hero .strap::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  padding:2px;
  background:conic-gradient(from var(--strap-angle),
    #000     0%,
    #F4504C  10%,
    #FB923C  20%,
    #FACC15  32%,
    #22C55E  45%,
    #06B6D4  58%,
    #4338CA  70%,
    #9333EA  82%,
    #EC4899  92%,
    #000     100%);
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
          mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;
          mask-composite:exclude;
  animation:strap-spin 5.5s linear infinite;
  pointer-events:none;
  z-index:-1;
}
@keyframes strap-spin{ to { --strap-angle:360deg; } }

/* Fallback for browsers without @property support */
@supports not (background: paint(something)) {
  .hero .strap::before{
    background:linear-gradient(90deg,
      #000, #F4504C, #FB923C, #FACC15, #22C55E,
      #06B6D4, #4338CA, #9333EA, #EC4899, #000);
    background-size:300% 100%;
    animation:strap-flow 5.5s linear infinite;
  }
  @keyframes strap-flow{
    0%{ background-position:0% 50%; }
    100%{ background-position:300% 50%; }
  }
}
@media (prefers-reduced-motion: reduce){
  .hero .strap::before{ animation:none; }
}

.hero .strap .dot{
  width:6px;height:6px;border-radius:50%;background:#F4504C;
  box-shadow:0 0 0 4px rgba(244,80,76,.18);
}

@media (max-width:1080px){ .hero h1.exec{font-size:54px;} }
@media (max-width:680px){  .hero h1.exec{font-size:40px;} }

/* ---------- AI AGENTS GRID ---------- */
.agents{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;perspective:1200px;}
.agent{
  --agent-accent:var(--indigo);
  --agent-accent-rgb:67,56,202;
  position:relative;min-height:228px;border:1px solid rgba(25,23,54,.09);border-radius:24px;
  padding:27px 24px 24px;background:
    linear-gradient(145deg,rgba(255,255,255,.97),rgba(248,249,255,.82) 56%,rgba(var(--agent-accent-rgb),.055)),
    var(--surface);
  box-shadow:0 1px 0 rgba(255,255,255,.9) inset,0 18px 42px rgba(30,28,67,.07);
  transition:border-color .24s ease,box-shadow .24s ease,transform .24s ease,background .24s ease;
  overflow:hidden;isolation:isolate;
}
.agent::before{
  content:"";position:absolute;inset:0 0 auto 0;height:4px;
  background:linear-gradient(90deg,rgba(var(--agent-accent-rgb),.18),var(--agent-accent),rgba(var(--agent-accent-rgb),.22));
  opacity:.92;transition:height .24s ease,opacity .24s ease;
}
.agent::after{
  content:"";position:absolute;right:-64px;top:-72px;width:190px;height:190px;border-radius:50%;
  background:radial-gradient(circle,rgba(var(--agent-accent-rgb),.18),rgba(var(--agent-accent-rgb),.08) 44%,transparent 70%);
  pointer-events:none;z-index:-1;transition:transform .28s ease,opacity .28s ease;
}
.agent:hover{
  border-color:rgba(var(--agent-accent-rgb),.34);
  box-shadow:0 1px 0 rgba(255,255,255,.95) inset,0 24px 60px rgba(30,28,67,.13);
  transform:translateY(-6px) rotateX(1deg);
}
.agent:hover::before{height:6px;opacity:1;}
.agent:hover::after{transform:translate(-10px,10px) scale(1.08);opacity:.95;}
.agent .ag-head{display:flex;align-items:center;gap:14px;margin-bottom:15px;position:relative;z-index:1;}
.agent .ag-glyph{
  width:48px;height:48px;border-radius:16px;display:grid;place-items:center;flex:none;
  background:linear-gradient(145deg,rgba(var(--agent-accent-rgb),.14),rgba(255,255,255,.88));
  border:1px solid rgba(var(--agent-accent-rgb),.18);color:var(--agent-accent);
  box-shadow:0 10px 24px rgba(var(--agent-accent-rgb),.13),0 1px 0 rgba(255,255,255,.9) inset;
  font-size:20px;font-weight:800;line-height:1;
}
.agent.a-strategy{--agent-accent:var(--red);--agent-accent-rgb:244,80,76;}
.agent.a-copy{--agent-accent:var(--violet);--agent-accent-rgb:124,58,237;}
.agent.a-design{--agent-accent:var(--indigo);--agent-accent-rgb:67,56,202;}
.agent.a-growth{--agent-accent:var(--teal);--agent-accent-rgb:14,148,132;}
.agent.a-qa{--agent-accent:#D97706;--agent-accent-rgb:217,119,6;}
.agent.a-publisher{--agent-accent:#17162F;--agent-accent-rgb:23,22,47;}
.agent.a-publisher .ag-glyph{background:linear-gradient(145deg,#17162F,#312D66);color:#fff;border-color:rgba(255,255,255,.08);}
.agent .ag-name{font-size:10.5px;font-weight:800;letter-spacing:.17em;color:rgba(var(--agent-accent-rgb),.74);
  text-transform:uppercase;margin-bottom:5px;}
.agent .ag-title{font-size:19px;font-weight:700;letter-spacing:-.015em;line-height:1.18;color:var(--ink);}
.agent .ag-sub{font-size:13.5px;color:var(--ink2);line-height:1.62;margin:15px 0 0;position:relative;z-index:1;}
.agent .ag-skills{display:flex;flex-wrap:wrap;gap:7px;margin-top:16px;position:relative;z-index:1;}
.agent .ag-skill{
  font-size:11px;color:rgba(30,28,67,.72);background:rgba(255,255,255,.72);
  border:1px solid rgba(var(--agent-accent-rgb),.12);box-shadow:0 1px 0 rgba(255,255,255,.9) inset;
  padding:4px 10px;border-radius:999px;font-weight:650;
}
.agent .ag-model{
  display:flex;align-items:center;gap:7px;font-size:11px;font-weight:700;letter-spacing:.055em;
  color:var(--ink3);margin-top:17px;padding-top:14px;border-top:1px solid rgba(var(--agent-accent-rgb),.13);
  position:relative;z-index:1;
}
.agent .ag-model::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--agent-accent);box-shadow:0 0 0 4px rgba(var(--agent-accent-rgb),.12);}
.agent .ag-model b{color:var(--ink);font-weight:750;}

/* ---------- MISSION COMPILER ---------- */
.compiler-stage{display:grid;grid-template-columns:1fr 1fr;gap:22px;align-items:stretch;}
.compiler-input{background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:26px 28px;
  position:relative;overflow:hidden;}
.compiler-input::before{content:"YOUR BRIEF";position:absolute;top:18px;inset-inline-end:22px;
  font-size:10px;font-weight:700;letter-spacing:.18em;color:var(--ink3);}
.compiler-input .lbl{font-size:11px;font-weight:700;letter-spacing:.18em;color:var(--ink3);
  text-transform:uppercase;margin-bottom:14px;display:flex;align-items:center;gap:8px;}
.compiler-input .lbl .num{width:22px;height:22px;border-radius:50%;background:var(--canvas);
  border:1px solid var(--border);display:grid;place-items:center;font-size:11px;color:var(--ink);}
.compiler-input p{font-size:17px;line-height:1.6;color:var(--ink);margin:0;font-weight:500;}
.compiler-input .meta{display:flex;gap:14px;margin-top:18px;font-size:11.5px;color:var(--ink3);}

.compiler-arrow{display:none;}

.compiler-out{background:#0F0E26;color:#FAFAFA;border-radius:18px;padding:26px 28px;position:relative;
  overflow:hidden;font-family:'SFMono-Regular',Consolas,monospace;font-size:12.5px;line-height:1.7;
  border:1px solid rgba(255,255,255,.08);}
.compiler-out::before{content:"COMPILED";position:absolute;top:18px;inset-inline-end:22px;
  font-size:10px;font-weight:700;letter-spacing:.18em;color:rgba(255,255,255,.45);}
.compiler-out .lbl{font-size:11px;font-weight:700;letter-spacing:.18em;color:#C4B5FD;
  text-transform:uppercase;margin-bottom:14px;font-family:Inter,system-ui;display:flex;align-items:center;gap:8px;}
.compiler-out .lbl .num{width:22px;height:22px;border-radius:50%;background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.18);display:grid;place-items:center;font-size:11px;
  color:#fff;font-family:Inter,system-ui;}
.compiler-out .k{color:#A78BFA;}
.compiler-out .s{color:#FCA5A5;}
.compiler-out .n{color:#FDE68A;}
.compiler-out .b{color:#86EFAC;}
.compiler-out .c{color:rgba(255,255,255,.32);font-style:italic;}
.compiler-out .cursor{display:inline-block;width:8px;height:14px;background:#F4504C;vertical-align:text-bottom;
  margin-inline-start:3px;animation:blink 1s infinite;}

.compiler-foot{margin-top:24px;background:linear-gradient(140deg,#FFFFFF 0%,#F5F3FD 100%);
  border:1px solid var(--border);border-radius:14px;padding:20px 24px;display:flex;align-items:center;gap:18px;}
.compiler-foot .icon-hex{width:46px;height:46px;flex:none;}
.compiler-foot .txt{flex:1;}
.compiler-foot .txt .h{font-size:13px;font-weight:600;line-height:1.3;}
.compiler-foot .txt .p{font-size:12.5px;color:var(--ink2);margin-top:3px;line-height:1.5;}

@media (max-width:980px){
  .compiler-stage{grid-template-columns:1fr;}
}

/* ---------- OUTPUT GALLERY ---------- */
.gallery{display:grid;grid-template-columns:repeat(12,1fr);gap:14px;}
.gallery-cell{background:var(--surface);border:1px solid var(--border);border-radius:14px;
  position:relative;overflow:hidden;cursor:pointer;transition:all .22s;display:flex;flex-direction:column;}
.gallery-cell:hover{border-color:var(--border2);box-shadow:var(--shadow-l);transform:translateY(-3px);}
/* tag/corner/title overlays: kept in DOM for a11y but hidden visually
   since the gallery images embed all labels (badge, mission name, subtitle).
   Screen readers still announce them via the original elements. */
.gallery-cell .tag,
.gallery-cell .corner,
.gallery-cell .ttl{
  position:absolute;
  width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;
  clip:rect(0,0,0,0);white-space:nowrap;border:0;
}

/* sizes within 12-column grid */
.gal-md{grid-column:span 6;aspect-ratio:5/3;}
.gal-sm{grid-column:span 4;aspect-ratio:1/1;}
.gal-tall{grid-column:span 4;aspect-ratio:3/4;}
.gal-wide{grid-column:span 8;aspect-ratio:5/3;}

/* gallery cards backed by real generated images.
   Images are self-contained (badge + mission name + subtitle baked in). */
.gp-brand  { background:#FFEFE0 url('uploads/gallery-brand.webp')    center/cover no-repeat; }
.gp-web    { background:#F5F3FD url('uploads/gallery-website.webp')  center/cover no-repeat; }
.gp-camp   { background:#17153A url('uploads/gallery-campaign.webp') center/cover no-repeat; }
.gp-analy  { background:#F0FAF8 url('uploads/gallery-analysis.webp') center/cover no-repeat; }
.gp-prop   { background:#FAF8FE url('uploads/gallery-proposal.webp') center/cover no-repeat; }
.gp-social { background:#FCD4D2 url('uploads/gallery-social.webp')   center/cover no-repeat; }
.gp-ui     { background:#EDE9FB url('uploads/gallery-ui.webp')       center/cover no-repeat; }
.gp-media  { background:#8B5A3C url('uploads/gallery-media.webp')    center/cover no-repeat; }

@media (max-width:980px){
  .gallery{grid-template-columns:repeat(6,1fr);}
  .gal-md,.gal-wide{grid-column:span 6;}
  .gal-sm,.gal-tall{grid-column:span 3;}
}
@media (max-width:560px){
  .gallery{grid-template-columns:1fr;}
  .gal-md,.gal-wide,.gal-sm,.gal-tall{grid-column:span 1;}
}

/* ---------- WHY NOUWA · 9 expressive differentiators ---------- */
.diff-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.diff-card{
  --diff-accent:var(--indigo);
  --diff-rgb:67,56,202;
  position:relative;min-height:218px;border:1px solid rgba(38,34,88,.09);border-radius:22px;
  padding:96px 22px 22px;background:
    linear-gradient(145deg,rgba(255,255,255,.98),rgba(249,250,255,.86)),
    var(--surface);
  box-shadow:0 1px 0 rgba(255,255,255,.92) inset,0 16px 40px rgba(30,28,67,.055);
  transition:border-color .22s ease,box-shadow .22s ease,transform .22s ease;
  overflow:hidden;isolation:isolate;
}
.diff-card:hover{
  border-color:rgba(var(--diff-rgb),.30);
  box-shadow:0 1px 0 rgba(255,255,255,.96) inset,0 24px 58px rgba(30,28,67,.12);
  transform:translateY(-5px);
}
.diff-card::before{
  content:"";position:absolute;left:18px;right:18px;top:18px;height:58px;border-radius:16px;
  background:
    radial-gradient(circle at 78% 50%,rgba(var(--diff-rgb),.16),transparent 29%),
    linear-gradient(145deg,rgba(var(--diff-rgb),.08),rgba(255,255,255,.82));
  border:1px solid rgba(var(--diff-rgb),.13);
  box-shadow:0 1px 0 rgba(255,255,255,.88) inset;
  z-index:-1;
}
.diff-card::after{
  content:"";position:absolute;top:32px;right:34px;width:92px;height:30px;opacity:.82;
  background:linear-gradient(90deg,rgba(var(--diff-rgb),.18),rgba(var(--diff-rgb),.04));
  border-radius:999px;
  z-index:-1;
}
.diff-card .num{
  position:absolute;top:20px;inset-inline-end:20px;width:30px;height:30px;border-radius:50%;
  background:rgba(255,255,255,.78);border:1px solid rgba(var(--diff-rgb),.15);
  display:grid;place-items:center;font-size:11px;font-weight:800;letter-spacing:.02em;
  color:rgba(var(--diff-rgb),.78);font-feature-settings:"tnum";
  box-shadow:0 1px 0 rgba(255,255,255,.9) inset;
}
.diff-card.featured .num{background:var(--grad);color:#fff;border-color:transparent;box-shadow:0 10px 22px rgba(124,58,237,.24);}
.diff-card .ico{
  position:absolute;top:30px;left:32px;width:36px;height:36px;border-radius:12px;
  display:grid;place-items:center;font-size:0;background:rgba(255,255,255,.78);
  color:var(--diff-accent);border:1px solid rgba(var(--diff-rgb),.14);
  box-shadow:0 10px 22px rgba(var(--diff-rgb),.11),0 1px 0 rgba(255,255,255,.94) inset;
}
.diff-card .ico::before{content:"";width:15px;height:15px;border-radius:5px;background:var(--diff-accent);}
.diff-card .ico::after{content:"";position:absolute;inset:auto -54px -6px auto;width:84px;height:44px;opacity:.9;}
.diff-card .nm{font-size:16px;font-weight:750;letter-spacing:-.01em;line-height:1.22;margin-bottom:9px;color:var(--ink);}
.diff-card .sd{font-size:13px;color:var(--ink2);line-height:1.62;margin:0;}

.diff-card:nth-child(1){--diff-accent:var(--red);--diff-rgb:244,80,76;}
.diff-card:nth-child(1) .ico::before{
  width:18px;height:22px;border-radius:4px;background:
    linear-gradient(var(--diff-accent),var(--diff-accent)) 5px 6px/8px 2px no-repeat,
    linear-gradient(var(--diff-accent),var(--diff-accent)) 5px 11px/12px 2px no-repeat,
    linear-gradient(var(--diff-accent),var(--diff-accent)) 5px 16px/9px 2px no-repeat,
    rgba(244,80,76,.12);
  border:1px solid rgba(244,80,76,.34);
}
.diff-card:nth-child(2){--diff-accent:var(--violet);--diff-rgb:124,58,237;}
.diff-card:nth-child(2) .ico::before{
  width:22px;height:22px;border-radius:50%;background:
    radial-gradient(circle at 50% 16%,var(--diff-accent) 0 3px,transparent 4px),
    radial-gradient(circle at 18% 78%,var(--diff-accent) 0 3px,transparent 4px),
    radial-gradient(circle at 82% 78%,var(--diff-accent) 0 3px,transparent 4px),
    linear-gradient(35deg,transparent 42%,rgba(124,58,237,.45) 43% 49%,transparent 50%),
    linear-gradient(-35deg,transparent 42%,rgba(124,58,237,.45) 43% 49%,transparent 50%);
}
.diff-card:nth-child(3){--diff-accent:var(--indigo);--diff-rgb:67,56,202;}
.diff-card:nth-child(3) .ico::before{
  width:24px;height:18px;border-radius:9px;background:
    radial-gradient(circle at 16% 50%,var(--diff-accent) 0 3px,transparent 4px),
    radial-gradient(circle at 50% 50%,var(--diff-accent) 0 3px,transparent 4px),
    radial-gradient(circle at 84% 50%,var(--diff-accent) 0 3px,transparent 4px),
    linear-gradient(90deg,rgba(67,56,202,.22),rgba(67,56,202,.05));
  border:1px solid rgba(67,56,202,.22);
}
.diff-card:nth-child(4){--diff-accent:var(--teal);--diff-rgb:14,148,132;}
.diff-card:nth-child(4) .ico::before{
  width:24px;height:22px;border-radius:4px;background:
    linear-gradient(180deg,transparent 45%,var(--diff-accent) 46% 100%) 2px bottom/4px 9px no-repeat,
    linear-gradient(180deg,transparent 30%,var(--diff-accent) 31% 100%) 10px bottom/4px 14px no-repeat,
    linear-gradient(180deg,transparent 10%,var(--diff-accent) 11% 100%) 18px bottom/4px 20px no-repeat;
}
.diff-card:nth-child(5){--diff-accent:#EF4444;--diff-rgb:239,68,68;}
.diff-card:nth-child(5) .ico::before{
  content:"عA";width:auto;height:auto;background:none;border-radius:0;
  font-size:15px;font-weight:800;letter-spacing:-.08em;color:var(--diff-accent);
}
.diff-card:nth-child(6){--diff-accent:var(--violet);--diff-rgb:124,58,237;}
.diff-card:nth-child(6) .ico::before{
  width:22px;height:18px;border-radius:3px;background:
    linear-gradient(var(--diff-accent),var(--diff-accent)) 0 0/22px 4px no-repeat,
    linear-gradient(rgba(124,58,237,.25),rgba(124,58,237,.25)) 0 7px/7px 11px no-repeat,
    linear-gradient(rgba(124,58,237,.16),rgba(124,58,237,.16)) 10px 7px/12px 11px no-repeat;
}
.diff-card:nth-child(7){--diff-accent:var(--indigo);--diff-rgb:67,56,202;}
.diff-card:nth-child(7) .ico::before{
  width:20px;height:22px;border-radius:4px;background:
    linear-gradient(var(--diff-accent),var(--diff-accent)) 5px 15px/10px 3px no-repeat,
    linear-gradient(135deg,transparent 0 45%,var(--diff-accent) 46% 54%,transparent 55%) 7px 4px/10px 10px no-repeat,
    rgba(67,56,202,.12);
  border:1px solid rgba(67,56,202,.25);
}
.diff-card:nth-child(8){--diff-accent:var(--violet);--diff-rgb:124,58,237;}
.diff-card:nth-child(8) .ico::before{
  width:22px;height:22px;border-radius:50%;background:
    conic-gradient(from 45deg,var(--diff-accent) 0 76%,transparent 77% 100%);
  -webkit-mask:radial-gradient(circle,transparent 0 8px,#000 9px);
          mask:radial-gradient(circle,transparent 0 8px,#000 9px);
}
.diff-card:nth-child(9){--diff-accent:var(--red);--diff-rgb:244,80,76;}
.diff-card:nth-child(9) .ico::before{
  width:22px;height:22px;border-radius:0;background:var(--diff-accent);
  clip-path:polygon(50% 0%,61% 34%,96% 38%,68% 58%,78% 92%,50% 72%,22% 92%,32% 58%,4% 38%,39% 34%);
}
@media (max-width:1080px){ .diff-grid{grid-template-columns:repeat(2,1fr);} }
@media (max-width:680px){  .diff-grid{grid-template-columns:1fr;} }

/* ---------- GROWTH · 5 named sub-engines (dark section) ---------- */
.growth-engines{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;}
.gx-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.10);border-radius:16px;
  padding:24px 22px 22px;position:relative;overflow:hidden;transition:all .2s;}
.gx-card:hover{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.18);transform:translateY(-3px);}
.gx-card .engine-num{display:inline-flex;align-items:center;gap:7px;font-size:10px;font-weight:700;
  letter-spacing:.18em;color:#C4B5FD;background:rgba(124,58,237,.20);padding:3px 9px;border-radius:5px;
  text-transform:uppercase;margin-bottom:18px;}
.gx-card .gx-ico{width:42px;height:42px;border-radius:11px;background:rgba(124,58,237,.18);color:#C4B5FD;
  display:grid;place-items:center;margin-bottom:14px;}
.gx-card .gx-nm{font-size:15px;font-weight:600;color:#fff;letter-spacing:-.005em;line-height:1.25;margin-bottom:8px;}
.gx-card .gx-sd{font-size:12.5px;color:rgba(255,255,255,.66);line-height:1.6;margin:0 0 14px;}
.gx-card .gx-tag{display:inline-flex;align-items:center;gap:6px;font-size:10px;font-weight:600;
  letter-spacing:.14em;color:#86EFAC;background:rgba(14,148,132,.18);padding:3px 8px;border-radius:5px;
  text-transform:uppercase;}
.gx-card .gx-tag .dot{width:5px;height:5px;border-radius:50%;background:#86EFAC;}
@media (max-width:1080px){ .growth-engines{grid-template-columns:repeat(2,1fr);} }
@media (max-width:680px){  .growth-engines{grid-template-columns:1fr;} }

/* ---------- Secondary button (Starter / Agency pricing) ---------- */
.btn-secondary{background:var(--ink);color:#fff;border:1px solid var(--ink);
  box-shadow:0 2px 8px rgba(23,21,58,.20);}
.btn-secondary:hover{background:#0F0E26;transform:translateY(-1px);box-shadow:0 5px 16px rgba(23,21,58,.30);}
.theme-dark .btn-secondary{background:var(--violet);border-color:var(--violet);}
.theme-dark .btn-secondary:hover{background:#6D28D9;}

/* ---------- Button-color override (defeats .site a{color:inherit} from marketing.css) ---------- */
.site .btn-primary,.site a.btn-primary,
.site .btn-secondary,.site a.btn-secondary,
.site .grad-cta,.site a.grad-cta{color:#fff;}
.site .btn-ghost,.site a.btn-ghost{color:var(--ink2);}
.site .btn-ghost:hover,.site a.btn-ghost:hover{color:var(--ink);}
.theme-dark .site .btn-ghost,.theme-dark .site a.btn-ghost{color:#E5E1FF;}

/* ---------- TABLET breakpoint (768px) for major grids ---------- */
@media (max-width:1024px) and (min-width:769px){
  .pillars,.agents,.why-grid,.tpl-grid,.lib-grid{grid-template-columns:repeat(2,1fr);}
  .pricing{grid-template-columns:repeat(2,1fr);}
}
/* Nav collapses earlier than the grid: 7 nav links + 3 CTAs need ~1000px; collapse below 960 */
@media (max-width:960px){
  .site-nav-links{display:none;}
  .nav-hamburger{display:inline-grid !important;}
  /* hide the desktop CTAs in the top-right; the hamburger menu has them */
  .site-nav-end .btn-ghost,
  .site-nav-end .btn-primary.btn-xl,
  .site-nav-end .lang-pill{display:none;}
}
@media (max-width:768px){
  .pillars,.agents,.why-grid,.tpl-grid,.lib-grid,.pricing,.growth-grid{grid-template-columns:1fr;}
  .compiler-stage,.engine,.cmp{grid-template-columns:1fr;}
  .growth-engines{grid-template-columns:1fr;}
  .foot-grid{grid-template-columns:1fr 1fr;}
  .hero .wrap{gap:32px;}
  .hero-scene{max-width:380px;margin:0 auto;}
  .hero-portrait-glow{inset:-6% !important;}
  /* the floating multi-model viz overflows hard on mobile — hide it */
  .engine-viz{display:none;}
  /* constrain anything that may peek past */
  .teams-stage,.gallery{grid-template-columns:1fr;}
  .gal-md,.gal-sm,.gal-tall,.gal-wide{grid-column:span 1;}
}
/* Safety net: prevent any decorative overflow from causing horizontal scroll */
html,body{overflow-x:hidden;}
/* Tablet (≤1024 and ≥769): step down high-column grids to 2 cols, optimize flow */
@media (max-width:1024px) and (min-width:769px){
  .agents,.diff-grid,.why-grid,.pillars{grid-template-columns:repeat(2,1fr);}
  .pricing{grid-template-columns:repeat(2,1fr);}
  .growth-engines{grid-template-columns:repeat(3,1fr);}
  .flow{grid-template-columns:1fr;gap:24px;}
  .gallery{grid-template-columns:repeat(4,1fr);}
  .gal-md,.gal-wide{grid-column:span 4;}
  .gal-sm,.gal-tall{grid-column:span 2;}
}
/* Mobile strap pill */
@media (max-width:560px){
  .hero .strap{padding:5px 11px;font-size:10.5px;}
}
/* Final-CTA buttons should wrap on small screens */
@media (max-width:560px){
  .cta-final .btns{flex-direction:column;gap:10px;width:100%;max-width:300px;margin:0 auto;}
  .cta-final .btns .btn{justify-content:center;width:100%;}
  .hero-cta{flex-direction:column;align-items:stretch;gap:10px;}
  .hero-cta .btn{justify-content:center;}
  .hero-meta{flex-wrap:wrap;justify-content:center;text-align:center;}
}
@media (max-width:560px){
  .hero h1.exec{font-size:36px;line-height:1.06;}
  .sect-head h2,.cta-final h2{font-size:30px;}
  .wrap{padding:0 18px;}
  .foot-grid{grid-template-columns:1fr;gap:24px;}
}

/* ---------- Mobile hamburger nav ---------- */
.nav-hamburger{display:none;width:38px;height:38px;border-radius:10px;background:var(--canvas);
  border:1px solid var(--border);place-items:center;cursor:pointer;color:var(--ink2);
  transition:all .15s;flex:none;}
.nav-hamburger:hover{border-color:var(--border2);color:var(--ink);}
.nav-hamburger svg{width:18px;height:18px;}
.mobile-nav{display:none;position:fixed;inset:var(--site-nav-h) 0 0 0;background:var(--surface);
  z-index:40;padding:24px 22px;flex-direction:column;gap:6px;overflow-y:auto;}
.mobile-nav.open{display:flex;animation:ghostin .2s both;}
.mobile-nav a{font-size:18px;font-weight:600;color:var(--ink);padding:14px 16px;border-radius:11px;
  border:1px solid transparent;}
.mobile-nav a:hover{background:var(--tint);}
.mobile-nav .mob-sep{height:1px;background:var(--border);margin:14px 0;}
.mobile-nav .mob-cta{background:var(--grad);color:#fff;text-align:center;font-size:15.5px;padding:14px 22px;
  border-radius:12px;font-weight:600;}

/* ---------- FAQ accordion ---------- */
.faq{max-width:780px;margin:0 auto;}
.faq-item{border-bottom:1px solid var(--border);}
.faq-item:first-child{border-top:1px solid var(--border);}
.faq-q{display:flex;align-items:center;gap:14px;padding:22px 4px;font-size:17px;font-weight:600;
  letter-spacing:-.005em;color:var(--ink);cursor:pointer;background:none;border:none;width:100%;
  text-align:start;font-family:inherit;}
.faq-q:hover{color:var(--indigo);}
.faq-q .num{font-size:12px;font-weight:700;letter-spacing:.14em;color:var(--ink3);min-width:30px;}
.faq-q .spc{flex:1;}
.faq-q .toggle{width:28px;height:28px;border-radius:50%;background:var(--canvas);border:1px solid var(--border);
  display:grid;place-items:center;color:var(--ink2);font-size:14px;font-weight:600;flex:none;transition:all .18s;}
.faq-item.open .faq-q .toggle{background:var(--grad);color:#fff;border-color:transparent;transform:rotate(45deg);}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease;}
.faq-item.open .faq-a{max-height:300px;}
.faq-a p{font-size:14.5px;color:var(--ink2);line-height:1.7;margin:0 0 22px;padding:0 4px 0 44px;}
.frame[dir="rtl"] .faq-a p{padding:0 44px 0 4px;}
.site[dir="rtl"] .faq-a p{padding:0 44px 0 4px;}

/* ---------- Why NOUWA card row ---------- */
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;}
.why-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:22px 22px 24px;
  transition:all .18s;}
.why-card:hover{border-color:var(--border2);box-shadow:var(--shadow-s);transform:translateY(-2px);}
.why-card .ico{width:38px;height:38px;border-radius:10px;background:var(--tint);color:var(--indigo);
  display:grid;place-items:center;margin-bottom:14px;}
.why-card .nm{font-size:14.5px;font-weight:600;margin-bottom:6px;letter-spacing:-.005em;}
.why-card .sd{font-size:12.5px;color:var(--ink2);line-height:1.6;margin:0;}
@media (max-width:980px){ .why-grid{grid-template-columns:repeat(2,1fr);} }
@media (max-width:560px){ .why-grid{grid-template-columns:1fr;} }

/* ---------- Mission Compiler in plan screen ---------- */
.compiler-card{margin:14px 0 0;background:#0F0E26;color:#FAFAFA;border-radius:14px;padding:16px 20px;
  font-family:'SFMono-Regular',Consolas,monospace;font-size:11.5px;line-height:1.65;
  animation:ghostin calc(.45s*var(--mt)) both;border:1px solid rgba(255,255,255,.10);overflow:hidden;}
.compiler-card .h{display:flex;align-items:center;gap:8px;margin-bottom:9px;font-size:10.5px;font-weight:700;
  letter-spacing:.16em;color:#C4B5FD;text-transform:uppercase;font-family:Inter,system-ui;}
.compiler-card .h .pulse{width:7px;height:7px;border-radius:50%;background:#F4504C;
  box-shadow:0 0 0 4px rgba(244,80,76,.22);animation:redring 1.8s ease-out infinite;}
.compiler-card .k{color:#A78BFA;}
.compiler-card .s{color:#FCA5A5;}
.compiler-card .b{color:#86EFAC;}
.compiler-card .n{color:#FDE68A;}
.compiler-card .c{color:rgba(255,255,255,.35);}

/* ---------- Missing-input smart cards (plan screen) ---------- */
.missing-row{margin-top:14px;animation:ghostin calc(.5s*var(--mt)) both;}
.missing-toggle{display:flex;align-items:center;gap:9px;width:100%;background:var(--surface);
  border:1px solid var(--border);border-radius:11px;padding:9px 14px;cursor:pointer;
  font-family:inherit;font-size:12px;color:var(--ink2);text-align:start;transition:all .14s;}
.missing-toggle:hover{border-color:var(--border2);color:var(--ink);}
.missing-row.open .missing-toggle{border-bottom-left-radius:0;border-bottom-right-radius:0;border-bottom-color:transparent;}
.missing-toggle .lbl{font-weight:600;color:var(--ink);letter-spacing:-.003em;}
.missing-toggle .sm{color:var(--ink3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0;font-size:11.5px;}
.missing-toggle .spc{flex:none;}
.missing-toggle .arr{font-size:11px;color:var(--ink3);}
.missing-row.open .missing-grid{margin-top:0;border:1px solid var(--border);border-top:none;
  border-radius:0 0 11px 11px;padding:11px;background:var(--surface);}
.missing-head{display:flex;align-items:center;gap:8px;margin-bottom:10px;font-size:11px;font-weight:600;
  letter-spacing:.14em;text-transform:uppercase;color:var(--ink3);}
.missing-head .dim{color:var(--ink3);opacity:.7;text-transform:none;letter-spacing:.02em;font-size:11.5px;font-weight:500;}
.missing-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:9px;}
@media (min-width:880px){ .missing-grid{grid-template-columns:repeat(4,1fr);} }
.missing-card{background:var(--surface);border:1px solid var(--border);border-radius:11px;padding:11px 13px;}
.missing-card .lbl{font-size:10.5px;font-weight:600;letter-spacing:.12em;color:var(--ink3);
  text-transform:uppercase;margin-bottom:8px;}
.missing-card .chips{display:flex;flex-wrap:wrap;gap:5px;}
.mchip{font-size:11px;font-weight:500;color:var(--ink2);background:var(--canvas);border:1px solid var(--border);
  padding:4px 9px;border-radius:7px;transition:all .14s;cursor:pointer;}
.mchip:hover{border-color:var(--border2);color:var(--ink);}
.mchip.on{background:var(--tint2);border-color:var(--violet);color:var(--indigo);font-weight:600;}

/* ---------- Agents row in plan screen ---------- */
.agent-row{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:14px;
  animation:ghostin calc(.5s*var(--mt)) both;}
.agent-pill{display:flex;align-items:center;gap:9px;padding:10px 12px;border-radius:10px;
  background:var(--surface);border:1px solid var(--border);font-size:12px;}
.agent-pill .gl{width:26px;height:26px;border-radius:7px;display:grid;place-items:center;font-size:12px;font-weight:700;color:#fff;flex:none;}
.agent-pill.a-strategy .gl{background:var(--red);}
.agent-pill.a-copy     .gl{background:var(--violet);}
.agent-pill.a-design   .gl{background:var(--indigo);}
.agent-pill.a-growth   .gl{background:var(--teal);}
.agent-pill.a-qa       .gl{background:#D97706;}
.agent-pill.a-publisher .gl{background:var(--ink);}
.agent-pill .body{min-width:0;}
.agent-pill .nm{font-size:12.5px;font-weight:600;line-height:1.2;}
.agent-pill .ml{font-size:10.5px;color:var(--ink3);margin-top:2px;}
.agent-pill .ml b{color:var(--ink2);font-weight:600;}

/* ---------- Stage 9 — ultra-small viewport polish (≤360px) ---------- */
/* Decorative pill-glyph hexagons sit behind cards; clamp them so they don't push body width */
.pillar{overflow:hidden;}
.pillar .pill-glyph{max-width:60%;height:auto;}
/* Footer bottom row: wrap socials + email + flags onto multiple lines on narrow screens */
@media (max-width:560px){
  .foot-bot{flex-direction:column;align-items:flex-start;gap:12px;}
  .foot-bot .right{flex-wrap:wrap;row-gap:8px;column-gap:14px;}
  .foot-bot .right a{font-size:12.5px;}
}
/* Specialist track is decorative and sticks to viewport right — hide on phones to avoid overlap */
@media (max-width:768px){
  .specialist-track{display:none !important;}
}
/* Tighter wrap padding at <360px so the proof-strip ticker text doesn't overflow */
@media (max-width:360px){
  .wrap{padding:0 14px;}
  .hero h1.exec,.h-think,.h-create,.h-work{font-size:44px;line-height:1.02;}
  .proof-strip .pill-row{flex-wrap:wrap;justify-content:center;gap:8px 14px;}
}

/* ============ Stage 12 — Mobile sidebar drawer (sidebar-3) ============ */
@media (max-width:820px){
  .sidebar{position:fixed;top:0;bottom:0;inset-inline-start:0;z-index:120;width:280px;
    transform:translateX(-100%);transition:transform .22s ease;
    box-shadow:0 0 0 0 rgba(0,0,0,0);}
  [dir="rtl"] .sidebar{transform:translateX(100%);}
  .sidebar.is-open{transform:translateX(0);box-shadow:0 0 50px rgba(15,14,38,.28);}
  .sidebar-scrim{position:fixed;inset:0;background:rgba(15,14,38,.42);z-index:110;
    animation:toast-in .2s both;}
}
