@import url('https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,300;12..96,400;12..96,500;12..96,700;12..96,800&family=Cormorant+Garamond:ital,wght@0,300;0,600;1,300;1,600&family=DM+Sans:wght@300;400;500;600&display=swap');

/* ═══ CSS VARIABLES ════════════════════════════════════════════ */
:root{
  --ink:#09090B;--ink2:#111316;--ink3:#1A1D21;
  --line:rgba(255,255,255,.07);--line2:rgba(255,255,255,.14);
  --cyan:#00C4D4;--cyan-d:#0096A6;--cyan-pale:rgba(0,196,212,.09);
  --gold:#C8A84B;--gold-pale:rgba(200,168,75,.1);
  --rose:#E8415E;--rose-pale:rgba(232,65,94,.1);
  --warm:#F3EDE6;--warm2:#A8A09A;--warm3:#5C5650;
  --ease:cubic-bezier(.4,0,.2,1);--spring:cubic-bezier(.34,1.56,.64,1);
  --fd:'Bricolage Grotesque',sans-serif;
  --fs:'Cormorant Garamond',serif;
  --fb:'DM Sans',sans-serif;
}

/* ═══ RESET ════════════════════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--ink);color:var(--warm);font-family:var(--fb);font-size:16px;line-height:1.65;overflow-x:hidden;-webkit-font-smoothing:antialiased}

a{text-decoration:none;color:inherit;cursor:pointer}
img,svg{display:block;max-width:100%}
button{cursor:pointer;border:none;background:none;font-family:inherit}
::-webkit-scrollbar{width:3px}
::-webkit-scrollbar-track{background:var(--ink)}
::-webkit-scrollbar-thumb{background:var(--gold);border-radius:10px}

/* ═══ NAV ══════════════════════════════════════════════════════ */
#ps-nav{position:fixed;top:0;left:0;right:0;z-index:9999;margin:0;padding:0;
  background:#0E1014;border-bottom:1px solid rgba(255,255,255,.08);transition:background .3s}
#ps-nav-inner{display:flex;align-items:center;justify-content:space-between;
  max-width:1280px;margin:0 auto;padding:.9rem 2.5rem;gap:2rem}
#ps-logo{display:flex;align-items:center;text-decoration:none;cursor:pointer;flex-shrink:0}
#ps-links{display:flex;align-items:center;gap:2rem;flex:1;justify-content:center;list-style:none}
#ps-links a{font-family:var(--fb);font-size:.875rem;font-weight:400;color:var(--warm2);
  text-decoration:none;cursor:pointer;white-space:nowrap;position:relative;transition:color .2s}
#ps-links a:hover,#ps-links a.ps-active{color:var(--warm)}
#ps-links a::after{content:'';position:absolute;left:0;right:0;bottom:-3px;height:1px;
  background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .3s}
#ps-links a:hover::after,#ps-links a.ps-active::after{transform:scaleX(1)}
#ps-cta{display:inline-flex;align-items:center;padding:10px 22px;background:var(--cyan);
  color:#000;font-weight:700;font-size:.85rem;border-radius:5px;text-decoration:none;
  cursor:pointer;border:none;white-space:nowrap;flex-shrink:0;transition:transform .2s,box-shadow .2s}
#ps-cta:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,196,212,.4)}
#ps-ham{display:none;align-items:center;justify-content:center;width:36px;height:36px;
  background:none;border:none;cursor:pointer;color:var(--warm);flex-shrink:0;padding:0}
#ps-nav.ps-open #ps-links{display:flex!important;flex-direction:column;align-items:flex-start;
  gap:1.25rem;position:fixed;top:60px;left:0;right:0;background:#0A0C10;
  padding:1.5rem 2rem;border-bottom:1px solid rgba(255,255,255,.08);z-index:9998}
#progress{position:fixed;top:0;left:0;height:2px;pointer-events:none;
  background:linear-gradient(90deg,var(--cyan),var(--gold));z-index:10000;width:0}

/* ═══ UTILITIES ════════════════════════════════════════════════ */
.container{max-width:1280px;margin:0 auto;padding:0 2.5rem}
.tag-line{font-size:.68rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;
  color:var(--cyan);margin-bottom:.75rem;display:flex;align-items:center;gap:10px}
.tag-line::before{content:'';display:block;width:22px;height:1px;background:var(--cyan)}
.section-title{font-family:var(--fd);font-size:clamp(2rem,4vw,3rem);font-weight:800;
  letter-spacing:-.04em;line-height:1.0}
.reveal{opacity:0;transform:translateY(28px);transition:opacity .85s var(--ease),transform .85s var(--ease)}
.reveal.visible{opacity:1;transform:none}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}

/* ═══ BUTTONS ══════════════════════════════════════════════════ */
.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 28px;border-radius:5px;
  font-family:var(--fb);font-size:.875rem;font-weight:500;cursor:pointer;
  text-decoration:none;transition:all .25s var(--ease);border:none;white-space:nowrap}
.btn svg{width:14px;height:14px;flex-shrink:0;transition:transform .2s var(--spring)}
.btn:hover svg{transform:translate(2px,-2px)}
.btn-cy{background:var(--cyan);color:#000;font-weight:700}
.btn-cy:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(0,196,212,.35)}
.btn-au{background:transparent;color:var(--warm);border:1px solid var(--line2)}
.btn-au:hover{border-color:rgba(255,255,255,.25);background:rgba(255,255,255,.04)}
.btn-gd{background:var(--gold);color:#000;font-weight:700}
.btn-gd:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(200,168,75,.3)}
.btn-magnetic{transition:transform .2s}

/* ═══ FOOTER ═══════════════════════════════════════════════════ */
footer{border-top:1px solid var(--line);padding:3rem 0;margin-top:0}
.foot-wrap{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:2rem}
.foot-copy{font-size:.75rem;color:var(--warm3);margin-top:6px}
.foot-nav{display:flex;gap:2.5rem;justify-content:center}
.foot-nav a{font-size:.8rem;color:var(--warm3);transition:color .2s;cursor:pointer}
.foot-nav a:hover{color:var(--warm)}
.foot-right{display:flex;justify-content:flex-end;align-items:center;gap:10px}
.fsoc{width:36px;height:36px;border-radius:8px;background:var(--ink3);
  border:1px solid var(--line);display:flex;align-items:center;justify-content:center;
  color:var(--warm3);transition:all .25s;cursor:pointer;text-decoration:none}
.fsoc:hover{background:var(--gold-pale);color:var(--gold);border-color:rgba(200,168,75,.3)}
.fsoc svg{width:15px;height:15px}

/* ═══ HERO ══════════════════════════════════════════════════════ */
#hero{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;align-items:center;
  padding:10rem 0 6rem;position:relative;overflow:hidden}
