/* ═══════════════════════════════════════════════════════════
   PROJECOST — SHARED STYLES
   Aesthetic: Modern Professional, Clean, Confident
   Typography: Outfit (display) + Source Serif 4 (accent) + JetBrains Mono (mono)
   Palette: Cool grays, slate, navy accent, warm gold touch
   ═══════════════════════════════════════════════════════════ */

:root {
  --bg: #F6F7F9;
  --surface: #FFFFFF;
  --card: #FFFFFF;
  --card-hover: #FAFBFC;
  --border: #E4E7EC;
  --border-hover: #CDD3DC;
  --accent: #1B3A5C;
  --accent-light: #2A5A8C;
  --accent-pale: #EDF2F8;
  --accent-glow: rgba(27,58,92,0.06);
  --gold: #B8943F;
  --gold-light: #D4AF5E;
  --gold-pale: #FAF6ED;
  --heading: #111827;
  --text: #374151;
  --text-dim: #6B7280;
  --text-muted: #9CA3AF;
  --white: #FFFFFF;
  --dark: #111827;
  --display: 'Outfit', sans-serif;
  --serif: 'Source Serif 4', Georgia, serif;
  --body: 'Outfit', system-ui, sans-serif;
  --mono: 'JetBrains Mono', monospace;
  --ease: cubic-bezier(.22,1,.36,1);
  --ease-out: cubic-bezier(0,.55,.45,1);
  --shadow-sm: 0 1px 3px rgba(0,0,0,.04), 0 1px 2px rgba(0,0,0,.03);
  --shadow-md: 0 4px 16px rgba(0,0,0,.05), 0 1px 4px rgba(0,0,0,.03);
  --shadow-lg: 0 12px 40px rgba(0,0,0,.07), 0 4px 12px rgba(0,0,0,.03);
  --shadow-xl: 0 20px 60px rgba(0,0,0,.08);
  --radius: 12px;
}

/* RESET */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;-webkit-font-smoothing:antialiased;scroll-behavior:smooth}
body{font-family:var(--body);color:var(--text);background:var(--bg);line-height:1.6;overflow-x:hidden;cursor:none}
a{color:inherit;text-decoration:none;cursor:none}
button{font-family:var(--body);cursor:none;border:none;background:none}
ul{list-style:none}
img{display:block;max-width:100%}
::selection{background:var(--accent);color:#fff}
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--border-hover);border-radius:3px}

/* ── CUSTOM CURSOR ── */
.cursor{position:fixed;top:0;left:0;width:12px;height:12px;background:var(--accent);border-radius:50%;pointer-events:none;z-index:9999;mix-blend-mode:multiply;transition:transform .15s var(--ease),width .2s,height .2s}
.cursor.hover{width:48px;height:48px;background:rgba(27,58,92,.08);border:1.5px solid var(--accent)}
.cursor-dot{position:fixed;top:0;left:0;width:4px;height:4px;background:var(--accent);border-radius:50%;pointer-events:none;z-index:10000;transition:opacity .2s}
@media(max-width:768px){.cursor,.cursor-dot{display:none}body,a,button{cursor:auto}}

/* ── NOISE TEXTURE OVERLAY ── */
.noise{position:fixed;inset:0;pointer-events:none;z-index:9000;opacity:.025}
.noise::after{content:'';position:absolute;inset:-200%;width:400%;height:400%;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");animation:noise .3s steps(3) infinite}
@keyframes noise{0%{transform:translate(0,0)}33%{transform:translate(-10px,5px)}66%{transform:translate(5px,-10px)}100%{transform:translate(0,0)}}

/* ── SCROLL REVEAL ── */
[data-reveal]{opacity:0;transform:translateY(30px);transition:opacity .7s var(--ease),transform .8s var(--ease)}
[data-reveal].vis{opacity:1;transform:translateY(0)}
[data-reveal="up"]{transform:translateY(50px)}
[data-reveal="up"].vis{transform:translateY(0)}
[data-reveal="left"]{transform:translateX(-30px)}
[data-reveal="left"].vis{transform:translateX(0)}
[data-reveal="scale"]{transform:scale(.95);opacity:0}
[data-reveal="scale"].vis{transform:scale(1);opacity:1}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}.d4{transition-delay:.4s}.d5{transition-delay:.5s}

/* ── LAYOUT ── */
.container{max-width:1280px;margin:0 auto;padding:0 40px}
@media(max-width:768px){.container{padding:0 20px}}

/* ═══════════════════════════════════════════════════════════
   NAVIGATION
   ═══════════════════════════════════════════════════════════ */
