/* ---------- Base ---------- */
:root{
  --bg: #0c0e0c;
  --bg-soft: #131512;
  --panel: #181a16;
  --line: rgba(241,239,233,0.1);
  --text: #f1efe9;
  --text-dim: #9a9d92;
  --text-faint: #5e615a;
  --accent: #93ad8e;
  --accent-soft: rgba(147,173,142,0.14);
  --serif: 'Fraunces', serif;
  --sans: 'Work Sans', sans-serif;
  --mono: 'IBM Plex Mono', monospace;
  --max: 1640px;
  --radius: 16px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:var(--sans);
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
h1,h2,h3{font-family:var(--serif);font-weight:500;margin:0;letter-spacing:-0.01em;}
p{margin:0;color:var(--text-dim);line-height:1.65;}
em{font-style:italic;color:var(--accent);}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;}

.skip-link{
  position:absolute;top:-60px;left:16px;z-index:100;
  background:var(--accent);color:#0c0e0c;font-family:var(--mono);font-size:0.85rem;
  padding:10px 18px;border-radius:8px;transition:top .25s;
}
.skip-link:focus{top:16px;}

.eyebrow{
  font-family:var(--mono);
  font-size:0.74rem;
  letter-spacing:0.05em;
  color:var(--accent);
  margin:0 0 14px;
  font-weight:400;
}

section{position:relative;padding:130px clamp(20px, 5vw, 72px);width:100%;}

/* Inner content stays centered/contained while the section itself goes full-bleed */
.hero-grid, .trust-inner, .section-head, .service-list,
.work-grid, .work-note, .process-list, .contact-inner{
  max-width:var(--max);margin-left:auto;margin-right:auto;width:100%;
}

/* ---------- Ghost watermark (section background signature) ---------- */
section[data-ghost]{overflow:clip;}
section[data-ghost]{--gx:50%;--gy:0%;}
section[data-ghost]::before{
  content:attr(data-ghost);
  position:absolute;top:50%;right:-2vw;
  transform:translateY(-50%);
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:min(22vw, 16rem);line-height:1;
  color:var(--text);opacity:0.025;
  white-space:nowrap;pointer-events:none;z-index:0;
}
section[data-ghost="Process"]::before, section[data-ghost]:nth-of-type(even)::before{
  right:auto;left:-2vw;
}
section[data-ghost]::after{
  content:'';position:absolute;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(ellipse 60% 50% at var(--gx) var(--gy), var(--accent-soft), transparent 70%);
  opacity:0.5;
  transition:opacity .4s;
}
section[data-ghost] > *{position:relative;z-index:1;}

/* ---------- Noise overlay ---------- */
.noise{
  position:fixed;inset:0;pointer-events:none;z-index:2;opacity:0.025;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='100' height='100'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  mix-blend-mode:overlay;
}