.hero-deco{position:absolute;right:-4vw;top:50%;transform:translateY(-50%);
  font-family:var(--fd);font-weight:800;font-size:clamp(8rem,16vw,20rem);
  line-height:.85;letter-spacing:-.06em;-webkit-text-stroke:1px rgba(255,255,255,.04);
  color:transparent;pointer-events:none;user-select:none;animation:float 8s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(-50%)}50%{transform:translateY(-52%)}}
.hero-left{padding-left:2.5rem;position:relative;z-index:1}
.hero-eyebrow{display:flex;align-items:center;gap:14px;margin-bottom:2rem;
  opacity:0;animation:fadeUp .8s ease .2s forwards}
.hero-eyebrow .line{width:36px;height:1px;background:var(--gold)}
.hero-eyebrow span{font-family:var(--fs);font-style:italic;font-size:1rem;color:var(--gold);font-weight:300}
.word-wrap{overflow:hidden;display:block}
.word-inner{display:block;transform:translateY(100%);animation:slideWord .9s cubic-bezier(.16,1,.3,1) forwards}
.w1{animation-delay:.3s}.w2{animation-delay:.45s}.w3{animation-delay:.6s}
@keyframes slideWord{to{transform:translateY(0)}}
.hero-h1{font-family:var(--fd);font-weight:800;font-size:clamp(2.8rem,5vw,5rem);
  line-height:.96;letter-spacing:-.04em;margin-bottom:2rem}
.hero-h1 em{font-style:italic;font-family:var(--fs);font-weight:600;color:var(--cyan);font-size:1.05em}
.hero-p{max-width:420px;color:var(--warm2);font-size:.97rem;font-weight:300;line-height:1.85;
  margin-bottom:2.5rem;opacity:0;animation:fadeUp .9s ease .7s forwards}
.hero-acts{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;
  opacity:0;animation:fadeUp .9s ease .85s forwards}
.hero-right{display:flex;flex-direction:column;border-left:1px solid var(--line);
  opacity:0;animation:fadeUp .9s ease .5s forwards}
.hstat{padding:2.5rem 2.5rem;border-bottom:1px solid var(--line);
  position:relative;overflow:hidden;transition:background .3s}
.hstat:last-child{border-bottom:none}
.hstat:hover{background:rgba(255,255,255,.02)}
.hstat::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;
  background:var(--gold);transform:scaleY(0);transition:transform .4s var(--ease);transform-origin:bottom}
.hstat:hover::before{transform:scaleY(1)}
.hs-num{font-family:var(--fd);font-size:3.2rem;font-weight:800;letter-spacing:-.05em;line-height:1}
.hs-sub{font-size:.78rem;color:var(--warm3);margin-top:5px}
.hero-scroll{position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:8px;
  opacity:0;animation:fadeUp 1s ease 1.2s forwards}
.hero-scroll span{font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--warm3)}
.scroll-bar{width:1px;height:48px;background:linear-gradient(to bottom,var(--gold),transparent)}

/* ═══ MARQUEE ══════════════════════════════════════════════════ */
.div-wrap{border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  overflow:hidden;padding:.9rem 0;background:rgba(255,255,255,.01)}
.div-track{display:flex;width:max-content;animation:marquee 35s linear infinite}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.div-item{display:flex;align-items:center;gap:1.5rem;padding:0 2rem;font-size:.7rem;
  font-weight:400;letter-spacing:.16em;text-transform:uppercase;color:var(--warm3);
  white-space:nowrap;flex-shrink:0}
.div-gem{width:5px;height:5px;background:var(--gold);transform:rotate(45deg);flex-shrink:0}

/* ═══ SERVICES ══════════════════════════════════════════════════ */
#services{padding:9rem 0}
.svc-intro{display:grid;grid-template-columns:5fr 7fr;gap:6rem;margin-bottom:5rem;align-items:end}
.svc-h2{font-family:var(--fd);font-weight:800;font-size:clamp(2.2rem,4.5vw,3.8rem);
  line-height:.95;letter-spacing:-.04em}
.svc-h2 span{font-family:var(--fs);font-weight:300;font-style:italic;font-size:.85em;
  color:var(--warm2);display:block}
.svc-list{display:flex;flex-direction:column}
.svc-item{display:grid;grid-template-columns:80px 1fr 180px;align-items:start;
  gap:2.5rem;padding:2.5rem 0;border-top:1px solid var(--line);position:relative;
  overflow:hidden;transition:background .3s}
.svc-item:last-child{border-bottom:1px solid var(--line)}
.svc-item::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,var(--gold),transparent);
  transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease)}
.svc-item:hover::after{transform:scaleX(1)}
.svc-num{font-family:var(--fs);font-size:3.5rem;font-weight:300;line-height:.9;
  color:var(--warm3);letter-spacing:-.03em;transition:color .3s}
.svc-item:hover .svc-num{color:var(--gold)}
.svc-name{font-family:var(--fd);font-size:1.4rem;font-weight:700;letter-spacing:-.02em;
  margin-bottom:.4rem;transition:color .3s}
.svc-item:hover .svc-name{color:var(--cyan)}
.svc-badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:4px;
  font-size:.65rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  background:var(--gold-pale);color:var(--gold);border:1px solid rgba(200,168,75,.2);white-space:nowrap}
.svc-desc{color:var(--warm2);font-size:.87rem;line-height:1.75;font-weight:300;max-width:560px}
.svc-pills{display:flex;gap:6px;flex-wrap:wrap;margin-top:.9rem}
.svc-pill{padding:4px 10px;border-radius:4px;font-size:.65rem;font-weight:500;
  letter-spacing:.06em;text-transform:uppercase;background:rgba(255,255,255,.04);
  color:var(--warm3);border:1px solid var(--line)}
.svc-img-wrap{width:180px;height:120px;border-radius:12px;overflow:hidden;
  opacity:.55;transition:opacity .4s,transform .5s var(--ease);filter:grayscale(.4) saturate(.8);flex-shrink:0}
.svc-item:hover .svc-img-wrap{opacity:.88;transform:scale(1.04);filter:none}
.svc-img-wrap img,.svc-img-wrap svg{width:100%;height:100%;object-fit:cover}

/* ═══ EVENT SECTION ════════════════════════════════════════════ */
#event{padding:0 0 9rem}
.evt-wrap{position:relative;border-radius:28px;overflow:hidden;border:1px solid var(--line)}
.evt-bg{position:absolute;inset:0;background:url('../img/gala-backdrop.svg') center/cover;
  opacity:.07;transition:opacity .8s;pointer-events:none}
.evt-wrap:hover .evt-bg{opacity:.12}
.evt-ov{position:absolute;inset:0;background:linear-gradient(125deg,var(--ink2) 0%,rgba(13,16,20,.96));pointer-events:none}
.evt-g1{position:absolute;top:-80px;right:-60px;width:440px;height:440px;
  background:radial-gradient(circle,rgba(200,168,75,.08),transparent 65%);pointer-events:none}