.nav{position:fixed;top:0;left:0;right:0;z-index:8000;padding:0 40px;background:rgba(255,255,255,.8);backdrop-filter:blur(20px);border-bottom:1px solid transparent;transition:all .3s}
.nav.solid{border-bottom-color:var(--border);box-shadow:var(--shadow-sm)}
.nav-inner{max-width:1280px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;height:72px}
.nav-logo{display:flex;align-items:center;gap:12px}
.nav-logo-icon{font-family:var(--display);font-size:12px;font-weight:800;letter-spacing:3px;color:var(--white);padding:8px 12px;background:var(--accent);border-radius:6px}
.nav-logo-text{font-family:var(--display);font-size:11px;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:var(--heading)}
.nav-links{display:flex;gap:32px}
.nav-link{font-size:13px;font-weight:500;color:var(--text-dim);transition:color .3s;position:relative}
.nav-link:hover,.nav-link.active{color:var(--accent)}
.nav-link::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--accent);border-radius:1px;transition:width .3s var(--ease)}
.nav-link:hover::after,.nav-link.active::after{width:100%}
.nav-cta-wrap{position:relative}
.nav-cta{font-size:13px;font-weight:600;color:var(--white);background:var(--accent);padding:10px 24px;border-radius:8px;transition:all .3s var(--ease);display:inline-block}
.nav-cta:hover{background:var(--accent-light);box-shadow:var(--shadow-md);transform:translateY(-1px)}
.nav-toggle{display:none;color:var(--heading);font-size:24px}
.nav-close{display:none !important}
.nav-mobile-cta{display:none !important}
@media(max-width:900px){
  .nav{padding:0 20px}
  .nav-cta-wrap{display:none}
  .nav-toggle{display:block;font-size:28px;padding:4px;z-index:9600;position:relative}
  .nav-links{display:none}
  .nav-links.open{display:flex !important;flex-direction:column;position:fixed;top:0;left:0;right:0;bottom:0;width:100vw;height:100vh;height:100dvh;background:#FFFFFF;z-index:9500;align-items:center;justify-content:center;gap:28px;padding:80px 40px;overflow:hidden}
  .nav-links.open .nav-link{font-size:22px;font-weight:600;letter-spacing:2px;color:var(--heading)}
  .nav-links.open .nav-link.active{color:var(--accent)}
  .nav-links.open .nav-link::after{display:none}
  .nav-links.open .nav-mobile-cta{display:inline-flex !important;margin-top:12px}
  .nav-links.open .nav-close{display:block !important;position:absolute;top:24px;right:24px;font-size:32px;color:var(--heading);z-index:9600;padding:4px 8px;cursor:pointer;background:none;border:none}
  .nav-links.open ~ .nav-toggle{display:none}
}

/* ═══════════════════════════════════════════════════════════
   PAGE HEADER (inner pages)
   ═══════════════════════════════════════════════════════════ */
.page-header{padding:160px 0 80px;background:var(--white);position:relative;overflow:hidden}
.page-header-bg{position:absolute;inset:0;z-index:0}
.page-header-dots{position:absolute;top:0;right:0;width:40%;height:100%;background-image:radial-gradient(circle,var(--border) 1px,transparent 1px);background-size:24px 24px;opacity:.4}
.page-header-orb{position:absolute;border-radius:50%;filter:blur(100px);z-index:0;animation:float 20s ease-in-out infinite}
.page-header-orb-1{width:400px;height:400px;background:rgba(27,58,92,.05);top:-100px;right:-50px}
.page-header-orb-2{width:300px;height:300px;background:rgba(184,148,63,.04);bottom:-80px;left:-60px;animation-delay:-7s}
@keyframes float{0%,100%{transform:translate(0,0) scale(1)}25%{transform:translate(30px,-20px) scale(1.05)}50%{transform:translate(-20px,30px) scale(.95)}75%{transform:translate(20px,10px) scale(1.02)}}
.page-header .container{position:relative;z-index:1}
.page-header .section-label{margin-bottom:12px}
.page-header-title{font-family:var(--display);font-size:clamp(36px,5vw,64px);font-weight:800;line-height:1.05;color:var(--heading);letter-spacing:-1.5px;margin-bottom:16px}
.page-header-title .it{font-family:var(--serif);font-style:italic;font-weight:400;color:var(--accent)}
.page-header-desc{font-size:16px;color:var(--text-dim);max-width:600px;line-height:1.7}
.page-header-breadcrumb{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-muted);margin-bottom:20px}
.page-header-breadcrumb a{color:var(--accent);font-weight:500;transition:color .2s}
.page-header-breadcrumb a:hover{color:var(--accent-light)}
.page-header-breadcrumb span{color:var(--text-muted)}