/* ---------- Nav ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  padding:22px clamp(20px, 5vw, 72px);
  transition:background .3s, border-color .3s, padding .3s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(12,14,12,0.8);
  backdrop-filter:blur(14px);
  border-bottom-color:var(--line);
  padding:15px clamp(20px, 5vw, 72px);
}
.nav-inner{
  max-width:var(--max);margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.logo{font-family:var(--serif);font-size:1.2rem;font-weight:500;letter-spacing:-0.01em;white-space:nowrap;}
.logo span{color:var(--accent);}
.nav-links{display:flex;gap:32px;flex:1;justify-content:center;}
.nav-links a{
  font-family:var(--mono);font-size:0.95rem;color:var(--text-dim);
  transition:color .25s;position:relative;padding-bottom:4px;
}
.nav-links a::after{
  content:'';position:absolute;left:0;bottom:0;width:100%;height:1px;
  background:var(--accent);transform:scaleX(0);transform-origin:left;
  transition:transform .35s cubic-bezier(.2,.7,.2,1);
}
.nav-links a:hover, .nav-links a.active{color:var(--text);}
.nav-links a:hover::after, .nav-links a.active::after{transform:scaleX(1);}
.nav-toggle{display:none;background:none;border:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px;}
.nav-toggle span{width:22px;height:1.5px;background:var(--text);display:block;}
.nav-mobile{display:none;flex-direction:column;gap:18px;padding:20px 4px 6px;}
.nav-mobile a{
  font-family:var(--mono);font-size:1rem;color:var(--text-dim);
  border-left:1px solid transparent;padding-left:12px;transition:color .25s, border-color .25s;
}
.nav-mobile a.active{color:var(--text);border-left-color:var(--accent);}

@media (max-width:880px){
  .nav-links, .btn-small{display:none;}
  .nav-toggle{display:flex;}
  .nav-mobile.open{display:flex;}
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  padding:13px 26px;border-radius:8px;font-size:0.9rem;font-weight:500;
  cursor:pointer;border:1px solid transparent;transition:transform .3s, background .3s, color .3s, border-color .3s, gap .3s;
  white-space:nowrap;position:relative;overflow:hidden;isolation:isolate;
}
.btn::after{
  content:'\2192';display:inline-block;opacity:0;transform:translateX(-6px);
  transition:opacity .3s, transform .3s;
}
.btn:hover::after{opacity:1;transform:translateX(0);}
.btn:hover{gap:10px;}
.btn-primary{background:var(--accent);color:#0c0e0c;}
.btn-primary::before{
  content:'';position:absolute;inset:0;z-index:-1;
  background:linear-gradient(115deg, transparent 30%, rgba(255,255,255,0.35) 50%, transparent 70%);
  transform:translateX(-100%);transition:transform .6s ease;
}
.btn-primary:hover::before{transform:translateX(100%);}
.btn-primary:hover{transform:translateY(-2px);}
.btn-ghost{border-color:var(--line);color:var(--text);}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent);}
.btn-small{padding:10px 20px;font-size:0.84rem;}
.btn-small::after{display:none;}
.btn-full{width:100%;}

/* ---------- Hero ---------- */
.hero{
  min-height:100vh;display:flex;align-items:center;
  padding:170px clamp(20px, 5vw, 72px) 90px;position:relative;overflow:clip;
  --gx:78%;--gy:35%;
}
.hero::before{
  content:'Studio';
  position:absolute;bottom:-4vw;left:-2vw;
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:min(20vw, 14rem);line-height:1;color:var(--text);
  opacity:0.025;white-space:nowrap;pointer-events:none;z-index:0;
}
.hero::after{
  content:'';position:absolute;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(ellipse 70% 55% at var(--gx) var(--gy), var(--accent-soft), transparent 65%);
  transition:opacity .4s;
}
.hero-grid{position:relative;z-index:1;}
.hero-grid{
  display:grid;grid-template-columns:1.1fr 0.9fr;gap:64px;align-items:center;width:100%;
}
.hero-title{font-size:clamp(2.6rem, 4.6vw, 4rem);line-height:1.08;}
.hero-sub{max-width:440px;margin:26px 0 0;font-size:1.02rem;}
.hero-cta{margin-top:38px;display:flex;gap:16px;flex-wrap:wrap;}

/* One-time hero load sequence (not scroll-triggered) */
.line-mask{display:block;overflow:hidden;}
.line-inner{display:block;transform:translateY(112%);transition:transform 1s cubic-bezier(.16,1,.3,1);}
.hero.is-loaded .line-inner{transform:translateY(0);}
.hero.is-loaded .line-mask:nth-of-type(1) .line-inner{transition-delay:.05s;}
.hero.is-loaded .line-mask:nth-of-type(2) .line-inner{transition-delay:.16s;}
.hero.is-loaded .line-mask:nth-of-type(3) .line-inner{transition-delay:.27s;}

