/* ═══════════════════════════════════════════════
   DEV DESIGNS — style.css  v4
   ★ LIGHT THEME  — Warm Ivory × Antique Gold × Navy
   ★ MOBILE-FIRST — Touch-optimized layout
═══════════════════════════════════════════════ */

/* ══════════════════════════════════════
   LIGHT COLOR PALETTE
   Old: Dark navy-charcoal bg
   New: Warm ivory bg, navy text, gold accents
══════════════════════════════════════ */
:root {
  --bg:          #f7f3ec;          /* warm ivory parchment           */
  --surface:     #ede8df;          /* slightly deeper ivory           */
  --glass:       rgba(255,255,255,0.60);
  --border:      rgba(30,25,20,0.10);
  --border-hi:   rgba(160,120,50,0.40);   /* gold border highlight    */
  --accent:      #b8922a;          /* antique gold — formal           */
  --accent-2:    #d4a83c;          /* lighter warm gold               */
  --accent-dim:  rgba(184,146,42,0.08);
  --accent-glow: rgba(184,146,42,0.06);
  --accent-hi:   rgba(184,146,42,0.22);
  --white:       #1a1612;          /* near-black for primary text     */
  --muted:       #9a948a;          /* mid warm grey                   */
  --muted-hi:    #5c5650;          /* slightly darker muted           */
  --ease:        cubic-bezier(0.76,0,0.24,1);
  --ease-out:    cubic-bezier(0.22,1,0.36,1);
  --ease-spring: cubic-bezier(0.34,1.56,0.64,1);
  --font-display:'Cormorant Garamond', serif;
  --font-body:   'Outfit', sans-serif;

  /* Shadow tokens for light theme */
  --shadow-sm:   0 2px 8px rgba(30,25,20,0.08);
  --shadow-md:   0 8px 28px rgba(30,25,20,0.10);
  --shadow-lg:   0 20px 60px rgba(30,25,20,0.13);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px}
body{
  background:var(--bg);
  color:var(--white);
  font-family:var(--font-body);
  font-weight:300;
  overflow:hidden;
  width:100vw;
  height:100dvh;   /* dvh for mobile browsers */
  cursor:none;
}
/* Paper texture overlay */
body::after{
  content:'';
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:10000;
  opacity:.025;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");
}
a{text-decoration:none;color:inherit}
button{cursor:none}
input,textarea,select{font-family:var(--font-body)}

/* ── CUSTOM CURSOR (desktop only) ── */
#cursor{
  position:fixed;width:8px;height:8px;
  background:var(--accent);border-radius:50%;
  pointer-events:none;z-index:9999;
  transform:translate(-50%,-50%);
  transition:width .25s var(--ease-spring),height .25s var(--ease-spring),background .3s;
}
#cursor-ring{
  position:fixed;width:34px;height:34px;
  border:1px solid rgba(184,146,42,.4);border-radius:50%;
  pointer-events:none;z-index:9998;
  transform:translate(-50%,-50%);
  transition:width .4s var(--ease-out),height .4s var(--ease-out),border-color .3s;
}
body:has(a:hover) #cursor,
body:has(button:hover) #cursor{width:13px;height:13px;background:var(--muted-hi)}
body:has(a:hover) #cursor-ring,
body:has(button:hover) #cursor-ring{width:52px;height:52px;border-color:var(--border-hi)}

::-webkit-scrollbar{width:3px}
::-webkit-scrollbar-track{background:var(--surface)}
::-webkit-scrollbar-thumb{background:rgba(184,146,42,.22);border-radius:2px}

/* ── PAGE TRANSITION ── */
#trans{position:fixed;inset:0;z-index:8000;display:flex;pointer-events:none}
.trans-half{width:50%;height:100%;background:var(--bg);transform:scaleX(0)}
.trans-half:first-child{transform-origin:left}
.trans-half:last-child{transform-origin:right}
#trans.active{pointer-events:all}
#trans.active .trans-half{animation:transIn .6s var(--ease) forwards}
#trans.out .trans-half{animation:transOut .6s var(--ease) forwards .3s}
@keyframes transIn{to{transform:scaleX(1)}}
@keyframes transOut{to{transform:scaleX(0)}}