/* ═══════════════════════════════════════════════════════════
   SHARED SECTION STYLES
   ═══════════════════════════════════════════════════════════ */
.section{padding:100px 0}
.section-label{font-family:var(--mono);font-size:11px;font-weight:500;letter-spacing:3px;text-transform:uppercase;color:var(--accent);margin-bottom:10px;display:flex;align-items:center;gap:10px}
.section-label::before{content:'';width:16px;height:2px;background:var(--accent);border-radius:1px}
.section-title{font-family:var(--display);font-size:clamp(28px,4vw,48px);font-weight:800;line-height:1.08;color:var(--heading);letter-spacing:-1px;margin-bottom:14px}
.section-title .it{font-family:var(--serif);font-style:italic;font-weight:400;color:var(--accent)}
.section-desc{font-size:15px;font-weight:400;color:var(--text-dim);max-width:520px;line-height:1.7}
@media(max-width:768px){.section{padding:72px 0}}

/* ═══════════════════════════════════════════════════════════
   BUTTONS
   ═══════════════════════════════════════════════════════════ */
.btn-primary{display:inline-flex;align-items:center;gap:8px;padding:14px 32px;background:var(--accent);color:var(--white);font-size:14px;font-weight:600;letter-spacing:.3px;border-radius:10px;transition:all .3s var(--ease);position:relative;overflow:hidden}
.btn-primary:hover{background:var(--accent-light);transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.btn-primary .arrow{transition:transform .3s}.btn-primary:hover .arrow{transform:translateX(3px)}
.btn-secondary{display:inline-flex;align-items:center;gap:8px;padding:14px 32px;border:1.5px solid var(--border);color:var(--text);font-size:14px;font-weight:500;border-radius:10px;transition:all .3s var(--ease);background:var(--white)}
.btn-secondary:hover{border-color:var(--accent);color:var(--accent);box-shadow:var(--shadow-sm)}
.btn-gold{display:inline-flex;align-items:center;gap:8px;padding:14px 32px;background:var(--gold);color:var(--white);font-size:14px;font-weight:600;border-radius:10px;transition:all .3s var(--ease)}
.btn-gold:hover{background:var(--gold-light);transform:translateY(-2px);box-shadow:0 12px 40px rgba(184,148,63,.2)}

/* ═══════════════════════════════════════════════════════════
   HERO (Home only)
   ═══════════════════════════════════════════════════════════ */
.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding:120px 0 80px;position:relative;overflow:hidden;background:var(--white)}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg-shape{position:absolute;border-radius:50%;opacity:1;z-index:0}
.hero-bg-shape-1{width:700px;height:700px;top:-200px;right:-150px;background:radial-gradient(circle,rgba(27,58,92,.04) 0%,transparent 70%)}
.hero-bg-shape-2{width:500px;height:500px;bottom:-100px;left:-100px;background:radial-gradient(circle,rgba(184,148,63,.04) 0%,transparent 70%)}
.hero-grid-dots{position:absolute;top:0;right:0;width:40%;height:100%;background-image:radial-gradient(circle,var(--border) 1px,transparent 1px);background-size:24px 24px;opacity:.5;z-index:0}
.hero-orb{position:absolute;border-radius:50%;filter:blur(100px);z-index:1;animation:float 20s ease-in-out infinite}
.hero-orb-1{width:500px;height:500px;background:rgba(27,58,92,.06);top:-10%;right:10%}
.hero-orb-2{width:350px;height:350px;background:rgba(184,148,63,.05);bottom:10%;left:-5%;animation-delay:-7s}
.hero-orb-3{width:250px;height:250px;background:rgba(27,58,92,.04);top:40%;left:40%;animation-delay:-14s}
.hero-content{position:relative;z-index:2;padding:0 40px;max-width:1280px;margin:0 auto;width:100%}
.hero-overline{font-family:var(--mono);font-size:11px;font-weight:500;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-bottom:20px;display:flex;align-items:center;gap:10px}
.hero-overline::before{content:'';width:32px;height:2px;background:var(--gold);border-radius:1px}
.hero-title{font-family:var(--display);font-size:clamp(40px,6.5vw,84px);font-weight:800;line-height:1.02;color:var(--heading);margin-bottom:20px;letter-spacing:-2px}
.hero-title .line{display:block;overflow:hidden}
.hero-title .line-inner{display:block;transform:translateY(110%);animation:slideUp .8s var(--ease) forwards}
.hero-title .line:nth-child(2) .line-inner{animation-delay:.12s}
.hero-title .line:nth-child(3) .line-inner{animation-delay:.24s}
@keyframes slideUp{to{transform:translateY(0)}}
.hero-title .italic{font-family:var(--serif);font-style:italic;font-weight:400;color:var(--accent)}
.hero-desc{font-size:clamp(15px,1.3vw,17px);font-weight:400;color:var(--text-dim);max-width:540px;line-height:1.7;margin-bottom:36px;opacity:0;animation:fadeIn .8s var(--ease) .5s forwards}
@keyframes fadeIn{to{opacity:1}}
.hero-actions{display:flex;gap:12px;align-items:center;opacity:0;animation:fadeIn .8s var(--ease) .7s forwards;flex-wrap:wrap}
.hero-stats-bar{position:relative;z-index:2;margin-top:72px;padding-top:32px;border-top:1px solid var(--border)}
.hero-stats-inner{max-width:1280px;margin:0 auto;padding:0 40px;display:flex;gap:56px;flex-wrap:wrap}
.hero-stat{display:flex;flex-direction:column}
.hero-stat-num{font-family:var(--display);font-size:clamp(32px,4vw,52px);font-weight:800;color:var(--accent);line-height:1;letter-spacing:-1px}
.hero-stat-label{font-size:12px;font-weight:500;color:var(--text-muted);margin-top:4px;letter-spacing:.5px}
@media(max-width:768px){.hero-stats-inner{gap:24px}.hero-stat-num{font-size:32px}}