.hero-load{opacity:0;transform:translateY(16px);transition:opacity .8s cubic-bezier(.2,.7,.2,1), transform .8s cubic-bezier(.2,.7,.2,1);}
.hero.is-loaded .hero-load{opacity:1;transform:translateY(0);}
.hero.is-loaded .hero-load-1{transition-delay:0s;}
.hero.is-loaded .hero-load-5{transition-delay:.4s;}
.hero.is-loaded .hero-load-6{transition-delay:.5s;}
.hero-load-7{transform:translateY(16px) scale(0.97);}
.hero.is-loaded .hero-load-7{transform:translateY(0) scale(1);transition-delay:.3s;}

/* Signature element: browser mockup with a drawing cursor */
.hero-mock{
  background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;box-shadow:0 40px 80px -40px rgba(0,0,0,0.6);
}
.mock-bar{
  display:flex;align-items:center;gap:8px;padding:14px 16px;border-bottom:1px solid var(--line);
}
.mock-dot{width:8px;height:8px;border-radius:50%;background:var(--text-faint);}
.mock-url{
  font-family:var(--mono);font-size:0.74rem;color:var(--text-faint);
  margin-left:10px;
}
.mock-canvas{
  position:relative;padding:22px;display:grid;grid-template-columns:1fr 1fr;
  grid-template-rows:auto auto;gap:14px;min-height:300px;
}
.mock-block{background:var(--bg-soft);border:1px solid var(--line);border-radius:8px;}
.mock-block--nav{grid-column:1 / -1;height:28px;}
.mock-block--hero{grid-column:1 / -1;height:90px;background:var(--accent-soft);border-color:rgba(147,173,142,0.25);}
.mock-block--a, .mock-block--b{height:70px;}
.mock-cursor{
  position:absolute;width:14px;height:14px;
  border:1.5px solid var(--accent);border-radius:50%;
  background:rgba(147,173,142,0.25);
  pointer-events:none;
  transition:left 1.4s cubic-bezier(.4,0,.2,1), top 1.4s cubic-bezier(.4,0,.2,1);
}

/* ---------- Trust strip ---------- */
.trust{padding:50px clamp(20px, 5vw, 72px);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.trust-stats{
  display:flex;justify-content:center;align-items:center;flex-wrap:wrap;
  font-family:var(--mono);font-size:0.82rem;color:var(--text-faint);
}
.trust-stats span{padding:4px 22px;position:relative;}
.trust-stats span:not(:last-child)::after{
  content:'';position:absolute;right:0;top:50%;transform:translateY(-50%);
  width:1px;height:14px;background:var(--line);
}
@media (max-width:520px){
  .trust-stats span:not(:last-child)::after{display:none;}
  .trust-stats span{padding:4px 0;width:100%;text-align:center;}
}

/* ---------- Section heads ---------- */
.section-head{margin-bottom:64px;}
.section-head h2{font-size:clamp(2rem, 3.6vw, 2.6rem);line-height:1.15;max-width:560px;}

/* ---------- Services ---------- */
.service-list{display:flex;flex-direction:column;}
.service-row{
  display:grid;grid-template-columns:90px 220px 1fr;gap:24px;align-items:baseline;
  padding:30px 0 30px 22px;border-top:1px solid var(--line);
  position:relative;transition:padding-left .4s cubic-bezier(.2,.7,.2,1);
}
.service-row::before{
  content:'';position:absolute;left:0;top:30px;bottom:30px;width:1.5px;
  background:var(--accent);transform:scaleY(0);transform-origin:top;
  transition:transform .45s cubic-bezier(.2,.7,.2,1);
}
.service-row:last-child{border-bottom:1px solid var(--line);}
.service-row:hover{padding-left:34px;}
.service-row:hover::before{transform:scaleY(1);}
.service-tag{
  font-family:var(--mono);font-size:0.78rem;color:var(--text-faint);
  transition:color .35s;
}
.service-row:hover .service-tag{color:var(--accent);}
.service-row h3{font-size:1.3rem;transition:transform .4s cubic-bezier(.2,.7,.2,1);}
.service-row:hover h3{transform:translateX(4px);}
.service-row p{max-width:480px;}

/* ---------- Work ---------- */
.work-grid{
  display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(2,1fr);gap:20px;
}
.work-card{
  border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);background:var(--bg-soft);
  transition:transform .4s cubic-bezier(.2,.7,.2,1), border-color .4s;position:relative;cursor:pointer;
}
.work-card:hover{transform:translateY(-5px);border-color:var(--accent);}
.work-card--feature{grid-column:1 / 3;grid-row:1 / 3;}
.work-card:not(.work-card--feature):nth-of-type(2){grid-column:3;grid-row:1;}
.work-card:not(.work-card--feature):nth-of-type(3){grid-column:3;grid-row:2;}
.work-thumb{height:100%;min-height:140px;position:relative;overflow:hidden;transform:scale(1);transition:transform .7s cubic-bezier(.2,.7,.2,1);}
.work-card--feature .work-thumb{min-height:280px;}
.work-thumb::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg, transparent 40%, rgba(0,0,0,0.3));transition:opacity .4s;}
.work-card:hover .work-thumb{transform:scale(1.03);}
.work-view{
  position:absolute;top:0;left:0;
  font-family:var(--mono);font-size:0.74rem;color:#0c0e0c;background:var(--accent);
  padding:8px 14px;border-radius:100px;pointer-events:none;
  opacity:0;transform:translate(-50%,-50%) scale(0.8);
  transition:opacity .25s, transform .25s;z-index:2;white-space:nowrap;
}
.work-card:hover .work-view{opacity:1;transform:translate(-50%,-50%) scale(1);}