/* ── ENTRANCE / DOOR ── */
#entrance{
  position:fixed;inset:0;z-index:7000;
  display:flex;align-items:center;justify-content:center;
  background:var(--bg);overflow:hidden;
}
#entrance::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse 55% 50% at 50% 50%,rgba(184,146,42,.07) 0%,transparent 70%),
    repeating-linear-gradient(0deg,transparent,transparent 59px,var(--border) 60px),
    repeating-linear-gradient(90deg,transparent,transparent 59px,var(--border) 60px);
}
.door{position:absolute;top:0;bottom:0;width:50%;background:var(--surface);transition:transform 1.4s var(--ease);z-index:1}
.door-l{
  left:0;transform-origin:left center;
  border-right:1px solid var(--border);
  background:
    linear-gradient(to right,var(--surface) 85%,rgba(184,146,42,.04) 100%),
    repeating-linear-gradient(90deg,transparent,transparent 39px,var(--border) 40px);
}
.door-r{
  right:0;transform-origin:right center;
  border-left:1px solid var(--border);
  background:
    linear-gradient(to left,var(--surface) 85%,rgba(184,146,42,.04) 100%),
    repeating-linear-gradient(90deg,transparent,transparent 39px,var(--border) 40px);
}
.door-l::before{content:'';position:absolute;top:0;bottom:0;right:0;width:1px;background:linear-gradient(to bottom,transparent,var(--border-hi),transparent)}
.door-r::before{content:'';position:absolute;top:0;bottom:0;left:0;width:1px;background:linear-gradient(to bottom,transparent,var(--border-hi),transparent)}
#entrance.open .door-l{transform:perspective(1200px) rotateY(-105deg)}
#entrance.open .door-r{transform:perspective(1200px) rotateY(105deg)}

.enter-ui{
  position:relative;z-index:2;
  display:flex;flex-direction:column;align-items:center;
  text-align:center;gap:1.2rem;
  animation:enterFadeIn 1s var(--ease-out) .3s both;
  padding:1.5rem;
}
@keyframes enterFadeIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}

.enter-emblem{
  width:72px;height:72px;
  border:1px solid var(--border-hi);
  display:flex;align-items:center;justify-content:center;
  font-size:1.8rem;color:var(--accent);position:relative;
  background:rgba(255,255,255,0.5);
  box-shadow:var(--shadow-sm);
  animation:emblemPulse 3s ease-in-out infinite;
}
.enter-emblem::before,.enter-emblem::after{
  content:'';position:absolute;
  border:1px solid rgba(184,146,42,.15);
  width:calc(100% + 16px);height:calc(100% + 16px);
  animation:emblemRing 3s ease-in-out infinite;
}
.enter-emblem::after{width:calc(100% + 32px);height:calc(100% + 32px);animation-delay:.4s}
@keyframes emblemPulse{0%,100%{box-shadow:var(--shadow-sm)}50%{box-shadow:0 0 30px 4px rgba(184,146,42,.18),var(--shadow-sm)}}
@keyframes emblemRing{0%,100%{opacity:.4;transform:scale(1)}50%{opacity:.1;transform:scale(1.05)}}

.enter-brand{font-family:var(--font-display);font-size:clamp(2rem,6vw,4rem);font-weight:300;letter-spacing:.15em;color:var(--white);line-height:1}
.enter-brand em{font-style:italic;color:var(--accent)}
.enter-tagline{font-size:.65rem;letter-spacing:.4em;color:var(--muted);text-transform:uppercase}
.enter-divider{width:4rem;height:1px;background:linear-gradient(to right,transparent,var(--accent),transparent);opacity:.5}

.enter-btn{
  display:flex;align-items:center;gap:.75rem;
  font-family:var(--font-body);font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;
  color:#fff;background:var(--accent);border:none;
  padding:1rem 2.5rem;position:relative;overflow:hidden;
  transition:all .4s var(--ease);
  box-shadow:0 4px 18px rgba(184,146,42,.25);
  -webkit-tap-highlight-color:transparent;
}
.enter-btn::before{content:'';position:absolute;inset:0;background:var(--accent-2);transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.enter-btn:hover::before,.enter-btn:active::before{transform:scaleX(1)}
.enter-btn span,.enter-btn i{position:relative;z-index:1}
.enter-btn:hover{transform:translateY(-2px);box-shadow:0 12px 32px rgba(184,146,42,.32)}

.enter-scan{display:flex;align-items:center;gap:.6rem;font-size:.6rem;letter-spacing:.2em;color:var(--muted);text-transform:uppercase}
.scan-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);animation:scanBlink 1.8s ease-in-out infinite}
@keyframes scanBlink{0%,100%{opacity:1}50%{opacity:.2}}

/* ── SITE SHELL ── */
#site{position:fixed;inset:0;opacity:0;visibility:hidden;transition:opacity .6s var(--ease-out),visibility .6s}
#site.visible{opacity:1;visibility:visible}

/* ── HEADER ── */
#header{
  position:fixed;top:0;left:0;right:0;z-index:500;height:64px;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 2.5rem;
  background:rgba(247,243,236,.88);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
  box-shadow:var(--shadow-sm);
}
.h-logo{height:36px;display:flex;align-items:center}
.h-logo img{height:100%;width:auto;object-fit:contain}
.h-center{position:absolute;left:50%;transform:translateX(-50%);display:flex;align-items:center;gap:.75rem;font-size:.65rem;letter-spacing:.2em;text-transform:uppercase}
.h-section-name{color:var(--white);font-weight:400}
.h-sep{color:var(--muted)}
#hSecSub{color:var(--muted)}
.h-right{display:flex;flex-direction:column;align-items:flex-end;gap:6px}
.h-counter{font-size:.6rem;letter-spacing:.3em;color:var(--muted-hi)}
.h-progress{width:80px;height:1px;background:var(--border);overflow:hidden}
.h-progress-fill{height:100%;background:var(--accent);transition:width .6s var(--ease)}