.evt-g2{position:absolute;bottom:-60px;left:40px;width:360px;height:360px;
  background:radial-gradient(circle,rgba(0,196,212,.06),transparent 65%);pointer-events:none}
.evt-inner{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;
  gap:5rem;padding:4.5rem}
.evt-ribbon{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;
  border-radius:999px;background:rgba(232,65,94,.1);border:1px solid rgba(232,65,94,.25);
  font-size:.7rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--rose);margin-bottom:1.5rem}
.evt-ribbon .pulse{width:6px;height:6px;border-radius:50%;background:var(--rose);
  animation:pulse 2s ease infinite;flex-shrink:0}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}
.evt-h2{font-family:var(--fd);font-weight:800;font-size:clamp(1.8rem,3.5vw,2.8rem);
  line-height:1.05;letter-spacing:-.03em;margin-bottom:1rem}
.evt-h2 em{font-style:italic;font-family:var(--fs);font-weight:600;color:var(--gold)}
.evt-p{color:var(--warm2);font-size:.93rem;line-height:1.85;font-weight:300;margin-bottom:2rem}
.pills{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:8px;margin-bottom:2rem}
.sp{display:flex;align-items:center;gap:9px;padding:10px 13px;
  background:rgba(255,255,255,.03);border:1px solid var(--line);border-radius:10px;
  font-size:.82rem;font-weight:400;color:var(--warm2);transition:all .25s;cursor:default}
.sp:hover{background:rgba(200,168,75,.05);border-color:rgba(200,168,75,.2);color:var(--warm)}
.spdot{width:7px;height:7px;border-radius:50%;flex-shrink:0}

/* ═══ PORTFOLIO ════════════════════════════════════════════════ */
#portfolio{padding:9rem 0}
.port-hdr{display:flex;align-items:flex-end;justify-content:space-between;
  margin-bottom:3.5rem;flex-wrap:wrap;gap:1.5rem}
.port-h2{font-family:var(--fd);font-weight:800;font-size:clamp(2rem,4vw,3.2rem);
  letter-spacing:-.04em;line-height:1}
.port-h2 em{font-style:italic;font-family:var(--fs);font-weight:300;color:var(--warm2)}
.pgrid{display:grid;grid-template-columns:5fr 4fr 3fr;gap:10px}
.pc{background:var(--ink2);border:1px solid var(--line);border-radius:18px;
  overflow:hidden;transition:transform .4s var(--ease),border-color .3s,box-shadow .4s;
  display:flex;flex-direction:column}
.pc:hover{transform:translateY(-5px);border-color:rgba(255,255,255,.12);
  box-shadow:0 28px 60px rgba(0,0,0,.35)}
.pc-img{position:relative;overflow:hidden;flex-shrink:0}
.pc-img img,.pc-img svg{width:100%;object-fit:cover;transition:transform .6s var(--ease),filter .4s;
  filter:brightness(.68) saturate(.8);display:block}
.pc:hover .pc-img img,.pc:hover .pc-img svg{transform:scale(1.06);filter:brightness(.85) saturate(1)}
.pc-grad{position:absolute;inset:0;background:linear-gradient(to top,rgba(9,9,11,.9) 0%,transparent 55%)}
.pc-badge{position:absolute;top:14px;left:14px;padding:5px 11px;border-radius:4px;
  font-size:.63rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;backdrop-filter:blur(10px)}
.pc-meta{padding:1.25rem 1.5rem 1.6rem;flex:1;display:flex;flex-direction:column}
.pc-cat{font-size:.66rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;margin-bottom:.4rem}
.pc-title{font-family:var(--fd);font-size:1rem;font-weight:700;letter-spacing:-.01em;margin-bottom:.35rem}
.pc-desc{font-size:.82rem;color:var(--warm2);line-height:1.55;font-weight:300;flex:1}
.pc-link{display:inline-flex;align-items:center;gap:6px;margin-top:.85rem;
  font-size:.75rem;font-weight:500;color:var(--warm3);transition:color .2s;cursor:pointer;text-decoration:none}
.pc-link:hover{color:var(--gold)}
.pc-link svg{width:11px;height:11px;transition:transform .2s}
.pc-link:hover svg{transform:translate(2px,-2px)}
.pc1{grid-column:1;grid-row:1}.pc1 .pc-img img,.pc1 .pc-img svg{height:260px}
.pc2{grid-column:2;grid-row:1}.pc2 .pc-img img,.pc2 .pc-img svg{height:260px}
.pc3{grid-column:3;grid-row:1/span 2;display:flex;flex-direction:column}
.pc3 .pc-img{flex:1}.pc3 .pc-img img,.pc3 .pc-img svg{height:340px}
.pc4{grid-column:1;grid-row:2}.pc4 .pc-img img,.pc4 .pc-img svg{height:210px}
.pc5{grid-column:2;grid-row:2}.pc5 .pc-img img,.pc5 .pc-img svg{height:210px}

/* ═══ PROCESS ══════════════════════════════════════════════════ */
#process{padding:9rem 0;border-top:1px solid var(--line)}
.proc-top{display:grid;grid-template-columns:1fr 1fr;gap:4rem;margin-bottom:5rem;align-items:end}
.proc-h2{font-family:var(--fd);font-weight:800;font-size:clamp(2rem,4vw,3.2rem);letter-spacing:-.04em;line-height:.98}
.proc-h2 em{font-style:italic;font-family:var(--fs);font-weight:300;color:var(--warm2);display:block}
.timeline{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.timeline::before{content:'';position:absolute;top:24px;left:10%;right:10%;height:1px;
  background:linear-gradient(90deg,transparent,var(--line),var(--gold) 30%,var(--cyan) 70%,var(--line),transparent)}
.tl-step{padding:0 2rem 0 0;position:relative;z-index:1}
.tl-dot{width:48px;height:48px;border-radius:50%;border:1px solid var(--gold);
  background:var(--ink);display:flex;align-items:center;justify-content:center;
  margin-bottom:1.75rem;transition:background .3s,box-shadow .3s;
  font-family:var(--fs);font-size:.9rem;font-weight:300;color:var(--gold)}
.tl-step:hover .tl-dot{background:var(--gold-pale);box-shadow:0 0 0 6px rgba(200,168,75,.08)}
.tl-n{font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--warm3);margin-bottom:.5rem}
.tl-title{font-family:var(--fd);font-size:1rem;font-weight:700;letter-spacing:-.01em;margin-bottom:.5rem;color:var(--warm)}
.tl-desc{font-size:.82rem;color:var(--warm2);line-height:1.65;font-weight:300}