/* ═══════════════════════════════════════════════════════════
   MARQUEE
   ═══════════════════════════════════════════════════════════ */
.marquee{border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:14px 0;overflow:hidden;background:var(--bg)}
.marquee-track{display:flex;gap:0;animation:marquee 45s linear infinite;width:max-content}
.marquee-item{white-space:nowrap;padding:0 28px;font-size:12px;font-weight:500;letter-spacing:1px;text-transform:uppercase;color:var(--text-muted);display:flex;align-items:center;gap:20px}
.marquee-item::after{content:'·';color:var(--accent);font-size:14px;font-weight:700}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ═══════════════════════════════════════════════════════════
   SERVICE CARDS
   ═══════════════════════════════════════════════════════════ */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:52px}
.svc-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:36px 28px;transition:all .4s var(--ease);position:relative;overflow:hidden}
.svc-card::after{content:'';position:absolute;top:0;left:0;width:100%;height:100%;background:radial-gradient(circle at var(--mx,50%) var(--my,50%),rgba(27,58,92,.06) 0%,transparent 60%);opacity:0;transition:opacity .4s;pointer-events:none}
.svc-card:hover::after{opacity:1}
.svc-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--accent);border-radius:var(--radius) var(--radius) 0 0;opacity:0;transition:opacity .3s;z-index:1}
.svc-card:hover{border-color:var(--border-hover);transform:translateY(-3px);box-shadow:var(--shadow-md)}
.svc-card:hover::before{opacity:1}
.svc-card.featured{grid-row:span 2;background:var(--accent-pale);border-color:rgba(27,58,92,.12)}
.svc-card.featured::before{opacity:1;background:var(--accent)}
.svc-num{font-family:var(--mono);font-size:13px;font-weight:500;color:var(--accent);opacity:.4;margin-bottom:16px}
.svc-card h3{font-family:var(--display);font-size:18px;font-weight:700;color:var(--heading);margin-bottom:8px}
.svc-card p,.svc-card .svc-lead{font-size:13.5px;color:var(--text-dim);line-height:1.65}
.svc-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:16px}
.svc-tag{padding:4px 12px;border:1px solid var(--border);border-radius:100px;font-size:10px;font-weight:500;letter-spacing:.5px;text-transform:uppercase;color:var(--text-muted);transition:all .3s;background:var(--bg)}
.svc-card:hover .svc-tag{border-color:var(--accent);color:var(--accent);background:var(--accent-pale)}
.svc-subs{display:flex;flex-direction:column;gap:0;margin-top:14px;padding-top:14px;border-top:1px solid var(--border)}
.svc-sub{display:flex;align-items:flex-start;gap:10px;padding:6px 0;font-size:12.5px;color:var(--text-dim);line-height:1.5}
.svc-sub::before{content:'';width:5px;height:5px;border-radius:1px;background:var(--accent);opacity:.3;flex-shrink:0;margin-top:6px}
.svc-card:hover .svc-sub::before{opacity:.6}
.svc-card.featured .svc-subs{border-top-color:rgba(27,58,92,.12)}
@media(max-width:900px){.svc-grid{grid-template-columns:1fr}.svc-card.featured{grid-row:span 1}}