/* ── DOT NAV ── */
#dotnav{
  position:fixed;right:2rem;top:50%;transform:translateY(-50%);
  z-index:400;display:flex;flex-direction:column;align-items:center;gap:14px;
}
.dot{
  width:6px;height:6px;border-radius:50%;
  background:rgba(30,25,20,.2);cursor:pointer;position:relative;
  transition:all .4s var(--ease-spring);
  -webkit-tap-highlight-color:transparent;
}
.dot::before{
  content:attr(data-label);position:absolute;
  right:18px;top:50%;transform:translateY(-50%) translateX(6px);
  font-size:.55rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--muted);white-space:nowrap;opacity:0;pointer-events:none;
  transition:opacity .3s,transform .3s var(--ease-out);
}
#dotnav:hover .dot::before{opacity:1;transform:translateY(-50%) translateX(0)}
.dot:hover{background:var(--muted-hi);transform:scale(1.4)}
.dot.active{background:var(--accent);transform:scale(1.5);box-shadow:0 0 12px rgba(184,146,42,.45)}
.dot.active::before{color:var(--accent);opacity:1;transform:translateY(-50%) translateX(0)}

/* ── SECTIONS ── */
#sections{position:fixed;inset:0;top:64px;overflow:hidden}
.sec{
  position:absolute;inset:0;
  overflow-y:auto;overflow-x:hidden;
  opacity:0;visibility:hidden;
  transform:translateY(40px) scale(.98);
  transition:opacity .7s var(--ease-out),transform .7s var(--ease-out),visibility .7s;
  scrollbar-width:thin;scrollbar-color:rgba(184,146,42,.18) transparent;
  -webkit-overflow-scrolling:touch;
}
.sec.active{opacity:1;visibility:visible;transform:translateY(0) scale(1)}
.sec.exit-up{opacity:0;visibility:hidden;transform:translateY(-40px) scale(.98)}

.sec-wrap{
  min-height:calc(100dvh - 64px);
  padding:5rem 6rem 4rem;
  display:flex;flex-direction:column;justify-content:center;
}
.sec-label{
  font-size:.6rem;letter-spacing:.4em;text-transform:uppercase;
  color:var(--accent);margin-bottom:1rem;
  display:flex;align-items:center;gap:.8rem;
}
.sec-label::before{content:'';display:inline-block;width:2rem;height:1px;background:var(--accent);opacity:.6}
.sec-title{
  font-family:var(--font-display);
  font-size:clamp(2rem,4vw,3.5rem);
  font-weight:300;line-height:1.05;letter-spacing:-.02em;
  color:var(--white);margin-bottom:2.5rem;
}
.sec-title em{font-style:italic;color:var(--accent)}

/* ── REVEAL ANIMATIONS ── */
.ri{opacity:0;transform:translateY(24px);transition:opacity .7s var(--ease-out),transform .7s var(--ease-out)}
.ri.show{opacity:1;transform:translateY(0)}
.d0{transition-delay:0s}.d1{transition-delay:.08s}.d2{transition-delay:.16s}
.d3{transition-delay:.24s}.d4{transition-delay:.32s}.d5{transition-delay:.40s}
.d6{transition-delay:.48s}.d7{transition-delay:.56s}

