/* ============================================================
   GOOB.services — brand system
   Purple #6936F5 · Orange #F56F00 · Ink #0A0614 · White
   ============================================================ */
:root{
  --ink:#0A0614;
  --ink-2:#120B24;
  --purple:#6936F5;
  --purple-soft:#9B7BFF;
  --orange:#F56F00;
  --orange-soft:#FF9A40;
  --paper:#F3F0FF;
  --dim:#9C94B8;
  --line:rgba(243,240,255,.10);
  --radius:18px;
  --max:1200px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--ink);
  color:var(--paper);
  font-family:'Sora',sans-serif;
  font-weight:300;
  line-height:1.65;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
::selection{background:var(--orange);color:#fff}
a{color:inherit;text-decoration:none}
:focus-visible{outline:2px solid var(--orange);outline-offset:3px;border-radius:4px}
img{max-width:100%;display:block}

.wrap{max-width:var(--max);margin:0 auto;padding:0 clamp(20px,5vw,48px)}
.mono{font-family:'IBM Plex Mono',monospace;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--dim)}
.display{font-family:'Michroma',sans-serif;font-weight:400;line-height:1.18;letter-spacing:.01em}

/* ---------- navigation ---------- */
nav{
  position:fixed;inset:0 0 auto 0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:16px clamp(20px,5vw,48px);
  transition:background .4s,backdrop-filter .4s,border-color .4s;
  border-bottom:1px solid transparent;
}
nav.scrolled{background:rgba(10,6,20,.78);backdrop-filter:blur(16px);border-color:var(--line)}
.logo{display:flex;align-items:center;gap:2px;font-family:'Michroma',sans-serif;font-size:1.22rem;letter-spacing:.04em;color:#fff}
.logo img{height:26px;width:auto;margin:0 1px;transition:transform .6s cubic-bezier(.2,.7,.2,1)}
.logo:hover img{transform:rotate(120deg)}
.nav-links{display:flex;gap:32px;align-items:center}
.nav-links a{font-size:.88rem;font-weight:400;color:var(--dim);transition:color .25s;position:relative}
.nav-links a:hover{color:var(--paper)}
.nav-links a.active{color:var(--paper)}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:2px;background:var(--orange);transition:width .3s}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.menu-toggle{display:none;background:none;border:none;color:var(--paper);cursor:pointer;padding:6px}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-family:'Sora',sans-serif;font-weight:500;font-size:.9rem;
  padding:14px 28px;border-radius:100px;cursor:pointer;border:1px solid transparent;
  transition:transform .25s,box-shadow .25s,background .25s,color .25s,border-color .25s;
  will-change:transform;
}
.btn-primary{background:var(--orange);color:#fff}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 14px 44px -8px rgba(245,111,0,.55);background:#FF7E14}
.btn-ghost{border-color:var(--line);color:var(--paper)}
.btn-ghost:hover{border-color:var(--orange);color:var(--orange-soft)}
.btn svg{transition:transform .25s}
.btn:hover svg{transform:translateX(4px)}
.nav-cta{padding:10px 22px;font-size:.82rem}
.nav-cta::after{display:none}

/* ---------- page hero (interior pages) ---------- */
.page-hero{padding:170px 0 70px;position:relative;overflow:hidden;border-bottom:1px solid var(--line);
  background:
   radial-gradient(55% 90% at 85% 0%,rgba(105,54,245,.30),transparent 60%),
   radial-gradient(40% 70% at 5% 100%,rgba(245,111,0,.12),transparent 60%),
   var(--ink-2);}
.page-hero h1{font-size:clamp(2rem,5vw,3.4rem);max-width:18ch}
.page-hero p{margin-top:18px;max-width:56ch;color:var(--dim);font-size:1.05rem}

/* ---------- sections ---------- */
section{padding:clamp(80px,11vw,130px) 0;position:relative}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:32px;margin-bottom:clamp(40px,6vw,68px);flex-wrap:wrap}
h2{font-size:clamp(1.6rem,3.4vw,2.6rem);max-width:22ch}
.sec-head p{max-width:44ch;color:var(--dim);font-size:1rem}
.eyebrow{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.eyebrow::before{content:"";width:34px;height:2px;background:var(--orange)}

/* highlight accents */
.hl-o{color:var(--orange)}
.hl-p{color:var(--purple-soft)}

/* ---------- service cards ---------- */
.services{display:grid;grid-template-columns:repeat(12,1fr);gap:18px}
.card{
  position:relative;border:1px solid var(--line);border-radius:var(--radius);
  background:linear-gradient(180deg,rgba(243,240,255,.04),rgba(243,240,255,.012));
  padding:34px 30px;overflow:hidden;
  transition:transform .35s cubic-bezier(.2,.7,.2,1),border-color .35s;
}
.card:hover{transform:translateY(-6px);border-color:rgba(245,111,0,.45)}
.card::before{
  content:"";position:absolute;inset:0;opacity:0;transition:opacity .4s;pointer-events:none;
  background:radial-gradient(420px circle at var(--mx,50%) var(--my,50%),rgba(105,54,245,.22),transparent 65%);
}
.card:hover::before{opacity:1}
.card-a{grid-column:span 7}
.card-b{grid-column:span 5}
.card-c{grid-column:span 5}
.card-d{grid-column:span 7}
.card .ico{
  width:50px;height:50px;border-radius:14px;display:grid;place-items:center;margin-bottom:22px;
  background:rgba(245,111,0,.10);border:1px solid rgba(245,111,0,.30);color:var(--orange-soft);
}
.card.alt .ico{background:rgba(105,54,245,.14);border-color:rgba(105,54,245,.4);color:var(--purple-soft)}
.card h3{font-family:'Michroma',sans-serif;font-weight:400;font-size:1.05rem;margin-bottom:14px}
.card p{color:var(--dim);font-size:.95rem;max-width:50ch}
.card .tags{display:flex;gap:8px;flex-wrap:wrap;margin-top:22px}
.tag{font-family:'IBM Plex Mono',monospace;font-size:.7rem;letter-spacing:.08em;padding:6px 12px;border-radius:100px;border:1px solid var(--line);color:#B6AED4}
.card ul{list-style:none;margin-top:18px;display:grid;gap:10px}
.card ul li{display:flex;gap:10px;color:#C9C2E4;font-size:.92rem}
.card ul li::before{content:"→";color:var(--orange);flex-shrink:0}

/* ---------- portfolio ---------- */
.work-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.work{
  position:relative;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  background:var(--ink-2);
  transition:transform .35s cubic-bezier(.2,.7,.2,1),border-color .35s,box-shadow .35s;
}
.work:hover{transform:translateY(-6px);border-color:rgba(105,54,245,.55);box-shadow:0 24px 60px -20px rgba(105,54,245,.45)}
.work .shot{position:relative;aspect-ratio:16/8.2;overflow:hidden}
.work .shot img{width:100%;height:100%;object-fit:cover;object-position:top;transition:transform .7s cubic-bezier(.2,.7,.2,1)}
.work:hover .shot img{transform:scale(1.045)}
.work .shot::after{content:"";position:absolute;inset:0;background:linear-gradient(rgba(10,6,20,0) 55%,rgba(10,6,20,.55));pointer-events:none}
.work .info{padding:24px 26px 28px}
.work .info .mono{color:var(--orange-soft);font-size:.7rem;margin-bottom:8px;display:block}
.work h3{font-family:'Michroma',sans-serif;font-weight:400;font-size:1.05rem;margin-bottom:8px}
.work p{color:var(--dim);font-size:.9rem}
.work.feature{grid-column:span 2}
.work.feature .shot{aspect-ratio:16/7}

/* gallery rows inside a case */
.case{border:1px solid var(--line);border-radius:22px;overflow:hidden;background:var(--ink-2);margin-bottom:54px}
.case .case-top{display:grid;grid-template-columns:1.25fr 1fr;gap:0}
.case .case-shot{position:relative;min-height:320px}
.case .case-shot img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:top left}
.case .case-body{padding:clamp(28px,4vw,48px);display:flex;flex-direction:column;justify-content:center}
.case .case-body .mono{color:var(--orange-soft);margin-bottom:14px}
.case h3{font-family:'Michroma',sans-serif;font-weight:400;font-size:clamp(1.1rem,2vw,1.45rem);margin-bottom:14px}
.case p{color:var(--dim);font-size:.96rem}
.case .tags{display:flex;gap:8px;flex-wrap:wrap;margin-top:20px}
.case .thumbs{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border-top:1px solid var(--line)}
.case .thumbs img{width:100%;aspect-ratio:16/7.5;object-fit:cover;object-position:top;background:var(--ink);transition:transform .6s,opacity .3s;cursor:zoom-in}
.case .thumbs a{overflow:hidden;display:block;background:var(--ink)}
.case .thumbs img:hover{transform:scale(1.03);opacity:.92}

/* ---------- reviews (public) ---------- */
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;align-items:start}
.review{border:1px solid var(--line);border-radius:18px;background:var(--ink-2);padding:26px;display:flex;flex-direction:column;gap:14px;transition:transform .35s cubic-bezier(.2,.7,.2,1),border-color .35s}
.review:hover{transform:translateY(-4px);border-color:rgba(245,111,0,.4)}
.review .stars{display:flex;gap:3px;font-size:16px;color:var(--orange)}
.review p{color:#C9C2E4;font-size:.95rem;line-height:1.65;flex:1;margin:0}
/* review image (screenshot) — compact thumbnail, click to view full size.
   Works for portrait OR landscape; never stretches the card. */
.review .shot{width:100%;height:200px;object-fit:cover;object-position:top;background:rgba(0,0,0,.25);border:1px solid var(--line);border-radius:12px;cursor:zoom-in;display:block}
/* lightbox overlay for viewing the full screenshot */
.rv-lightbox{position:fixed;inset:0;background:rgba(5,3,12,.92);display:none;align-items:center;justify-content:center;z-index:9999;padding:30px;cursor:zoom-out;backdrop-filter:blur(4px)}
.rv-lightbox.open{display:flex}
.rv-lightbox img{max-width:92vw;max-height:90vh;border-radius:14px;border:1px solid var(--line);box-shadow:0 30px 80px rgba(0,0,0,.6)}
.rv-lightbox .x{position:absolute;top:22px;right:26px;font-size:34px;color:#fff;cursor:pointer;line-height:1;opacity:.8;font-family:sans-serif}
.rv-lightbox .x:hover{opacity:1}
.review .who{display:flex;align-items:center;gap:12px}
.review .who .ph{width:44px;height:44px;border-radius:12px;flex-shrink:0;background:linear-gradient(135deg,var(--purple),var(--orange));display:grid;place-items:center;font-weight:700;color:#fff}
.review .who b{display:block;font-size:.92rem;font-weight:600}
.review .who span{font-size:.8rem;color:var(--dim)}
.reviews-empty{text-align:center;color:var(--dim);padding:40px;border:1px dashed var(--line);border-radius:18px}
@media(max-width:900px){.reviews-grid{grid-template-columns:1fr}}

/* ---------- team (full-card images) ---------- */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.member{
  position:relative;border:1px solid var(--line);border-radius:20px;overflow:hidden;
  background:var(--ink-2);line-height:0;
  transition:transform .35s cubic-bezier(.2,.7,.2,1),border-color .35s,box-shadow .35s;
}
.member:hover{transform:translateY(-6px);border-color:rgba(245,111,0,.5);box-shadow:0 26px 60px -22px rgba(245,111,0,.4)}
.member img{width:100%;height:auto;display:block;transition:transform .7s cubic-bezier(.2,.7,.2,1)}
.member:hover img{transform:scale(1.04)}

/* ---------- founder story ---------- */
.story{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(28px,5vw,56px);align-items:center}
.story .portrait{position:relative;border:1px solid var(--line);border-radius:22px;overflow:hidden;aspect-ratio:4/5}
.story .portrait img{width:100%;height:100%;object-fit:cover;object-position:center top}
.story .portrait::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,transparent 60%,rgba(105,54,245,.25));pointer-events:none}
.story-body .mono{color:var(--orange-soft);margin-bottom:16px;display:block}
.story-body h2{margin-bottom:22px}
.story-body p{color:#C9C2E4;font-size:1rem;margin-bottom:16px;max-width:56ch}
.story-body p:last-of-type{margin-bottom:0}
.story-body .sign{margin-top:28px;font-family:'Michroma',sans-serif;font-size:.95rem;color:#fff}
.story-body .sign span{display:block;font-family:'IBM Plex Mono',monospace;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--dim);margin-top:6px}

@media(max-width:900px){
  .team-grid{grid-template-columns:1fr}
  .story{grid-template-columns:1fr}
  .story .portrait{max-width:420px}
}

/* ---------- process steps ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.step{padding:36px 28px;border-right:1px solid var(--line);position:relative;transition:background .35s}
.step:last-child{border-right:none}
.step:hover{background:rgba(105,54,245,.07)}
.step .n{font-family:'IBM Plex Mono',monospace;color:var(--orange);font-size:.8rem;letter-spacing:.15em;margin-bottom:46px;display:block}
.step h3{font-family:'Michroma',sans-serif;font-weight:400;font-size:.95rem;margin-bottom:12px}
.step p{color:var(--dim);font-size:.88rem}
.step::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:0;background:linear-gradient(90deg,var(--orange),var(--purple));transition:width .5s cubic-bezier(.2,.7,.2,1)}
.step:hover::after{width:100%}

/* ---------- stats ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.stat{padding:30px 8px;text-align:center;border:1px solid var(--line);border-radius:var(--radius);background:rgba(243,240,255,.02)}
.stat .v{font-family:'Michroma',sans-serif;font-size:clamp(1.5rem,2.8vw,2.1rem);background:linear-gradient(90deg,var(--orange),var(--purple-soft));-webkit-background-clip:text;background-clip:text;color:transparent}
.stat .l{color:var(--dim);font-size:.82rem;margin-top:10px}

/* ---------- marquee ---------- */
.marquee{border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden;padding:20px 0;background:var(--ink-2)}
.marquee-track{display:flex;gap:64px;width:max-content;animation:slide 30s linear infinite;font-family:'IBM Plex Mono',monospace;font-size:.85rem;letter-spacing:.18em;text-transform:uppercase;color:var(--dim);white-space:nowrap}
.marquee-track span b{color:var(--orange);font-weight:500;margin-right:64px}
@keyframes slide{to{transform:translateX(-50%)}}

/* ---------- CTA ---------- */
.cta-box{
  position:relative;border-radius:28px;overflow:hidden;border:1px solid var(--line);
  padding:clamp(56px,8vw,96px) clamp(28px,6vw,80px);text-align:center;
  background:
    radial-gradient(60% 120% at 18% 0%,rgba(105,54,245,.38),transparent 60%),
    radial-gradient(55% 110% at 85% 100%,rgba(245,111,0,.22),transparent 60%),
    var(--ink-2);
}
.cta-box h2{margin:0 auto 18px;max-width:22ch}
.cta-box p{color:#CBC4E6;max-width:52ch;margin:0 auto 38px}
.cta-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* ---------- contact ---------- */
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:24px}
.contact-card{border:1px solid var(--line);border-radius:var(--radius);padding:36px 32px;background:rgba(243,240,255,.025)}
.contact-card h3{font-family:'Michroma',sans-serif;font-weight:400;font-size:1rem;margin-bottom:18px}
.contact-list{list-style:none;display:grid;gap:18px}
.contact-list li{display:flex;gap:16px;align-items:flex-start}
.contact-list .ci{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;flex-shrink:0;background:rgba(245,111,0,.1);border:1px solid rgba(245,111,0,.3);color:var(--orange-soft)}
.contact-list b{display:block;font-weight:500;font-size:.92rem}
.contact-list span{color:var(--dim);font-size:.88rem}
.form-grid{display:grid;gap:14px}
.form-grid label{font-size:.8rem;color:var(--dim);display:block;margin-bottom:6px}
.form-grid input,.form-grid textarea,.form-grid select{
  width:100%;background:rgba(243,240,255,.04);border:1px solid var(--line);border-radius:12px;
  padding:13px 16px;color:var(--paper);font-family:'Sora',sans-serif;font-size:.92rem;
  transition:border-color .25s;
}
.form-grid input:focus,.form-grid textarea:focus,.form-grid select:focus{outline:none;border-color:var(--purple-soft)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}

/* ---------- footer ---------- */
footer{border-top:1px solid var(--line);padding:54px 0 36px;background:var(--ink-2)}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;margin-bottom:42px}
.foot-grid p{color:var(--dim);font-size:.9rem;max-width:38ch;margin-top:16px}
.foot-grid h4{font-family:'IBM Plex Mono',monospace;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--dim);margin-bottom:18px}
.foot-grid ul{list-style:none;display:grid;gap:12px}
.foot-grid ul a{color:#C9C2E4;font-size:.9rem;transition:color .25s}
.foot-grid ul a:hover{color:var(--orange-soft)}
.foot-bottom{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;border-top:1px solid var(--line);padding-top:28px}
.foot-bottom .mono{font-size:.72rem}

/* ---------- reveal ---------- */
.rv{opacity:0;transform:translateY(28px);transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1)}
.rv.in{opacity:1;transform:none}

/* ---------- lightbox ---------- */
.lb{position:fixed;inset:0;z-index:100;background:rgba(10,6,20,.92);backdrop-filter:blur(10px);display:none;align-items:center;justify-content:center;padding:4vw;cursor:zoom-out}
.lb.open{display:flex}
.lb img{max-width:100%;max-height:92vh;border-radius:12px;border:1px solid var(--line);box-shadow:0 40px 120px rgba(0,0,0,.6)}

/* ---------- responsive ---------- */
@media(max-width:960px){
  .nav-links{display:none;position:fixed;inset:0;background:rgba(10,6,20,.97);flex-direction:column;justify-content:center;gap:30px;font-size:1.2rem;z-index:60}
  .nav-links.open{display:flex}
  .nav-links a{font-size:1.25rem}
  .menu-toggle{display:block;z-index:70;position:relative}
  .card-a,.card-b,.card-c,.card-d{grid-column:span 12}
  .work-grid{grid-template-columns:1fr}
  .work.feature{grid-column:span 1}
  .case .case-top{grid-template-columns:1fr}
  .case .case-shot{min-height:230px}
  .steps{grid-template-columns:1fr 1fr}
  .step:nth-child(2n){border-right:none}
  .step:nth-child(-n+2){border-bottom:1px solid var(--line)}
  .stats{grid-template-columns:1fr 1fr}
  .contact-grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr;gap:30px}
}
@media(max-width:560px){
  .steps{grid-template-columns:1fr}
  .step{border-right:none;border-bottom:1px solid var(--line)}
  .step:last-child{border-bottom:none}
  .form-row{grid-template-columns:1fr}
  .case .thumbs{grid-template-columns:1fr}
}
@media(prefers-reduced-motion:reduce){
  .marquee-track{animation:none}
  .rv{transition:none;opacity:1;transform:none}
  html{scroll-behavior:auto}
}