/* ═══════════════════════════════════════════════════════════
   PROCESS TIMELINE
   ═══════════════════════════════════════════════════════════ */
.process-section{background:var(--white);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.process-header{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:end;margin-bottom:64px}
.process-header-right{font-size:14px;color:var(--text-dim);line-height:1.7;border-left:2px solid var(--accent);padding-left:24px}
.process-timeline{position:relative;display:flex;flex-direction:column;gap:0}
.process-timeline::before{content:'';position:absolute;top:0;bottom:0;left:39px;width:2px;background:linear-gradient(180deg,var(--border) 0%,var(--accent) 50%,var(--border) 100%)}
.proc-item{display:flex;gap:32px;align-items:flex-start;padding:32px 0;position:relative;transition:all .3s}
.proc-item:first-child{padding-top:0}.proc-item:last-child{padding-bottom:0}
.proc-marker{width:80px;flex-shrink:0;display:flex;flex-direction:column;align-items:center;position:relative;z-index:1}
.proc-num{width:44px;height:44px;border-radius:12px;background:var(--bg);border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:12px;font-weight:600;color:var(--text-muted);transition:all .4s var(--ease)}
.proc-item:hover .proc-num{background:var(--accent);border-color:var(--accent);color:var(--white);transform:scale(1.1);box-shadow:var(--shadow-md)}
.proc-content{flex:1;padding:4px 0;max-width:700px}
.proc-content h4{font-family:var(--display);font-size:18px;font-weight:700;color:var(--heading);margin-bottom:6px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.proc-content h4 .proc-label{font-family:var(--mono);font-size:9px;font-weight:500;letter-spacing:2px;text-transform:uppercase;color:var(--accent);background:var(--accent-pale);padding:3px 10px;border-radius:4px}
.proc-content p{font-size:13.5px;color:var(--text-dim);line-height:1.65}
.proc-details{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.proc-detail{font-size:11px;font-weight:500;color:var(--text-muted);padding:4px 12px;background:var(--bg);border:1px solid var(--border);border-radius:6px;transition:all .3s}
.proc-item:hover .proc-detail{border-color:var(--accent);color:var(--accent);background:var(--accent-pale)}
@media(max-width:900px){.process-header{grid-template-columns:1fr}.proc-item{gap:20px}.proc-marker{width:60px}}

/* ═══════════════════════════════════════════════════════════
   WHY PCA
   ═══════════════════════════════════════════════════════════ */
.why-section{background:var(--accent);color:var(--white);overflow:hidden}
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
.why-left{padding-right:40px}
.why-left .section-label{color:var(--gold-light)}.why-left .section-label::before{background:var(--gold-light)}
.why-left .section-title{color:var(--white)}.why-left .section-title .it{color:var(--gold-light)}
.why-left .section-desc{color:rgba(255,255,255,.6)}
.why-items{display:flex;flex-direction:column;gap:0}
.why-item{padding:28px 0;border-bottom:1px solid rgba(255,255,255,.1);display:flex;gap:20px;align-items:flex-start}
.why-item:last-child{border-bottom:none}
.why-num{font-family:var(--mono);font-size:12px;font-weight:500;color:var(--gold-light);opacity:.6;flex-shrink:0;padding-top:4px}
.why-item h3{font-family:var(--display);font-size:17px;font-weight:600;color:var(--white);margin-bottom:5px}
.why-item p{font-size:13.5px;color:rgba(255,255,255,.55);line-height:1.6}
@media(max-width:900px){.why-grid{grid-template-columns:1fr;gap:40px}}

/* ═══════════════════════════════════════════════════════════
   PROJECTS ACCORDION
   ═══════════════════════════════════════════════════════════ */
.proj-summary{display:flex;gap:12px;flex-wrap:wrap;margin-top:28px}
.proj-summary-chip{padding:8px 16px;border-radius:8px;font-size:12px;font-weight:500;background:var(--white);border:1px solid var(--border);color:var(--text-dim);display:flex;align-items:center;gap:8px}
.proj-summary-chip .chip-dot{width:8px;height:8px;border-radius:2px;flex-shrink:0}
.proj-summary-chip .chip-ct{font-weight:700;color:var(--heading)}
.proj-accordion{display:flex;flex-direction:column;gap:8px;margin-top:8px}
.proj-acc{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:all .3s var(--ease)}
.proj-acc:hover{border-color:var(--border-hover)}
.proj-acc.open{border-color:var(--accent);box-shadow:var(--shadow-md)}
.proj-acc-head{display:flex;align-items:center;gap:14px;padding:18px 24px;cursor:pointer;transition:background .2s;user-select:none}
.proj-acc-head:hover{background:var(--bg)}
.proj-acc-dot{width:10px;height:10px;border-radius:3px;flex-shrink:0;transition:transform .3s}
.proj-acc.open .proj-acc-dot{transform:scale(1.3)}
.proj-acc-title{font-family:var(--display);font-size:15px;font-weight:600;color:var(--heading);flex:1}
.proj-acc-ct{font-size:11px;font-weight:600;color:var(--text-muted);padding:3px 10px;background:var(--bg);border-radius:6px;margin-right:8px}
.proj-acc.open .proj-acc-ct{background:var(--accent-pale);color:var(--accent)}
.proj-acc-chevron{width:20px;height:20px;color:var(--text-muted);transition:transform .3s var(--ease);flex-shrink:0}
.proj-acc.open .proj-acc-chevron{transform:rotate(180deg);color:var(--accent)}
.proj-acc-body{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.proj-acc.open .proj-acc-body{max-height:2000px}
.proj-acc-list{padding:0 24px 20px;display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:0}
.proj-row{padding:10px 14px;font-size:13px;color:var(--text-dim);line-height:1.55;border-radius:6px;transition:all .2s;border-left:2px solid transparent;display:flex;align-items:flex-start;gap:10px}
.proj-row::before{content:'';width:4px;height:4px;border-radius:1px;background:var(--border-hover);flex-shrink:0;margin-top:8px;transition:background .2s}
.proj-row:hover{background:var(--accent-pale);color:var(--accent);border-left-color:var(--accent)}
.proj-row:hover::before{background:var(--accent)}
@media(max-width:768px){.proj-acc-list{grid-template-columns:1fr}}

/* ═══════════════════════════════════════════════════════════
   CERTIFICATIONS
   ═══════════════════════════════════════════════════════════ */
.cert-badges{display:flex;gap:14px;flex-wrap:wrap;margin-top:44px}
.cert-badge{flex:1;min-width:240px;padding:28px 24px;border:1px solid var(--border);border-radius:var(--radius);background:var(--white);transition:all .4s var(--ease);position:relative;overflow:hidden}
.cert-badge::after{content:'';position:absolute;top:0;left:0;width:100%;height:100%;background:radial-gradient(circle at var(--mx,50%) var(--my,50%),rgba(184,148,63,.08) 0%,transparent 60%);opacity:0;transition:opacity .4s;pointer-events:none}
.cert-badge:hover::after{opacity:1}
.cert-badge::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--gold);border-radius:var(--radius) var(--radius) 0 0;opacity:0;transition:opacity .3s;z-index:1}
.cert-badge:hover{border-color:var(--gold);transform:translateY(-3px);box-shadow:var(--shadow-md)}.cert-badge:hover::before{opacity:1}
.cert-abbr{font-family:var(--display);font-size:28px;font-weight:800;color:var(--accent);line-height:1;margin-bottom:8px}
.cert-badge h4{font-size:14px;font-weight:600;color:var(--heading);margin-bottom:4px}
.cert-badge p{font-size:12px;color:var(--text-dim)}
.cert-agencies{margin-top:28px;padding:28px;background:var(--white);border:1px solid var(--border);border-radius:var(--radius)}
.cert-agencies h4{font-family:var(--mono);font-size:11px;font-weight:500;letter-spacing:2px;text-transform:uppercase;color:var(--text-muted);margin-bottom:16px}
.cert-agencies-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:4px}
.cert-ag{padding:7px 0;font-size:12.5px;color:var(--text-dim);display:flex;align-items:center;gap:8px;transition:color .2s}
.cert-ag:hover{color:var(--accent)}
.cert-ag::before{content:'';width:5px;height:5px;border-radius:2px;background:var(--accent);opacity:.2;flex-shrink:0}

/* ═══════════════════════════════════════════════════════════
   CTA BAND
   ═══════════════════════════════════════════════════════════ */
.cta{text-align:center;padding:100px 0;position:relative;overflow:hidden;background:var(--white)}
.cta::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 60% at 50% 50%,rgba(27,58,92,.03) 0%,transparent 70%)}
.cta-title{font-family:var(--display);font-size:clamp(26px,3.5vw,44px);font-weight:800;color:var(--heading);margin-bottom:14px;letter-spacing:-.5px;position:relative}
.cta p{font-size:15px;color:var(--text-dim);position:relative;margin-bottom:28px}