/* ── BUTTONS ── */
.btn-g{
  display:inline-flex;align-items:center;gap:.6rem;
  font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;
  padding:.85rem 2rem;position:relative;overflow:hidden;
  transition:all .4s var(--ease);
  -webkit-tap-highlight-color:transparent;
}
.btn-g::after{content:'';position:absolute;inset:0;transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.btn-g:hover::after,.btn-g:active::after{transform:scaleX(1)}
.btn-g i,.btn-g span{position:relative;z-index:1}

.btn-solid{background:var(--accent);color:#fff;border:none;box-shadow:0 4px 16px rgba(184,146,42,.25)}
.btn-solid::after{background:var(--accent-2)}
.btn-solid:hover{transform:translateY(-3px);box-shadow:0 12px 32px rgba(184,146,42,.32)}

.btn-outline{background:transparent;color:var(--muted-hi);border:1px solid var(--border)}
.btn-outline::after{background:var(--accent-dim)}
.btn-outline:hover{border-color:var(--border-hi);color:var(--accent)}

/* ════════════════════════════════════
   S0 · HOME
════════════════════════════════════ */
#s0 .sec-wrap{
  position:relative;overflow:hidden;
  padding-top:0;padding-bottom:0;
  justify-content:flex-end;
  min-height:calc(100dvh - 64px);
}
.home-bg{
  position:absolute;inset:0;
  background-image:url('https://images.unsplash.com/photo-1486325212027-8081e485255e?w=1800&q=80');
  background-size:cover;background-position:center 30%;
  transform:scale(1.04);transition:transform 10s var(--ease-out);
  filter:brightness(.75) saturate(.55);
}
#s0.active .home-bg{transform:scale(1)}
.home-bg::before{
  content:'';position:absolute;inset:0;
  background:
    linear-gradient(to right,rgba(247,243,236,.97) 0%,rgba(247,243,236,.55) 55%,rgba(247,243,236,.15) 100%),
    linear-gradient(to top,rgba(247,243,236,.99) 0%,transparent 55%);
}
.home-bg::after{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 70% 60% at 65% 40%,rgba(184,146,42,.06) 0%,transparent 70%);
}
.home-grid-lines{
  position:absolute;inset:0;pointer-events:none;z-index:1;
  background:
    repeating-linear-gradient(0deg,transparent,transparent 79px,rgba(184,146,42,.06) 80px),
    repeating-linear-gradient(90deg,transparent,transparent 79px,rgba(184,146,42,.06) 80px);
  mask-image:radial-gradient(ellipse 65% 80% at 15% 55%,black 0%,transparent 75%);
}
.home-kicker,.home-h1,.home-sub,.home-actions,.home-stats,.home-scroll-hint{position:relative;z-index:2}
.home-kicker{font-size:.62rem;letter-spacing:.35em;text-transform:uppercase;color:var(--accent);display:flex;align-items:center;gap:.6rem;margin-bottom:1.5rem;padding-top:4rem}
.home-h1{font-family:var(--font-display);font-size:clamp(2.6rem,6.5vw,6.5rem);font-weight:300;line-height:.95;letter-spacing:-.03em;color:var(--white);margin-bottom:1.5rem;max-width:13ch}
.home-h1 em{font-style:italic;color:var(--accent)}
.home-sub{
  font-size:.95rem;color:rgba(26,22,18,.58);line-height:1.8;
  max-width:44ch;margin-bottom:2.5rem;font-weight:300;
  border-left:2px solid var(--border-hi);padding-left:1.2rem;
}
.home-actions{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:3rem}
.home-stats{
  display:flex;flex-wrap:wrap;
  border-top:1px solid rgba(184,146,42,.18);
  padding:1.8rem 0 3rem;gap:0;
}
.hstat{padding:0 2.5rem 0 0;margin-right:2.5rem;border-right:1px solid var(--border)}
.hstat:last-child{border-right:none;margin-right:0;padding-right:0}
.hstat-num{font-family:var(--font-display);font-size:2.8rem;font-weight:500;color:var(--white);line-height:1;letter-spacing:-.02em}
.hstat-num sup{font-size:1rem;color:var(--accent);vertical-align:top;margin-top:.4rem}
.hstat-lbl{font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-top:.3rem}
.home-scroll-hint{
  position:absolute;bottom:2.5rem;left:6rem;z-index:2;
  display:flex;align-items:center;gap:.6rem;font-size:.6rem;
  letter-spacing:.25em;text-transform:uppercase;color:rgba(184,146,42,.6);
}
.home-scroll-hint i{animation:bounceDown 1.8s ease-in-out infinite;color:var(--accent)}
@keyframes bounceDown{0%,100%{transform:translateY(0)}50%{transform:translateY(5px)}}