/* ═══ WHY US ════════════════════════════════════════════════════ */
#why{padding:9rem 0;border-top:1px solid var(--line)}
.why-wrap{display:grid;grid-template-columns:1fr 1fr;gap:0}
.why-left{padding-right:6rem;border-right:1px solid var(--line)}
.why-right{padding-left:6rem}
.why-h2{font-family:var(--fd);font-weight:800;font-size:clamp(2rem,4vw,3rem);
  letter-spacing:-.04em;line-height:.96;margin-bottom:1.5rem}
.why-h2 em{font-style:italic;font-family:var(--fs);font-weight:300;color:var(--cyan);display:block}
.why-pts{display:flex;flex-direction:column}
.wpt{padding:1.5rem 0;border-bottom:1px solid var(--line);display:flex;gap:1.25rem;align-items:flex-start}
.wpt:first-child{border-top:1px solid var(--line)}
.wpt-ico{width:36px;height:36px;border-radius:9px;border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--cyan);
  transition:background .3s,border-color .3s}
.wpt:hover .wpt-ico{background:var(--cyan-pale);border-color:rgba(0,196,212,.3)}
.wpt-ico svg{width:16px;height:16px}
.wpt-lbl{font-weight:600;font-size:.9rem;margin-bottom:.2rem;font-family:var(--fd)}
.wpt-desc{font-size:.81rem;color:var(--warm2);font-weight:300;line-height:1.6}
.bigstats{display:flex;flex-direction:column}
.bstat{padding:2.5rem 0;border-bottom:1px solid var(--line);position:relative;transition:background .2s}
.bstat:first-child{border-top:1px solid var(--line)}
.bstat:hover{background:rgba(255,255,255,.015)}
.bstat::before{content:'';position:absolute;right:0;top:0;bottom:0;width:2px;background:var(--cyan);
  transform:scaleY(0);transition:transform .4s var(--ease);transform-origin:top}
.bstat:hover::before{transform:scaleY(1)}
.bstat-n{font-family:var(--fd);font-size:4rem;font-weight:800;letter-spacing:-.06em;line-height:1;
  background:linear-gradient(135deg,var(--warm),var(--gold));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.bstat-l{font-size:.82rem;color:var(--warm3);margin-top:5px}
.bstat-q{font-family:var(--fs);font-style:italic;font-size:.88rem;color:var(--warm3);margin-top:4px}

/* ═══ CTA ═══════════════════════════════════════════════════════ */
#cta{padding:9rem 0;border-top:1px solid var(--line)}
.cta-inner{position:relative;border-radius:28px;overflow:hidden;border:1px solid var(--line);
  padding:6rem 3rem;background:var(--ink2);text-align:center}
.cta-inner::before{content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 70% 60% at 50% 0%,rgba(0,196,212,.08),transparent 70%)}
.cta-inner::after{content:'';position:absolute;bottom:-60px;left:50%;transform:translateX(-50%);
  width:300px;height:300px;background:radial-gradient(circle,rgba(200,168,75,.07),transparent 65%)}
.cta-bg-t{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  font-family:var(--fd);font-weight:800;font-size:clamp(5rem,13vw,15rem);
  line-height:1;-webkit-text-stroke:1px rgba(255,255,255,.035);color:transparent;
  white-space:nowrap;pointer-events:none;user-select:none}
.cta-h2{font-family:var(--fd);font-weight:800;font-size:clamp(2.2rem,5vw,4.5rem);
  letter-spacing:-.04em;line-height:.95;max-width:700px;margin:.8rem auto 1.25rem;position:relative;z-index:1}
.cta-h2 em{font-style:italic;font-family:var(--fs);font-weight:300;color:var(--gold)}
.cta-p{color:var(--warm2);font-size:.97rem;font-weight:300;max-width:440px;
  margin:0 auto 2.5rem;position:relative;z-index:1}
.cta-acts{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap;position:relative;z-index:1}
.cta-note{margin-top:1.75rem;font-size:.8rem;color:var(--warm3);position:relative;z-index:1}
.cta-note a{color:var(--cyan);transition:color .2s}.cta-note a:hover{color:var(--gold)}

/* ═══ ANIMATIONS ════════════════════════════════════════════════ */
@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}
@keyframes scrollPulse{0%{opacity:1}100%{opacity:0;transform:scaleY(.3);transform-origin:top}}

/* ═══ PORTFOLIO PAGE ════════════════════════════════════════════ */
.port-hero{padding:10rem 0 5rem;border-bottom:1px solid var(--line);position:relative;overflow:hidden}
.port-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 60% at 80% 50%,rgba(200,168,75,.06),transparent 70%)}
.ph-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(0,196,212,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(0,196,212,.03) 1px,transparent 1px);background-size:70px 70px;mask-image:radial-gradient(ellipse 90% 90% at 50% 50%,black 10%,transparent 100%)}
.fbtn{padding:8px 18px;border-radius:4px;font-size:.78rem;font-weight:500;letter-spacing:.04em;
  border:1px solid var(--line);color:var(--warm2);background:transparent;font-family:var(--fb);
  cursor:pointer;transition:all .25s}
.fbtn:hover{border-color:var(--line2);color:var(--warm)}
.fbtn.active{background:var(--gold);color:#000;border-color:var(--gold);font-weight:700}
.all-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.pcard{background:var(--ink2);border:1px solid var(--line);border-radius:18px;overflow:hidden;
  transition:transform .35s var(--ease),border-color .3s,box-shadow .3s;display:flex;flex-direction:column}
.pcard:hover{transform:translateY(-5px);border-color:rgba(255,255,255,.12);box-shadow:0 28px 60px rgba(0,0,0,.35)}
.pthumb{height:220px;position:relative;overflow:hidden;background:var(--ink3);flex-shrink:0}
.pthumb img,.pthumb svg{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease),filter .4s;filter:brightness(.68) saturate(.8);display:block}
.pcard:hover .pthumb img,.pcard:hover .pthumb svg{transform:scale(1.06);filter:brightness(.85) saturate(1)}
.pthumb-ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(9,9,11,.9) 0%,transparent 55%)}
.pbadge{position:absolute;top:14px;left:14px;padding:5px 11px;border-radius:4px;font-size:.63rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;backdrop-filter:blur(10px)}
.pmeta{padding:1.25rem 1.5rem 1.6rem;flex:1;display:flex;flex-direction:column}
.pcat{font-size:.66rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;margin-bottom:.4rem}
.ptitle{font-family:var(--fd);font-size:1.05rem;font-weight:700;letter-spacing:-.01em;margin-bottom:.35rem}
.pdesc{font-size:.82rem;color:var(--warm2);line-height:1.55;font-weight:300;flex:1}
.ptags{display:flex;gap:5px;flex-wrap:wrap;margin-top:.75rem}
.ptag{font-size:.62rem;padding:3px 8px;border-radius:3px;background:rgba(255,255,255,.04);color:var(--warm3);border:1px solid var(--line)}
.plink{display:inline-flex;align-items:center;gap:6px;margin-top:.9rem;font-size:.75rem;font-weight:500;color:var(--warm3);transition:color .2s;text-decoration:none;cursor:pointer}
.plink:hover{color:var(--gold)}.plink svg{width:11px;height:11px;transition:transform .2s}.plink:hover svg{transform:translate(2px,-2px)}