/* ═══════════════════════════════════════════════════════════
   CONTACT
   ═══════════════════════════════════════════════════════════ */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;margin-top:52px}
.contact-cards{display:flex;flex-direction:column;gap:10px}
.c-card{padding:20px 22px;background:var(--white);border:1px solid var(--border);border-radius:10px;display:flex;gap:14px;align-items:flex-start;transition:all .3s}
.c-card:hover{border-color:var(--accent);box-shadow:var(--shadow-sm)}
.c-card-icon{width:42px;height:42px;border-radius:8px;background:var(--accent-pale);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.c-card h4{font-size:13px;font-weight:600;color:var(--heading);margin-bottom:2px}
.c-card p{font-size:13px;color:var(--text-dim);line-height:1.5}
.c-card a{color:var(--accent);font-weight:500;transition:color .2s}.c-card a:hover{color:var(--accent-light)}
.form{display:flex;flex-direction:column;gap:12px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-group{display:flex;flex-direction:column;gap:5px}
.form-group label{font-size:11px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--text-muted)}
.form-group input,.form-group textarea,.form-group select{padding:12px 14px;background:var(--white);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:var(--body);font-size:13.5px;transition:border-color .3s,box-shadow .3s;outline:none}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
.form-group textarea{resize:vertical;min-height:110px}
.form-group select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239CA3AF' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}
@media(max-width:900px){.contact-grid{grid-template-columns:1fr;gap:36px}.form-row{grid-template-columns:1fr}}

/* ═══════════════════════════════════════════════════════════
   ABOUT PAGE SPECIFIC
   ═══════════════════════════════════════════════════════════ */
.about-split{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start}
.about-bio{position:relative}
.about-bio-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:40px;position:sticky;top:100px}
.about-bio-name{font-family:var(--display);font-size:24px;font-weight:800;color:var(--heading);margin-bottom:4px}
.about-bio-role{font-size:14px;color:var(--accent);font-weight:500;margin-bottom:4px}
.about-bio-creds{font-family:var(--mono);font-size:11px;color:var(--text-muted);letter-spacing:1px;margin-bottom:20px}
.about-bio-text{font-size:14px;color:var(--text-dim);line-height:1.7}
.about-bio-text p{margin-bottom:14px}
.about-cred-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:24px}
.about-cred{padding:16px;background:var(--bg);border-radius:8px;text-align:center}
.about-cred-abbr{font-family:var(--display);font-size:20px;font-weight:800;color:var(--accent);margin-bottom:2px}
.about-cred-label{font-size:10px;color:var(--text-muted);letter-spacing:.5px}
.about-story p{font-size:15px;color:var(--text-dim);line-height:1.8;margin-bottom:20px}
.about-values{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:48px}
.about-value{padding:28px 24px;background:var(--white);border:1px solid var(--border);border-radius:var(--radius);transition:all .3s}
.about-value:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.about-value h4{font-family:var(--display);font-size:16px;font-weight:700;color:var(--heading);margin-bottom:6px}
.about-value p{font-size:13px;color:var(--text-dim);line-height:1.6}
@media(max-width:900px){.about-split{grid-template-columns:1fr}.about-values{grid-template-columns:1fr}}