/* ════════════════════════════════════
   S1 · ABOUT
════════════════════════════════════ */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.about-features{display:flex;flex-direction:column;gap:.8rem;margin-top:2rem}
.af-item{
  display:flex;align-items:center;gap:1rem;
  padding:.8rem 1.2rem;
  border:1px solid var(--border);
  background:var(--glass);backdrop-filter:blur(8px);
  box-shadow:var(--shadow-sm);
  transition:all .4s var(--ease);position:relative;overflow:hidden;
}
.af-item::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--accent);transform:scaleY(0);transform-origin:bottom;transition:transform .4s var(--ease)}
.af-item:hover,.af-item:active{border-color:var(--border-hi);background:rgba(255,255,255,.8)}
.af-item:hover::before{transform:scaleY(1)}
.af-icon{color:var(--accent);font-size:.9rem;flex-shrink:0}
.af-text{font-size:.82rem;color:var(--muted-hi)}
.about-visual{position:relative;height:340px;display:flex;align-items:center;justify-content:center;perspective:800px}
.av-ring{position:absolute;border-radius:50%;border:1px solid var(--border)}
.avr1{width:280px;height:280px;border-color:rgba(184,146,42,.12);animation:ringRotate 12s linear infinite}
.avr2{width:200px;height:200px;border-color:rgba(184,146,42,.22);animation:ringRotate 8s linear infinite reverse;border-style:dashed}
.avr3{width:120px;height:120px;border-color:rgba(184,146,42,.35);animation:ringRotate 5s linear infinite}
@keyframes ringRotate{from{transform:rotate3d(1,.5,.2,0deg)}to{transform:rotate3d(1,.5,.2,360deg)}}
.av-center{
  width:72px;height:72px;
  background:rgba(255,255,255,.7);
  border:1px solid var(--border-hi);
  border-radius:50%;z-index:2;
  display:flex;align-items:center;justify-content:center;
  font-size:1.6rem;color:var(--accent);
  box-shadow:0 0 40px rgba(184,146,42,.18),var(--shadow-md);
  animation:centerPulse 3s ease-in-out infinite;
}
@keyframes centerPulse{0%,100%{transform:scale(1);box-shadow:0 0 40px rgba(184,146,42,.18),var(--shadow-md)}50%{transform:scale(1.05);box-shadow:0 0 60px rgba(184,146,42,.28),var(--shadow-md)}}
.av-pills{position:absolute;inset:0;pointer-events:none}
.av-pill{
  position:absolute;display:flex;align-items:center;gap:.4rem;
  font-size:.62rem;letter-spacing:.15em;color:var(--accent);
  background:rgba(255,255,255,.85);
  border:1px solid var(--border-hi);
  padding:.4rem .8rem;white-space:nowrap;
  box-shadow:var(--shadow-sm);
  animation:pillFloat 4s ease-in-out infinite;
}
.av-pill i{font-size:.65rem}
.avp1{top:5%;left:calc(50% - 50px);animation-delay:0s}
.avp2{top:calc(50% - 13px);right:-20px;animation-delay:1s}
.avp3{bottom:5%;left:calc(50% - 50px);animation-delay:2s}
.avp4{top:calc(50% - 13px);left:-20px;animation-delay:1.5s}
@keyframes pillFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}

/* ════════════════════════════════════
   S2 · SERVICES
════════════════════════════════════ */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.svc-card{
  background:var(--glass);backdrop-filter:blur(8px);
  border:1px solid var(--border);
  padding:2rem 1.8rem;position:relative;overflow:hidden;
  box-shadow:var(--shadow-sm);
  transition:border-color .4s var(--ease),background .4s var(--ease),box-shadow .4s;
  cursor:pointer;-webkit-tap-highlight-color:transparent;
}
.svc-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(to right,transparent,var(--accent),transparent);
  opacity:0;transform:scaleX(0);transition:opacity .4s,transform .4s var(--ease);
}
.svc-card:hover,.svc-card:active{border-color:var(--border-hi);background:rgba(255,255,255,.85);box-shadow:var(--shadow-md)}
.svc-card:hover::before{opacity:1;transform:scaleX(1)}
.svc-num{font-family:var(--font-display);font-size:4rem;font-weight:300;line-height:1;color:rgba(30,25,20,.07);position:absolute;top:1rem;right:1.5rem;transition:color .4s;letter-spacing:-.02em}
.svc-card:hover .svc-num{color:rgba(184,146,42,.15)}
.svc-icon-wrap{width:44px;height:44px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:var(--accent);margin-bottom:1.2rem;background:rgba(255,255,255,.6);transition:all .4s var(--ease-spring)}
.svc-card:hover .svc-icon-wrap{background:rgba(184,146,42,.08);border-color:var(--border-hi);transform:rotate(10deg) scale(1.1)}
.svc-title{font-size:.92rem;font-weight:500;color:var(--white);margin-bottom:.6rem}
.svc-desc{font-size:.78rem;color:var(--muted);line-height:1.7;margin-bottom:1.5rem}
.svc-more{font-size:.6rem;letter-spacing:.25em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:.5rem;transition:all .3s var(--ease)}
.svc-more i{font-size:.65rem;transition:transform .3s var(--ease)}
.svc-card:hover .svc-more{color:var(--accent)}
.svc-card:hover .svc-more i{transform:translateX(4px)}