/* ═══ PROJECT PAGES ═════════════════════════════════════════════ */
.proj-hero{min-height:70vh;position:relative;display:flex;align-items:flex-end;padding:0 0 4rem;overflow:hidden}
.ph-bg{position:absolute;inset:0;background-size:cover;background-position:center}
.ph-ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(9,9,11,.97) 0%,rgba(9,9,11,.55) 50%,rgba(9,9,11,.25))}
.phc{position:relative;z-index:1;width:100%;padding-top:9rem}
.breadcrumb{display:flex;align-items:center;gap:10px;font-size:.73rem;color:var(--warm3);margin-bottom:1.75rem;flex-wrap:wrap}
.breadcrumb a{color:var(--warm3);transition:color .2s;cursor:pointer;text-decoration:none}.breadcrumb a:hover{color:var(--warm)}
.breadcrumb span{opacity:.4}
.pcbadge{display:inline-flex;align-items:center;padding:5px 14px;border-radius:999px;font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;border:1px solid;margin-bottom:1.25rem}
.proj-title{font-family:var(--fd);font-size:clamp(2.2rem,5.5vw,4.8rem);font-weight:800;letter-spacing:-.04em;line-height:.95;margin-bottom:1rem}
.proj-tag{color:var(--warm2);font-size:1rem;font-weight:300;max-width:620px;line-height:1.75}
.meta-bar{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin:4rem 0}
.mi{padding:1.75rem 0;border-right:1px solid var(--line)}.mi:last-child{border-right:none}
.mi-label{font-size:.68rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--warm3);margin-bottom:.4rem}
.mi-val{font-family:var(--fd);font-size:1.05rem;font-weight:700}
.proj-sec{padding:5rem 0;border-bottom:1px solid var(--line)}.proj-sec:last-of-type{border-bottom:none}
.ps-grid{display:grid;grid-template-columns:1fr 2fr;gap:5rem;align-items:start}
.ps-lbl{font-size:.7rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--warm3);padding-top:.4rem}
.ps-h3{font-family:var(--fd);font-size:1.6rem;font-weight:700;letter-spacing:-.03em;margin-bottom:.9rem}
.ps-p{color:var(--warm2);font-size:.95rem;line-height:1.85;font-weight:300;margin-bottom:.9rem}
.mock-grid{display:grid;gap:10px;margin-top:1.5rem}
.mock-grid.g2{grid-template-columns:1fr 1fr}.mock-grid.g1{grid-template-columns:1fr}
.mock-item{border-radius:14px;overflow:hidden;background:var(--ink2);border:1px solid var(--line);position:relative;transition:transform .4s var(--ease),border-color .3s,box-shadow .4s;min-height:200px}
.mock-item:hover{transform:translateY(-4px);border-color:rgba(200,168,75,.25);box-shadow:0 24px 60px rgba(0,0,0,.5)}
.mock-item img,.mock-item svg{display:block;width:100%;height:auto}
.mock-item.tall{min-height:300px}.mock-item.medium{min-height:240px}
.dl-list{display:flex;flex-direction:column}
.dl{display:flex;align-items:center;gap:1rem;padding:1rem 0;border-bottom:1px solid var(--line)}
.dl:first-child{border-top:1px solid var(--line)}
.dl-icon{width:34px;height:34px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:.95rem}
.dl-text{font-size:.9rem}
.res-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:1.5rem}
.rc{background:var(--ink2);border:1px solid var(--line);border-radius:16px;padding:2rem;text-align:center;transition:border-color .3s,transform .3s}
.rc:hover{border-color:rgba(200,168,75,.25);transform:translateY(-3px)}
.rc-n{font-family:var(--fd);font-size:2.8rem;font-weight:800;letter-spacing:-.05em;line-height:1;background:linear-gradient(135deg,var(--warm),var(--gold));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.rc-l{font-size:.78rem;color:var(--warm3);margin-top:6px}
.qblock{background:var(--ink2);border:1px solid var(--line);border-left:3px solid var(--gold);border-radius:0 14px 14px 0;padding:2rem 2.5rem;margin:2.5rem 0}
.qt{font-family:var(--fs);font-size:1.3rem;font-style:italic;font-weight:300;line-height:1.65;margin-bottom:.75rem}
.qa{font-size:.8rem;color:var(--warm3)}
.next-proj{padding:6rem 0;border-top:1px solid var(--line);text-align:center}
.np-lbl{font-size:.7rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--warm3);margin-bottom:1rem}
.np-title{font-family:var(--fd);font-size:clamp(1.5rem,4vw,3rem);font-weight:800;letter-spacing:-.04em;margin-bottom:2rem}

/* ═══ CONTACT PAGE ══════════════════════════════════════════════ */
.cw{padding:10rem 0 8rem}
.ch-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:6rem;align-items:start}
.ch-info{position:sticky;top:8rem}
.ch-h2{font-family:var(--fd);font-size:clamp(2.2rem,5vw,4rem);font-weight:800;letter-spacing:-.04em;line-height:.96;margin-bottom:1.25rem}
.ch-h2 em{font-style:italic;font-family:var(--fs);font-weight:300;color:var(--gold)}
.cdet{display:flex;flex-direction:column}
.cdi{display:flex;align-items:flex-start;gap:1rem;padding:1.25rem 0;border-bottom:1px solid var(--line)}
.cdi:first-child{border-top:1px solid var(--line)}
.cdico{width:36px;height:36px;border-radius:9px;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--cyan)}
.cdico svg{width:16px;height:16px}
.cdl{font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--warm3);margin-bottom:.25rem}
.cdv{font-size:.92rem;color:var(--warm)}
.cdv a{color:var(--cyan);transition:color .2s;text-decoration:none}.cdv a:hover{color:var(--gold)}
.fw{background:var(--ink2);border:1px solid var(--line);border-radius:24px;padding:2.5rem}
.fg{margin-bottom:1.5rem}
.fr{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
label{display:block;font-size:.72rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--warm3);margin-bottom:.6rem}
input,select,textarea{width:100%;background:rgba(255,255,255,.04);border:1px solid var(--line);
  border-radius:8px;padding:12px 16px;color:var(--warm);font-family:var(--fb);font-size:.9rem;
  font-weight:300;outline:none;transition:border-color .25s,background .25s;-webkit-appearance:none;appearance:none}