/* ═══════════════════════════════════════════════════════════
   CASE STUDY CARDS (Projects page)
   ═══════════════════════════════════════════════════════════ */
.case-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:48px}
.case-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:0;transition:all .4s var(--ease);position:relative;overflow:hidden}
.case-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;border-radius:var(--radius) var(--radius) 0 0;opacity:0;transition:opacity .3s}
.case-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--border-hover)}
.case-card:hover::before{opacity:1}
.case-img{width:100%;height:200px;object-fit:cover;display:block}
.case-img-placeholder{width:100%;height:200px;background:linear-gradient(135deg,var(--accent-pale) 0%,var(--bg) 100%);display:flex;align-items:center;justify-content:center;font-size:40px;color:var(--accent);opacity:.15}
.case-body{padding:28px 28px 32px}
.case-sector{font-family:var(--mono);font-size:10px;font-weight:500;letter-spacing:2px;text-transform:uppercase;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.case-sector::before{content:'';width:8px;height:8px;border-radius:2px;flex-shrink:0}
.case-card h3{font-family:var(--display);font-size:20px;font-weight:700;color:var(--heading);margin-bottom:10px}
.case-card .case-desc{font-size:13.5px;color:var(--text-dim);line-height:1.65;margin-bottom:16px}
.case-meta{display:flex;gap:20px;flex-wrap:wrap}
.case-meta-item{display:flex;flex-direction:column;gap:2px}
.case-meta-label{font-size:10px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--text-muted)}
.case-meta-val{font-size:13px;font-weight:600;color:var(--heading)}
@media(max-width:768px){.case-grid{grid-template-columns:1fr}}