/* ════════════════════════════════════
   S3 · PROJECTS
════════════════════════════════════ */
.sec-wrap-projects{min-height:calc(100dvh - 64px);padding:5rem 6rem 3rem}
.projects-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(2,240px);gap:1px;background:var(--border);border:1px solid var(--border)}
.proj{position:relative;overflow:hidden;background:var(--surface);cursor:pointer;-webkit-tap-highlight-color:transparent}
.proj-bg{position:absolute;inset:0;transition:transform .7s var(--ease-out),filter .5s}
.proj-bg img{width:100%;height:100%;object-fit:cover;filter:brightness(.75) saturate(.65)}
.proj:hover .proj-bg img{filter:brightness(.6) saturate(.5)}
.proj-hatch{position:absolute;inset:0;opacity:.04;background:repeating-linear-gradient(45deg,var(--accent) 0%,var(--accent) 1px,transparent 1px,transparent 12px);transition:opacity .4s}
.proj:hover .proj-hatch{opacity:.02}
.proj:hover .proj-bg{transform:scale(1.06)}
.proj-overlay{
  position:absolute;inset:0;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:1.5rem;
  background:linear-gradient(to top,rgba(247,243,236,.9) 0%,rgba(247,243,236,.1) 60%,transparent 100%);
  transform:translateY(4px);transition:transform .5s var(--ease-out);
}
.proj:hover .proj-overlay{transform:translateY(0)}
.proj-cat{font-size:.55rem;letter-spacing:.35em;text-transform:uppercase;color:var(--accent);margin-bottom:.35rem}
.proj-name{font-family:var(--font-display);font-size:1.15rem;font-weight:300;color:var(--white);line-height:1.2}
.proj-tag{font-size:.6rem;letter-spacing:.1em;color:var(--muted-hi);margin-top:.4rem;opacity:0;transform:translateY(6px);transition:opacity .4s .1s,transform .4s var(--ease-out) .1s}
.proj:hover .proj-tag{opacity:1;transform:translateY(0)}

/* ════════════════════════════════════
   S4 · PROCESS
════════════════════════════════════ */
.process-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--border);margin-bottom:3rem;background:var(--glass);backdrop-filter:blur(8px)}
.pstep{
  padding:2.5rem 2rem;border-right:1px solid var(--border);
  position:relative;overflow:hidden;
  transition:background .4s var(--ease);
}
.pstep:last-child{border-right:none}
.pstep::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--accent);transform:scaleY(0);transform-origin:top;transition:transform .5s var(--ease)}
.pstep:hover,.pstep:active{background:rgba(255,255,255,.6)}
.pstep:hover::before{transform:scaleY(1)}
.pstep-num{font-family:var(--font-display);font-size:3.5rem;font-weight:300;color:rgba(184,146,42,.1);line-height:1;margin-bottom:1.2rem;transition:color .4s}
.pstep:hover .pstep-num{color:rgba(184,146,42,.22)}
.pstep-title{font-size:.9rem;font-weight:500;color:var(--white);margin-bottom:.75rem}
.pstep-desc{font-size:.78rem;color:var(--muted);line-height:1.7}
.process-cta{display:flex;align-items:center;gap:2rem}
.process-cta p{font-family:var(--font-display);font-size:1.4rem;font-weight:300;font-style:italic;color:var(--muted-hi)}

/* ════════════════════════════════════
   S5 · CONTACT
════════════════════════════════════ */
.contact-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:5rem;align-items:start}
.contact-info-title{font-family:var(--font-display);font-size:clamp(1.8rem,3.5vw,3rem);font-weight:300;line-height:1.1;color:var(--white);margin-bottom:1rem}
.contact-info-title em{color:var(--accent);font-style:italic}
.contact-info-sub{font-size:.85rem;color:var(--muted);line-height:1.8;margin-bottom:2.5rem}
.cdetail{
  display:flex;align-items:center;gap:1rem;
  padding:.85rem 1rem;border:1px solid var(--border);margin-bottom:.6rem;
  background:var(--glass);backdrop-filter:blur(8px);
  box-shadow:var(--shadow-sm);
  transition:all .4s var(--ease);position:relative;overflow:hidden;
}
.cdetail::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--accent);transform:scaleY(0);transform-origin:bottom;transition:transform .4s var(--ease)}
.cdetail:hover,.cdetail:active{border-color:var(--border-hi);background:rgba(255,255,255,.85)}
.cdetail:hover::before{transform:scaleY(1)}
.cd-ico{width:36px;height:36px;background:rgba(184,146,42,.08);border:1px solid var(--border-hi);display:flex;align-items:center;justify-content:center;font-size:.8rem;color:var(--accent);flex-shrink:0}
.cd-lbl{font-size:.55rem;letter-spacing:.25em;color:var(--muted);text-transform:uppercase}
.cd-val{font-size:.85rem;color:var(--white);margin-top:.15rem}