/* Per-project mini browser mockup, standing in for real screenshots */
.work-mock{background:var(--bg-soft);display:flex;flex-direction:column;}
.work-mock-bar{display:flex;gap:5px;padding:10px 12px;border-bottom:1px solid var(--line);flex-shrink:0;}
.work-mock-bar span{width:6px;height:6px;border-radius:50%;background:var(--text-faint);opacity:0.5;}
.work-mock-canvas{
  flex:1;padding:16px;display:grid;grid-template-columns:1fr 1fr;
  grid-template-rows:auto 1.4fr 1fr;gap:8px;
}
.work-mock-block{border-radius:6px;}
.wmb-nav{grid-column:1 / -1;height:12px;background:var(--wa1);opacity:0.55;}
.wmb-hero{grid-column:1 / -1;background:var(--wa2);opacity:0.65;}
.wmb-a{background:var(--wa1);opacity:0.4;}
.wmb-b{background:var(--wa2);opacity:0.4;}

.work-card{display:flex;flex-direction:column;}
.work-thumb{flex:1;}
.work-meta{padding:20px 22px;display:flex;justify-content:space-between;align-items:baseline;}
.work-meta h3{font-size:1.1rem;display:flex;align-items:center;gap:8px;}
.work-meta p{font-size:0.82rem;color:var(--text-faint);font-family:var(--mono);}
.work-note{margin-top:28px;font-size:0.82rem;color:var(--text-faint);text-align:center;font-family:var(--mono);}
.work-arrow{
  display:inline-block;color:var(--accent);opacity:0;transform:translate(-3px,3px);
  transition:opacity .3s, transform .3s;font-size:0.85em;
}
.work-card:hover .work-arrow{opacity:1;transform:translate(0,0);}

/* ---------- Process ---------- */
.process-list{display:flex;flex-direction:column;position:relative;padding-left:8px;}
.process-list::before{
  content:'';position:absolute;left:32px;top:8px;bottom:8px;width:1px;background:var(--line);
}
.process-item{
  display:flex;gap:32px;padding:30px 0;align-items:flex-start;position:relative;
}
.process-index{
  font-family:var(--mono);color:var(--accent);font-size:0.85rem;min-width:48px;
  background:var(--bg);position:relative;z-index:1;
}
.process-item h3{font-size:1.2rem;margin-bottom:8px;}
.process-item p{max-width:520px;}