/* ═══════════════════════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════════════════════ */
.footer{padding:56px 0 36px;border-top:1px solid var(--border);background:var(--white)}
.footer-grid{display:grid;grid-template-columns:2.5fr 1fr 1fr 1fr;gap:36px;margin-bottom:44px}
.footer-brand p{font-size:13px;color:var(--text-muted);line-height:1.6;margin-top:14px;max-width:320px}
.footer h5{font-family:var(--mono);font-size:10px;font-weight:500;letter-spacing:2px;text-transform:uppercase;color:var(--text-muted);margin-bottom:14px}
.footer-links li{margin-bottom:7px}
.footer-links a{font-size:13px;color:var(--text-dim);transition:color .2s}.footer-links a:hover{color:var(--accent)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:24px;border-top:1px solid var(--border);font-size:11px;color:var(--text-muted)}
@media(max-width:768px){.footer-grid{grid-template-columns:1fr 1fr;gap:24px}}

/* ═══════════════════════════════════════════════════════════
   MOBILE REFINEMENTS
   ═══════════════════════════════════════════════════════════ */
@media(max-width:768px){
  /* Page Header */
  .page-header{padding:120px 0 56px}
  .page-header-title{font-size:clamp(28px,8vw,40px)}
  .page-header-desc{font-size:14px}
  .page-header-dots{display:none}

  /* Hero */
  .hero{min-height:auto;padding:120px 0 60px}
  .hero-content{padding:0 20px}
  .hero-title{font-size:clamp(32px,9vw,48px)}
  .hero-desc{font-size:14px}
  .hero-actions{flex-direction:column;align-items:flex-start}
  .hero-actions .btn-primary,.hero-actions .btn-secondary{width:100%;justify-content:center}
  .hero-stats-bar{margin-top:48px}
  .hero-stats-inner{padding:0 20px;gap:20px}
  .hero-grid-dots{display:none}

  /* Buttons */
  .btn-primary,.btn-secondary,.btn-gold{padding:12px 24px;font-size:13px}

  /* Process Timeline */
  .process-header{gap:32px}
  .process-header-right{font-size:13px}
  .process-timeline::before{left:21px}
  .proc-marker{width:44px}
  .proc-num{width:36px;height:36px;font-size:11px;border-radius:8px}
  .proc-item{gap:16px;padding:24px 0}
  .proc-content h4{font-size:16px}
  .proc-content p{font-size:13px}
  .proc-details{gap:6px}
  .proc-detail{font-size:10px;padding:3px 8px}

  /* Service Cards */
  .svc-grid{gap:12px;margin-top:36px}
  .svc-card{padding:28px 22px}
  .svc-card h3{font-size:16px}

  /* Why PCA */
  .why-grid{gap:32px}
  .why-left{padding-right:0}
  .why-num{font-size:11px}
  .why-item{padding:20px 0;gap:14px}

  /* Projects Accordion */
  .proj-summary{gap:8px}
  .proj-summary-chip{padding:6px 12px;font-size:11px}
  .proj-acc-head{padding:14px 16px;gap:10px}
  .proj-acc-title{font-size:14px}
  .proj-acc-list{padding:0 16px 16px}
  .proj-row{padding:8px 10px;font-size:12px}

  /* Case Studies */
  .case-grid{gap:12px}
  .case-img{height:180px}
  .case-body{padding:22px 20px 26px}
  .case-card h3{font-size:17px}
  .case-meta{gap:14px}

  /* Certifications */
  .cert-badges{flex-direction:column}
  .cert-badge{min-width:unset}
  .cert-agencies{padding:20px}
  .cert-agencies-grid{grid-template-columns:1fr}

  /* Contact */
  .contact-grid{gap:32px}
  .c-card{padding:16px 18px}

  /* CTA */
  .cta{padding:72px 0}
  .cta-title{font-size:clamp(22px,6vw,32px)}

  /* About */
  .about-split{gap:40px}
  .about-bio-card{padding:28px;position:static}
  .about-cred-grid{grid-template-columns:1fr 1fr;gap:8px}
  .about-values{gap:10px}
  .about-value{padding:22px 20px}

  /* Footer */
  .footer{padding:40px 0 28px}
  .footer-bottom{flex-direction:column;gap:8px;text-align:center}
}