input:focus,select:focus,textarea:focus{border-color:rgba(0,196,212,.4);background:rgba(255,255,255,.06)}
input::placeholder,textarea::placeholder{color:var(--warm3)}
select{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%235C5650' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;padding-right:40px}
textarea{resize:vertical;min-height:140px}
.fsub{width:100%;justify-content:center;margin-top:.5rem;padding:14px 28px}
.fnote{text-align:center;font-size:.78rem;color:var(--warm3);margin-top:1rem}
.fsucc{display:none;text-align:center;padding:2rem;background:rgba(0,196,212,.08);border:1px solid rgba(0,196,212,.25);border-radius:12px;margin-top:1rem}
.fsucc h3{font-family:var(--fd);font-weight:700;margin-bottom:.5rem;color:var(--cyan)}

/* ═══ TILT CARDS ════════════════════════════════════════════════ */
.tilt-card{transition:transform .6s cubic-bezier(.34,1.56,.64,1)}

/* ═══ RESPONSIVE — TABLET (max 1100px) ═══════════════════════════ */
@media(max-width:1100px){
  #hero{grid-template-columns:1fr}
  .hero-right{display:grid;grid-template-columns:repeat(2,1fr);border-left:none;border-top:1px solid var(--line)}
  .hero-left{padding-left:0}
  .hero-deco{font-size:clamp(6rem,13vw,14rem);opacity:.6}
  .svc-intro{grid-template-columns:1fr;gap:1.5rem}
  .svc-item{grid-template-columns:60px 1fr;gap:1.5rem}
  .svc-img-wrap{display:none}
  .evt-inner{grid-template-columns:1fr;gap:2.5rem}
  .pgrid{grid-template-columns:1fr 1fr;grid-template-rows:auto}
  .pc1,.pc2,.pc3,.pc4,.pc5{grid-column:span 1;grid-row:auto}
  .pc1 .pc-img img,.pc1 .pc-img svg,.pc2 .pc-img img,.pc2 .pc-img svg,
  .pc3 .pc-img img,.pc3 .pc-img svg,.pc4 .pc-img img,.pc4 .pc-img svg,
  .pc5 .pc-img img,.pc5 .pc-img svg{height:220px}
  .proc-top{grid-template-columns:1fr;gap:1.5rem}
  .timeline{grid-template-columns:1fr 1fr}.timeline::before{display:none}
  .why-wrap{grid-template-columns:1fr}
  .why-left{border-right:none;padding-right:0;padding-bottom:3rem;border-bottom:1px solid var(--line)}
  .why-right{padding-left:0}
  .foot-wrap{grid-template-columns:1fr;text-align:center}
  .foot-nav,.foot-right{justify-content:center}
  .ch-grid{grid-template-columns:1fr;gap:3rem}
  .ch-info{position:static}
  .ps-grid{grid-template-columns:1fr;gap:1.5rem}
  .meta-bar{grid-template-columns:1fr 1fr}
  .mi{border-bottom:1px solid var(--line)}.mi:nth-child(even){border-right:none}
  .res-grid{grid-template-columns:1fr 1fr}
  .all-grid{grid-template-columns:repeat(2,1fr)}
}

/* ═══ RESPONSIVE — MOBILE (max 768px) ════════════════════════════ */
@media(max-width:768px){
  #ps-links,#ps-cta{display:none!important}
  #ps-ham{display:flex!important}
  #ps-nav.ps-open #ps-links{display:flex!important}
  #ps-nav-inner{padding:.85rem 1.5rem}
  .container{padding:0 1.25rem}
  #hero{padding:8rem 0 4rem}
  .hero-right{grid-template-columns:1fr 1fr}
  .hero-deco{display:none}
  .svc-item{grid-template-columns:44px 1fr;gap:1rem;padding:1.75rem 0}
  .svc-name{font-size:1.1rem}
  .svc-num{font-size:2.5rem}
  .pgrid{grid-template-columns:1fr}
  .pc1,.pc2,.pc3,.pc4,.pc5{grid-column:span 1;grid-row:auto}
  .timeline{grid-template-columns:1fr}
  .evt-inner{padding:2rem}
  .pills{grid-template-columns:1fr 1fr}
  .cta-inner{padding:3.5rem 1.5rem}
  .cta-inner::before{display:none}
  .hero-scroll{display:none}
  .proc-top{flex-direction:column}
  .mock-grid.g2{grid-template-columns:1fr}
  .res-grid{grid-template-columns:1fr}
  .fr{grid-template-columns:1fr}
  .all-grid{grid-template-columns:1fr}
  .hstat{padding:1.5rem}
  .hs-num{font-size:2.5rem}
  .bstat-n{font-size:3rem}
  .port-hdr{flex-direction:column;align-items:flex-start}
  .why-left,.why-right{padding-left:0;padding-right:0}
  .cta-h2{font-size:clamp(2rem,8vw,3rem)}
  .foot-wrap{gap:1.5rem}
  .proj-title{font-size:clamp(2rem,7vw,3rem)}
  .meta-bar{grid-template-columns:1fr 1fr}
  .breadcrumb{font-size:.7rem}
}

/* ═══ RESPONSIVE — SMALL MOBILE (max 480px) ══════════════════════ */
@media(max-width:480px){
  .pills{grid-template-columns:1fr}
  .hero-acts{flex-direction:column;align-items:flex-start;gap:.75rem}
  .hero-right{grid-template-columns:1fr}
  .hstat{padding:1.25rem}
  .cta-acts{flex-direction:column;align-items:center}
  .btn{width:100%;justify-content:center}
  .meta-bar{grid-template-columns:1fr}
  .mi:nth-child(even){border-right:1px solid var(--line)}
  .mi{border-right:none}
  .all-grid{grid-template-columns:1fr}
  .svc-item{grid-template-columns:40px 1fr;gap:1rem}
  .svc-num{font-size:2rem}
}

/* Scroll offset for fixed nav */
section[id],div[id]{scroll-margin-top:70px}

@media(max-width:640px){.all-grid{grid-template-columns:1fr!important}}

* {box-sizing:border-box}
html{scroll-padding-top:70px}

/* ═══ REDUCED MOTION ACCESSIBILITY ════════════════════════════ */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.01ms!important;
    animation-iteration-count:1!important;
    transition-duration:.01ms!important;
    scroll-behavior:auto!important;
  }
  .word-inner{transform:none!important;opacity:1!important}
  .reveal{opacity:1!important;transform:none!important}
  .hero-deco{animation:none!important}
  .div-track{animation:none!important}
  .scroll-bar{animation:none!important}
  .evt-ribbon .pulse{animation:none!important}
}

/* ═══════════════════════════════════════════════════════════════
   PREMIO STUDIO — 2026 UPGRADE LAYER
   Append-only additions — do not modify above lines
   ═══════════════════════════════════════════════════════════════ */