.contact-form-wrap{
  background:rgba(255,255,255,.7);backdrop-filter:blur(12px);
  border:1px solid var(--border);
  padding:2.5rem;position:relative;
  box-shadow:var(--shadow-md);
}
.contact-form-wrap::before{content:'';position:absolute;top:0;left:2rem;right:2rem;height:1px;background:linear-gradient(to right,transparent,var(--border-hi),transparent)}
.fg-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.fg{margin-bottom:1rem}
.fg label{display:block;font-size:.6rem;letter-spacing:.25em;text-transform:uppercase;color:var(--muted);margin-bottom:.5rem}
.fg input,.fg select,.fg textarea{
  width:100%;
  background:rgba(247,243,236,.8);
  border:1px solid var(--border);
  color:var(--white);
  padding:.8rem 1rem;font-size:.85rem;outline:none;
  transition:border-color .3s,background .3s;
  caret-color:var(--accent);
}
.fg input::placeholder,.fg textarea::placeholder{color:var(--muted)}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--border-hi);background:rgba(255,255,255,.9)}
.fg select{appearance:none;-webkit-appearance:none;cursor:pointer}
.fg select option{background:var(--surface);color:var(--white)}
.fg textarea{resize:vertical;min-height:100px}
.btn-send{
  width:100%;display:flex;align-items:center;justify-content:center;gap:.75rem;
  font-family:var(--font-body);font-size:.7rem;letter-spacing:.25em;text-transform:uppercase;
  color:#fff;background:var(--accent);border:none;
  padding:1rem;position:relative;overflow:hidden;
  transition:all .4s var(--ease);margin-top:.5rem;
  box-shadow:0 4px 18px rgba(184,146,42,.25);
  -webkit-tap-highlight-color:transparent;
}
.btn-send::before{content:'';position:absolute;inset:0;background:var(--accent-2);transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.btn-send:hover::before{transform:scaleX(1)}
.btn-send i{position:relative;z-index:1}
.btn-send:hover{box-shadow:0 8px 30px rgba(184,146,42,.32);transform:translateY(-2px)}

/* ── WHATSAPP FAB ── */
.wa{
  position:fixed;bottom:2rem;right:2rem;
  width:52px;height:52px;border-radius:50%;
  background:#25d366;
  display:flex;align-items:center;justify-content:center;
  font-size:1.4rem;color:#fff;z-index:600;
  box-shadow:0 4px 20px rgba(37,211,102,.35);
  transition:all .3s var(--ease-spring);
  -webkit-tap-highlight-color:transparent;
}
.wa:hover,.wa:active{transform:scale(1.15) translateY(-3px);box-shadow:0 8px 30px rgba(37,211,102,.48)}
.wa::before{content:'';position:absolute;inset:-4px;border-radius:50%;border:1px solid rgba(37,211,102,.3);animation:waPulse 2.5s ease-in-out infinite}
@keyframes waPulse{0%,100%{transform:scale(1);opacity:.6}50%{transform:scale(1.2);opacity:0}}


/* ══════════════════════════════════════════════════
   RESPONSIVE — Mobile-First Full Overhaul
   Breakpoints: 1100 → 860 → 640 → 480 → 380
══════════════════════════════════════════════════ */

/* ── Tablet 1100px ── */
@media(max-width:1100px){
  .sec-wrap,.sec-wrap-projects{padding:4rem 3.5rem}
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .process-steps{grid-template-columns:repeat(2,1fr)}
  .pstep{border-bottom:1px solid var(--border)}
  .about-grid{gap:3rem}
}

/* ── Large phone / landscape 860px ── */
@media(max-width:860px){
  body{cursor:auto}
  #cursor,#cursor-ring{display:none}
  button{cursor:pointer}

  /* Header */
  #header{padding:0 1.2rem;height:56px}
  .h-center{display:none}
  .h-logo img{height:28px}

  /* Sections */
  #sections{top:56px}
  .sec-wrap,.sec-wrap-projects{
    padding:2.5rem 1.5rem 6rem;
    min-height:calc(100dvh - 56px);
    justify-content:flex-start;
  }

  /* Dot nav */
  #dotnav{right:.6rem;gap:10px}
  .dot{width:5px;height:5px}
  .dot.active{transform:scale(1.4)}
  #dotnav:hover .dot::before,
  .dot.active::before{display:none}

  /* Section titles */
  .sec-title{font-size:clamp(1.7rem,6vw,2.6rem);margin-bottom:1.5rem}

  /* About */
  .about-grid{grid-template-columns:1fr;gap:2rem}
  .about-visual{height:200px}
  .avp2,.avp4{display:none}
  .avr1{width:180px;height:180px}
  .avr2{width:130px;height:130px}
  .avr3{width:80px;height:80px}
  .av-center{width:60px;height:60px;font-size:1.3rem}

  /* Services */
  .services-grid{grid-template-columns:1fr 1fr;gap:.8rem}
  .svc-card{padding:1.4rem 1.2rem}
  .svc-num{font-size:2.8rem}

  /* Projects */
  .projects-grid{
    grid-template-columns:1fr 1fr;
    grid-template-rows:repeat(3,180px);
  }

  /* Process */
  .process-steps{grid-template-columns:1fr 1fr}
  .pstep{border-right:none;padding:1.8rem 1.5rem}
  .pstep-num{font-size:2.5rem}
  .process-cta{flex-direction:column;align-items:flex-start;gap:1.2rem}
  .process-cta p{font-size:1.1rem}

  /* Contact */
  .contact-grid{grid-template-columns:1fr;gap:2rem}
  .fg-row{grid-template-columns:1fr}
  .contact-form-wrap{padding:1.5rem}

  /* Home hero */
  .home-kicker{padding-top:2rem;font-size:.58rem}
  .home-h1{font-size:clamp(2.2rem,8vw,3.4rem)}
  .home-sub{font-size:.88rem;max-width:100%}
  .home-actions{flex-direction:column;gap:.8rem}
  .home-actions .btn-g{justify-content:center;width:100%;max-width:280px;padding:.9rem 1.6rem}
  .home-stats{
    flex-direction:row;flex-wrap:wrap;
    gap:1.2rem 2rem;padding:1.2rem 0 2.5rem;
  }
  .hstat{border-right:none;padding:0;margin:0}
  .hstat-num{font-size:2.2rem}
  .home-scroll-hint{left:1.5rem;bottom:1.5rem;font-size:.55rem}
  .home-scroll-hint span{display:none}

  .wa{bottom:1.2rem;right:1.2rem;width:46px;height:46px;font-size:1.2rem}
}

/* ── Portrait phone 640px ── */
@media(max-width:640px){
  #header{height:52px;padding:0 1rem}
  #sections{top:52px}
  .sec-wrap,.sec-wrap-projects{padding:2rem 1.2rem 5rem}

  /* Entrance */
  .enter-brand{font-size:1.8rem;letter-spacing:.08em}
  .enter-tagline{font-size:.58rem;letter-spacing:.25em}
  .enter-btn{padding:.9rem 2rem;font-size:.65rem;width:100%;max-width:280px;justify-content:center}
  .enter-emblem{width:60px;height:60px;font-size:1.5rem}

  /* Home */
  .home-h1{font-size:clamp(2rem,9vw,3rem)}
  .home-stats{gap:1rem 1.5rem}
  .hstat-num{font-size:1.9rem}

  /* Services — 1 col */
  .services-grid{grid-template-columns:1fr;gap:.7rem}
  .svc-card{padding:1.3rem 1.2rem}

  /* Projects — 1 col */
  .projects-grid{
    grid-template-columns:1fr;
    grid-template-rows:repeat(6,160px);
  }

  /* Process — 1 col */
  .process-steps{grid-template-columns:1fr}
  .pstep{border-bottom:1px solid var(--border)}
  .pstep:last-child{border-bottom:none}

  /* Dot nav — hide on small screens */
  #dotnav{display:none}

  .sec-title{font-size:clamp(1.6rem,7vw,2.2rem)}
  .sec-label{font-size:.56rem}

  .about-visual{height:170px}
  .avr1{width:145px;height:145px}
  .avr2{width:104px;height:104px}
  .avr3{width:64px;height:64px}

  .contact-form-wrap{padding:1.2rem}
  .cdetail{padding:.7rem .8rem}
  .cd-val{font-size:.8rem}

  .home-scroll-hint{display:none}

  /* Safe area for notched phones */
  .sec-wrap,.sec-wrap-projects{padding-bottom:calc(4.5rem + env(safe-area-inset-bottom, 0px))}
  .wa{bottom:calc(1.2rem + env(safe-area-inset-bottom, 0px))}
}

/* ── Very small 480px ── */
@media(max-width:480px){
  .enter-brand{font-size:1.6rem}
  .enter-ui{gap:.9rem}
  .home-h1{font-size:clamp(1.9rem,10vw,2.6rem)}
  .btn-g{padding:.8rem 1.5rem;font-size:.62rem}
  .sec-wrap,.sec-wrap-projects{padding:1.8rem 1rem 4.5rem}
  .hstat-num{font-size:1.75rem}
  .about-features .af-item{padding:.65rem 1rem}
}

/* ── Tiny 380px ── */
@media(max-width:380px){
  .enter-brand{font-size:1.4rem}
  .home-h1{font-size:1.75rem}
  .btn-g{padding:.7rem 1.2rem;font-size:.6rem}
  .sec-wrap,.sec-wrap-projects{padding:1.5rem .9rem 4rem}
  .enter-btn{padding:.8rem 1.6rem}
}

/* ══════════════════════════════════════
   TOUCH IMPROVEMENTS
══════════════════════════════════════ */
@media(hover:none){
  /* Always show proj tag on touch */
  .proj-tag{opacity:1;transform:translateY(0)}

  /* Tap states */
  .svc-card:active{border-color:var(--border-hi);background:rgba(255,255,255,.85)}
  .af-item:active{border-color:var(--border-hi)}
  .pstep:active{background:rgba(255,255,255,.6)}
  .cdetail:active{border-color:var(--border-hi)}

  /* Larger tap targets */
  .dot{
    width:20px;height:20px;
    background:transparent;
    display:flex;align-items:center;justify-content:center;
  }
  .dot::after{
    content:'';
    width:6px;height:6px;
    border-radius:50%;
    background:rgba(30,25,20,.2);
    transition:background .3s,transform .3s;
  }
  .dot.active::after{background:var(--accent);transform:scale(1.4)}
}

/* ══════════════════════════════════════
   REDUCED MOTION
══════════════════════════════════════ */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.01ms !important;
    transition-duration:.01ms !important;
  }
}