/* ---------- Contact ---------- */
.contact-inner{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start;}
.contact-inner h2{font-size:clamp(2rem,3.6vw,2.4rem);margin:10px 0 16px;}
.contact-sub{max-width:420px;}
.contact-details{display:flex;gap:48px;margin-top:40px;}
.contact-details span{font-family:var(--mono);font-size:0.74rem;color:var(--text-faint);}
.contact-details p{color:var(--text);margin-top:6px;}

.contact-form{
  background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--radius);padding:36px;
  display:flex;flex-direction:column;gap:18px;
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.contact-form label{display:flex;flex-direction:column;gap:8px;font-size:0.85rem;color:var(--text-dim);}
.contact-form input, .contact-form select, .contact-form textarea{
  background:#0c0e0c;border:1px solid var(--line);border-radius:8px;padding:12px 14px;
  color:var(--text);font-family:var(--sans);font-size:0.95rem;outline:none;
  transition:border-color .2s;resize:vertical;
}
.contact-form input:focus, .contact-form select:focus, .contact-form textarea:focus{border-color:var(--accent);}
.form-status{font-family:var(--mono);font-size:0.82rem;color:var(--accent);min-height:1em;}

/* ---------- Footer ---------- */
.footer{border-top:1px solid var(--line);padding:36px clamp(20px, 5vw, 72px);}
.footer-inner{max-width:var(--max);margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;}
.footer-inner p{font-size:0.82rem;color:var(--text-faint);font-family:var(--mono);}

/* ---------- Reveal animation ---------- */
.reveal{
  opacity:0;transform:translateY(22px) scale(0.985);filter:blur(6px);
  transition:opacity .9s cubic-bezier(.2,.7,.2,1), transform .9s cubic-bezier(.2,.7,.2,1), filter .9s cubic-bezier(.2,.7,.2,1);
}
.reveal.in{opacity:1;transform:translateY(0) scale(1);filter:blur(0);}

/* ---------- Responsive ---------- */
@media (max-width:900px){
  .hero-grid{grid-template-columns:1fr;}
  .hero-mock{order:-1;max-width:420px;}
  .service-row{grid-template-columns:1fr;gap:10px;}
}
@media (max-width:880px){
  section{padding:90px 20px;}
  .work-grid{grid-template-columns:1fr;grid-template-rows:none;}
  .work-card--feature{grid-column:1;grid-row:auto;}
  .work-card:not(.work-card--feature):nth-of-type(2),
  .work-card:not(.work-card--feature):nth-of-type(3){grid-column:1;grid-row:auto;}
  .contact-inner{grid-template-columns:1fr;gap:40px;}
  .form-row{grid-template-columns:1fr;}
  .hero{padding-top:140px;}
  .process-list::before{left:24px;}
}
@media (max-width:520px){
  .mock-canvas{min-height:220px;padding:14px;gap:10px;}
  .mock-cursor{display:none;}
  .hero-mock{max-width:100%;}
}

/* ---------- Touch devices: swap hover affordances for always-visible ones ---------- */
@media (hover: none){
  .work-view{display:none;}
  .work-arrow{opacity:1;transform:none;}
  .service-row{padding-left:34px;}
  .service-row::before{transform:scaleY(1);opacity:0.6;}
  .service-row .service-tag{color:var(--accent);}
  .work-card:hover{transform:none;}
  .work-card:hover .work-thumb{transform:none;}
}

@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto;}
  .mock-cursor{transition:none;}
  .reveal{transition:none;opacity:1;transform:none;}
  .line-inner{transition:none;transform:none;}
  .hero-load{transition:none;opacity:1;transform:none;}
}