/* ── NOISE TEXTURE on body ─────────────────────────────────────*/
body::after{
  content:'';position:fixed;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");
  opacity:.028;pointer-events:none;z-index:1;
}

/* ── PAGE TRANSITIONS ──────────────────────────────────────────*/
body.page-enter{opacity:0;}
body.page-visible{opacity:1;transition:opacity .3s ease;}
body.page-leaving{opacity:0;transition:opacity .25s ease;}

/* ── CUSTOM CURSOR ─────────────────────────────────────────────*/
#ps-cursor{
  position:fixed;width:44px;height:44px;border-radius:50%;
  border:1px solid rgba(0,196,212,.6);pointer-events:none;z-index:99999;
  opacity:0;transition:transform .08s linear,border-color .3s,width .3s cubic-bezier(.34,1.56,.64,1),height .3s cubic-bezier(.34,1.56,.64,1),background .3s;
  mix-blend-mode:normal;
}
#ps-cursor-dot{
  position:fixed;width:8px;height:8px;border-radius:50%;
  background:var(--cyan);pointer-events:none;z-index:100000;
  opacity:0;transition:transform .05s linear;
}
#ps-cursor.cursor-hover{
  width:64px;height:64px;border-color:var(--gold);
  background:rgba(200,168,75,.06);
}
@media(hover:none),(max-width:768px){
  #ps-cursor,#ps-cursor-dot{display:none!important;}
}

/* ── WHATSAPP FLOAT ────────────────────────────────────────────*/
#ps-whatsapp{
  position:fixed;bottom:2rem;right:2rem;z-index:9998;
  width:52px;height:52px;border-radius:50%;
  background:#25D366;color:#fff;
  display:flex;align-items:center;justify-content:center;
  text-decoration:none;box-shadow:0 4px 24px rgba(37,211,102,.35);
  transition:transform .3s cubic-bezier(.34,1.56,.64,1),box-shadow .3s;
  overflow:hidden;
}
#ps-whatsapp:hover{
  transform:scale(1.1);box-shadow:0 8px 32px rgba(37,211,102,.5);
  width:auto;padding:0 20px 0 16px;border-radius:999px;
}
#ps-whatsapp svg{flex-shrink:0;}
#ps-whatsapp .wa-label{
  font-family:var(--fb);font-size:.82rem;font-weight:600;
  white-space:nowrap;max-width:0;overflow:hidden;
  transition:max-width .3s ease,margin-left .3s ease;margin-left:0;
}
#ps-whatsapp:hover .wa-label{max-width:160px;margin-left:10px;}
/* Pulse ring */
#ps-whatsapp::before{
  content:'';position:absolute;inset:0;border-radius:50%;
  border:2px solid #25D366;animation:wa-pulse 2.5s ease infinite;
}
@keyframes wa-pulse{
  0%{transform:scale(1);opacity:.6}
  70%{transform:scale(1.5);opacity:0}
  100%{transform:scale(1.5);opacity:0}
}
#ps-whatsapp:hover::before{animation:none;}

/* ── KINETIC HEADLINE ──────────────────────────────────────────*/
#word-cycle{
  display:inline;font-style:italic;font-family:var(--fs);
  font-weight:300;color:var(--cyan);font-size:1.05em;
  transition:opacity .38s ease, transform .38s ease;
}
#word-cycle.word-exit{opacity:0;transform:translateY(-12px);}
#word-cycle.word-enter{animation:wordIn .5s cubic-bezier(.16,1,.3,1) forwards;}
@keyframes wordIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}

/* ── TESTIMONIALS SECTION ──────────────────────────────────────*/
#testimonials{padding:9rem 0;border-top:1px solid var(--line);}
.testi-hdr{display:grid;grid-template-columns:1fr 1fr;gap:4rem;margin-bottom:4rem;align-items:end;}
.testi-h2{font-family:var(--fd);font-weight:800;font-size:clamp(2rem,4vw,3.2rem);letter-spacing:-.04em;line-height:.98;}
.testi-h2 em{font-style:italic;font-family:var(--fs);font-weight:300;color:var(--gold);}
.testi-sub{color:var(--warm2);font-size:.93rem;line-height:1.85;font-weight:300;align-self:end;}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);}
.tcard{background:var(--ink);padding:2.5rem;position:relative;transition:background .3s;}
.tcard:hover{background:var(--ink2);}
.tcard::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--gold),transparent);
  transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease);}
.tcard:hover::before{transform:scaleX(1);}
.tq{font-family:var(--fs);font-size:1.18rem;font-style:italic;font-weight:300;
  line-height:1.65;color:var(--warm);margin-bottom:2rem;}
.tq::before{content:'\201C';font-size:3rem;line-height:.5;display:block;
  color:var(--gold);opacity:.4;margin-bottom:.75rem;font-style:normal;}
.tauthor{display:flex;align-items:center;gap:1rem;}
.tavatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;
  justify-content:center;font-family:var(--fd);font-size:.75rem;font-weight:700;
  flex-shrink:0;border:1px solid;}
.tname{font-family:var(--fd);font-size:.88rem;font-weight:700;letter-spacing:-.01em;}
.trole{font-size:.73rem;color:var(--warm3);margin-top:2px;}

/* ── ENHANCED BENTO PORTFOLIO GRID ────────────────────────────*/
/* Hero card now spans 2 rows on desktop */
@media(min-width:1101px){
  .pgrid{grid-template-columns:2fr 1fr 1fr;grid-template-rows:auto auto;}
  .pc1{grid-column:1;grid-row:1/3;}
  .pc1 .pc-img img,.pc1 .pc-img svg{height:100%;min-height:480px;}
  .pc1 .pc-img{flex:1;min-height:480px;}
  .pc2{grid-column:2;grid-row:1;}
  .pc3{grid-column:3;grid-row:1;}
  .pc3 .pc-img img,.pc3 .pc-img svg{height:220px;}
  .pc4{grid-column:2;grid-row:2;}
  .pc5{grid-column:3;grid-row:2;}
  .pc2 .pc-img img,.pc2 .pc-img svg,
  .pc4 .pc-img img,.pc4 .pc-img svg,
  .pc5 .pc-img img,.pc5 .pc-img svg{height:220px;}
}

/* ── NAV SCROLLED GLOW ─────────────────────────────────────────*/
#ps-nav[data-scrolled]{
  box-shadow:0 1px 0 rgba(0,196,212,.05),0 8px 40px rgba(0,0,0,.4);
}

/* ── SERVICE ITEM HOVER — left accent bar ──────────────────────*/
.svc-item{padding-left:1.5rem;transition:background .3s,padding-left .3s;}
.svc-item::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;
  background:var(--cyan);transform:scaleY(0);transform-origin:bottom;transition:transform .4s var(--ease);}
.svc-item:hover::before{transform:scaleY(1);}

/* ── PROCESS STEP HOVER NUMBERS ────────────────────────────────*/
.tl-step:hover .tl-dot{
  background:var(--gold-pale);color:var(--gold);
  box-shadow:0 0 0 6px rgba(200,168,75,.08),0 0 30px rgba(200,168,75,.15);
}

/* ── SECTION DIVIDER ENHANCEMENT ──────────────────────────────*/
.div-gem{width:6px;height:6px;animation:gem-spin 4s linear infinite;}
@keyframes gem-spin{to{transform:rotate(360deg);}}

/* ── HERO SCROLL INDICATOR PULSE ──────────────────────────────*/
.scroll-bar{animation:scroll-pulse 2s ease-in-out infinite;}
@keyframes scroll-pulse{
  0%,100%{opacity:1;transform:scaleY(1);}
  50%{opacity:.3;transform:scaleY(.6);}
}

/* ── ENHANCED CARD SHADOWS ─────────────────────────────────────*/
.pc:hover{box-shadow:0 32px 80px rgba(0,0,0,.5),0 0 0 1px rgba(255,255,255,.08);}
.pcard:hover{box-shadow:0 32px 80px rgba(0,0,0,.5),0 0 0 1px rgba(255,255,255,.08);}

/* ── CTA GHOST TEXT UPDATE ─────────────────────────────────────*/
/* Handled in HTML — changed from "WORK" to "STUDIO" */

/* ── TESTIMONIAL RESPONSIVE ────────────────────────────────────*/
@media(max-width:1100px){
  .testi-hdr{grid-template-columns:1fr;gap:1.5rem;}
  .testi-grid{grid-template-columns:1fr;}
}
@media(max-width:768px){
  #testimonials{padding:6rem 0;}
  .tcard{padding:2rem;}
  .tq{font-size:1.05rem;}
}

/* ── REDUCED MOTION (complete) ─────────────────────────────────*/
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.01ms!important;
    animation-iteration-count:1!important;
    transition-duration:.01ms!important;
    scroll-behavior:auto!important;
  }
  .word-inner{transform:none!important;opacity:1!important;}
  .reveal{opacity:1!important;transform:none!important;}
  .hero-deco{animation:none!important;}
  .div-track{animation:none!important;}
  .scroll-bar,.div-gem{animation:none!important;}
  .evt-ribbon .pulse{animation:none!important;}
  #word-cycle{transition:none!important;}
  #ps-whatsapp::before{animation:none!important;}
  body.page-enter,body.page-visible,body.page-leaving{opacity:1!important;transition:none!important;}
}

/* ═══════════════════════════════════════════════════════════════
   LOGO & BRAND ORANGE — #FF3301 Integration Layer
   ═══════════════════════════════════════════════════════════════ */

/* Brand orange variable */
:root{
  --orange:#FF3301;
  --orange-pale:rgba(255,51,1,.08);
  --orange-mid:rgba(255,51,1,.18);
}

/* ── NAV LOGO ──────────────────────────────────────────────────*/
.ps-logo-wrap{
  display:flex;align-items:center;gap:10px;text-decoration:none;
}
.ps-logo-mark{
  width:32px;height:32px;flex-shrink:0;
  transition:transform .4s cubic-bezier(.34,1.56,.64,1);
}
#ps-nav:hover .ps-logo-mark,
.ps-logo-wrap:hover .ps-logo-mark{
  transform:rotate(30deg) scale(1.08);
}
.ps-logo-text{display:flex;flex-direction:column;line-height:1;}
.ps-logo-name{
  font-family:'Bricolage Grotesque',sans-serif;
  font-size:17px;font-weight:800;letter-spacing:-.03em;
  color:#F3EDE6;
}
.ps-logo-sub{
  font-family:'DM Sans',sans-serif;
  font-size:7.5px;font-weight:400;letter-spacing:.32em;
  color:#9A938A;text-transform:uppercase;margin-top:1px;
}

/* ── ORANGE as brand accent — strategic placements ─────────────*/

/* Hero tag line dash */
.tag-line::before{background:var(--orange);}

/* Service numbers */
.svc-n{color:var(--orange)!important;}

/* Process step active dot border */
.tl-step:nth-child(1) .tl-dot{border-color:var(--orange);color:var(--orange);}
.tl-step:nth-child(1):hover .tl-dot{background:var(--orange-pale);box-shadow:0 0 0 6px var(--orange-pale),0 0 30px rgba(255,51,1,.12);}

/* Portfolio badge — first/hero card */
.pc1 .pc-badge{background:var(--orange);color:#fff;}

/* CTA section — primary button hover glow */
.btn-cy:hover{box-shadow:0 8px 32px rgba(255,51,1,.25),0 0 0 1px var(--orange);}

/* Why section — first bullet icon */
.wpt:nth-child(1) .wpt-ico{color:var(--orange);border-color:rgba(255,51,1,.25);}
.wpt:nth-child(1):hover .wpt-ico{background:var(--orange-pale);border-color:rgba(255,51,1,.3);}

/* Testimonial first card top bar */
.tcard:nth-child(1)::before{background:linear-gradient(90deg,var(--orange),transparent);}

/* Event partnership section ribbon/accent */
.evt-ribbon{border-color:rgba(255,51,1,.3)!important;background:rgba(255,51,1,.04)!important;}
.evt-ribbon .pulse{background:var(--orange)!important;}

/* Footer logo area bottom accent line */
.foot-brand-line{
  width:28px;height:2px;
  background:linear-gradient(90deg,var(--orange),var(--gold));
  margin-top:10px;border-radius:2px;
}

/* ── SCROLL PROGRESS BAR — orange ─────────────────────────────*/
#progress{background:linear-gradient(90deg,var(--orange),var(--gold),var(--cyan))!important;}

/* ── HERO — orange in gradient on deco text ────────────────────*/
.hero-deco{
  background:linear-gradient(135deg,rgba(255,51,1,.06),rgba(200,168,75,.04));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}

/* ── FAVICON — update to use orange mark ──────────────────────*/
/* (handled in HTML head) */

/* ── PORTFOLIO PAGE badge for pitch deck ──────────────────────*/
.pbadge[data-type="Presentation"]{background:rgba(255,51,1,.15);color:var(--orange);border:1px solid rgba(255,51,1,.25);}

/* ── CONTACT PAGE — active field border ───────────────────────*/
input:focus,select:focus,textarea:focus{
  border-color:rgba(255,51,1,.5)!important;
  box-shadow:0 0 0 3px rgba(255,51,1,.08)!important;
}

/* ── CASE STUDY pages — accent override ───────────────────────*/
.rc-label{color:var(--orange)!important;}

/* ── MARQUEE / DIVIDER dots ───────────────────────────────────*/
.div-gem{fill:var(--orange)!important;color:var(--orange)!important;}
