/* PATH — Business & Marketing Solutions · website
   Layout styles. Tokens come from colors_and_type.css */

*{margin:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--font-sans);color:var(--fg-1);background:var(--bg-page);-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
button{font-family:inherit;cursor:pointer}
::selection{background:var(--path-azure);color:#fff}

.wrap{max-width:1180px;margin:0 auto;padding:0 32px}
section{position:relative}

/* ============ HEADER ============ */
.hdr{position:sticky;top:0;z-index:60;background:rgba(2,27,57,.78);backdrop-filter:blur(16px);
  border-bottom:1px solid var(--line-navy);transition:background .3s}
.hdr .bar{display:flex;align-items:center;justify-content:space-between;height:74px;gap:24px}
.hdr .logo{display:flex;align-items:center}
.hdr .logo img{height:30px;width:auto}
.hdr nav{display:flex;align-items:center;gap:34px}
.hdr nav a{font-size:14.5px;font-weight:400;color:var(--fg-on-navy);opacity:.8;letter-spacing:.01em;transition:opacity .18s}
.hdr nav a:hover{opacity:1}
.hdr .right{display:flex;align-items:center;gap:16px}
.menu-btn{display:none;background:none;border:none;color:var(--fg-on-navy);padding:6px}
.mobile-menu{border-top:1px solid var(--line-navy);padding:10px 32px 24px;background:rgba(2,27,57,.96)}
.mobile-menu a{display:block;color:var(--fg-on-navy);padding:13px 0;font-size:16px;border-bottom:1px solid var(--line-navy)}

/* ============ BUTTONS ============ */
.btn{font-family:var(--font-sans);font-weight:500;font-size:14px;letter-spacing:.05em;
  padding:13px 26px;border-radius:var(--r-sm);border:1px solid transparent;
  transition:all .18s cubic-bezier(.2,.6,.2,1);display:inline-flex;align-items:center;gap:9px;white-space:nowrap}
.btn:active{transform:translateY(1px)}
.btn-navy{background:var(--path-navy);color:var(--fg-on-navy)}
.btn-navy:hover{background:var(--path-navy-3)}
.btn-azure{background:var(--path-azure);color:#fff}
.btn-azure:hover{background:var(--path-azure-hover)}
.btn-light{background:#fff;color:var(--path-navy);box-shadow:var(--sh-sm)}
.btn-light:hover{background:var(--n-50)}
.btn-ghost-d{background:transparent;color:var(--fg-on-navy);border-color:rgba(255,255,255,.28)}
.btn-ghost-d:hover{background:rgba(255,255,255,.08)}
.btn-ghost{background:transparent;color:var(--path-navy);border-color:var(--line-strong)}
.btn-ghost:hover{background:var(--bg-sunken)}
.btn-lg{padding:15px 30px;font-size:15px}

/* ============ HERO ============ */
.hero{background:
  radial-gradient(1200px 600px at 78% -8%, rgba(45,108,178,.22), transparent 60%),
  linear-gradient(180deg,#02152e 0%,var(--path-navy) 55%,#031e40 100%);
  color:var(--fg-on-navy);overflow:hidden}
.hero .inner{display:grid;grid-template-columns:1.1fr .9fr;gap:56px;align-items:center;padding:96px 0 104px}
.hero .ghost-mark{position:absolute;right:-90px;top:-40px;width:560px;opacity:.05;pointer-events:none}
.hero h1{font-family:var(--font-display);font-weight:700;font-size:clamp(40px,5.2vw,68px);line-height:1.04;letter-spacing:.005em;color:#fff;margin:22px 0 0}
.hero h1 em{font-style:italic;color:transparent;background:var(--path-metallic);-webkit-background-clip:text;background-clip:text}
.hero .sub{font-weight:300;font-size:19px;line-height:1.62;color:var(--fg-on-navy-2);max-width:520px;margin:24px 0 34px}
.hero .cta-row{display:flex;gap:14px;flex-wrap:wrap}
.hero .trust{margin-top:42px;display:flex;align-items:center;gap:20px;flex-wrap:wrap;color:var(--fg-on-navy-2);font-size:13.5px}
.hero .trust .dot{width:5px;height:5px;border-radius:50%;background:var(--path-silver-lo)}
.hero-visual{position:relative}
.hero-visual image-slot{width:100%;height:440px;box-shadow:var(--sh-navy)}
.hero-visual .badge{position:absolute;left:-22px;bottom:30px;background:#fff;border-radius:var(--r-lg);
  box-shadow:var(--sh-lg);padding:18px 22px;max-width:230px}
.hero-visual .badge .n{font-family:var(--font-display);font-style:italic;font-size:34px;color:var(--path-navy);line-height:1}
.hero-visual .badge .l{font-size:13px;color:var(--fg-2);margin-top:6px;line-height:1.4}

/* ============ MARQUEE / SERVE STRIP ============ */
.serve{background:var(--bg-surface);border-bottom:1px solid var(--line)}
.serve .row{display:flex;align-items:center;justify-content:space-between;gap:30px;padding:30px 0;flex-wrap:wrap}
.serve .lab{font-family:var(--font-sans);font-weight:500;font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--fg-3);white-space:nowrap}
.serve .tags{display:flex;gap:10px;flex-wrap:wrap}
.serve .tag{font-size:14px;color:var(--fg-2);border:1px solid var(--line);border-radius:var(--r-pill);padding:7px 16px;background:var(--n-25)}

/* ============ SECTION HEAD ============ */
.sec{padding:100px 0}
.sec.alt{background:var(--bg-surface);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.sec.sunken{background:var(--bg-sunken)}
.sec-head{max-width:680px;margin-bottom:56px}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head h2{font-family:var(--font-display);font-weight:700;font-size:clamp(30px,3.7vw,48px);line-height:1.08;color:var(--fg-1);margin-top:16px}
.sec-head p{font-weight:300;font-size:18px;line-height:1.6;color:var(--fg-2);margin-top:18px}

/* ============ SOLUTIONS GRID ============ */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.svc{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:32px 30px 34px;
  box-shadow:var(--sh-sm);transition:box-shadow .22s,transform .22s,border-color .22s;position:relative;overflow:hidden}
.svc::before{content:"";position:absolute;left:0;top:0;height:3px;width:100%;background:var(--path-metallic);transform:scaleX(0);transform-origin:left;transition:transform .3s}
.svc:hover{box-shadow:var(--sh-md);transform:translateY(-4px);border-color:var(--line-strong)}
.svc:hover::before{transform:scaleX(1)}
.svc .ic{width:48px;height:48px;border-radius:var(--r-md);background:var(--path-navy);
  display:flex;align-items:center;justify-content:center;color:var(--path-silver-hi);margin-bottom:22px}
.svc h3{font-family:var(--font-serif);font-weight:600;font-size:20px;color:var(--fg-1);margin-bottom:11px;line-height:1.2}
.svc p{font-size:14.5px;line-height:1.58;color:var(--fg-2)}
.svc .more{margin-top:18px;display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:500;letter-spacing:.04em;color:var(--path-azure);opacity:0;transform:translateX(-4px);transition:all .25s}
.svc:hover .more{opacity:1;transform:none}

/* ============ EXPERTISE ============ */
.exp-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px 48px}
.exp{display:grid;grid-template-columns:auto 1fr;gap:20px;align-items:start;padding:6px 0}
.exp .ic{width:50px;height:50px;border-radius:var(--r-md);background:var(--path-azure-soft);
  border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--path-azure);flex-shrink:0}
.exp h3{font-family:var(--font-sans);font-weight:500;font-size:18px;color:var(--fg-1);margin-bottom:8px;line-height:1.25}
.exp p{font-size:14.5px;line-height:1.58;color:var(--fg-2)}

/* ============ APPROACH (editorial split) ============ */
.approach .grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:64px;align-items:center}
.approach image-slot{width:100%;height:auto;aspect-ratio:4/5;max-width:480px;box-shadow:var(--sh-lg)}
.steps{display:flex;flex-direction:column;gap:4px}
.step{display:grid;grid-template-columns:auto 1fr;gap:22px;padding:24px 0;border-top:1px solid var(--line)}
.step:last-child{border-bottom:1px solid var(--line)}
.step .num{font-family:var(--font-display);font-style:italic;font-size:30px;color:var(--path-navy-4);line-height:1;min-width:46px}
.step h3{font-family:var(--font-sans);font-weight:500;font-size:19px;color:var(--fg-1);margin-bottom:7px}
.step p{font-size:15px;line-height:1.55;color:var(--fg-2)}

/* Approach — deep disciplines (accordion) + KAM commitment band */
.approach-deep{margin-top:90px;padding-top:74px;border-top:1px solid var(--line)}
.approach-deep .sec-head{margin-bottom:36px}
.disc-acc{max-width:940px}
.disc{border-top:1px solid var(--line)}
.disc:last-child{border-bottom:1px solid var(--line)}
.disc-h{display:flex;align-items:center;gap:24px;width:100%;text-align:left;background:none;border:0;
  padding:26px 6px;cursor:pointer;color:var(--fg-1);transition:color .18s}
.disc-h:hover{color:var(--path-azure)}
.disc-h .ix{font-family:var(--font-display);font-style:italic;font-size:23px;color:var(--path-navy-4);min-width:38px;line-height:1}
.disc-h h3{flex:1;font-family:var(--font-serif);font-weight:600;font-size:20px;line-height:1.2;color:inherit}
.disc-h .chev{width:20px;height:20px;color:var(--path-navy-4);transition:transform .26s cubic-bezier(.2,.6,.2,1);flex-shrink:0}
.disc.open .disc-h{color:var(--path-navy)}
.disc.open .chev{transform:rotate(180deg)}
.disc-b{display:grid;grid-template-rows:0fr;transition:grid-template-rows .28s cubic-bezier(.2,.6,.2,1)}
.disc.open .disc-b{grid-template-rows:1fr}
.disc-b .inner{overflow:hidden}
.disc-b .pad{padding:0 6px 30px 62px}
.disc-b p{font-size:15.5px;line-height:1.62;color:var(--fg-2);max-width:700px}
.disc-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px}
.disc-tags span{font-size:12.5px;color:var(--path-navy-4);background:var(--path-azure-soft);border:1px solid var(--line);
  border-radius:var(--r-pill);padding:5px 13px}

.kam{margin-top:84px;background:
  radial-gradient(820px 400px at 86% -25%,rgba(45,108,178,.22),transparent 60%),var(--path-navy);
  border:1px solid var(--line-navy);border-radius:var(--r-xl);padding:56px 56px 52px;color:#fff;box-shadow:var(--sh-navy)}
.kam .path-eyebrow{color:var(--path-silver-lo)}
.kam h2{font-family:var(--font-display);font-weight:700;font-size:clamp(26px,3vw,38px);line-height:1.13;color:#fff;margin-top:14px;max-width:780px}
.kam .lead{font-weight:300;font-size:17px;line-height:1.64;color:var(--fg-on-navy-2);margin-top:20px;max-width:700px}
.kam-pts{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:46px}
.kam-pt{border-top:1px solid var(--line-navy);padding-top:22px}
.kam-pt .ic{width:42px;height:42px;border-radius:var(--r-md);background:rgba(255,255,255,.06);border:1px solid var(--line-navy);
  display:flex;align-items:center;justify-content:center;color:var(--path-silver-hi);margin-bottom:16px}
.kam-pt h4{font-family:var(--font-sans);font-weight:500;font-size:17px;color:#fff;margin-bottom:8px}
.kam-pt p{font-size:14px;line-height:1.58;color:var(--fg-on-navy-2)}
.kam .cta{margin-top:42px}

/* ============ STATS ============ */
.stats{background:
  radial-gradient(900px 400px at 15% 120%, rgba(45,108,178,.18), transparent 60%),
  var(--path-navy);color:#fff}
.stats .row{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;padding:72px 0}
.stat{position:relative}
.stat .n{font-family:var(--font-display);font-weight:400;font-style:italic;font-size:clamp(44px,5vw,60px);line-height:1;
  background:var(--path-metallic);-webkit-background-clip:text;background-clip:text;color:transparent}
.stat .l{font-size:14px;color:var(--fg-on-navy-2);margin-top:14px;letter-spacing:.01em;line-height:1.5;max-width:220px}

/* ============ ABOUT / PARTNERS ============ */
.about .lead{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start;margin-bottom:64px}
.about .lead .big{font-family:var(--font-display);font-weight:700;font-size:clamp(26px,2.8vw,34px);line-height:1.22;color:var(--fg-1)}
.about .lead .big em{font-style:italic;color:var(--path-navy-4)}
.about .lead .body p{margin-bottom:18px}
.partners{display:grid;grid-template-columns:repeat(2,1fr);gap:28px;max-width:780px;margin:0 auto}
.partner{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-sm);
  transition:box-shadow .22s,transform .22s}
.partner:hover{box-shadow:var(--sh-md);transform:translateY(-3px)}
.partner image-slot{width:100%;height:340px}
.partner .bd{padding:24px 24px 28px}
.partner .role{font-size:11px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--path-navy-4)}
.partner h3{font-family:var(--font-display);font-weight:700;font-size:23px;margin:9px 0 12px;color:var(--fg-1)}
.partner p{font-size:14px;line-height:1.6;color:var(--fg-2)}

/* ============ ARTICLES ============ */
.art-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.articles .sec-head{flex-wrap:wrap;gap:20px}
.art{display:block;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;
  box-shadow:var(--sh-sm);transition:box-shadow .22s,transform .22s,border-color .22s}
.art:hover{box-shadow:var(--sh-md);transform:translateY(-4px);border-color:var(--line-strong)}
.art image-slot{width:100%;height:190px}
.art-bd{padding:24px 24px 26px}
.art-meta{display:flex;align-items:center;gap:10px;font-size:11px;font-weight:500;letter-spacing:.14em;
  text-transform:uppercase;color:var(--path-navy-4)}
.art-dot{width:3px;height:3px;border-radius:50%;background:var(--line-strong)}
.art h3{font-family:var(--font-display);font-weight:700;font-size:21px;line-height:1.22;margin:13px 0 11px;color:var(--fg-1)}
.art p{font-size:14.5px;line-height:1.55;color:var(--fg-2)}
.art-read{margin-top:18px;display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:500;
  letter-spacing:.04em;color:var(--path-azure)}
.art:hover .art-read{color:var(--path-azure-hover)}

/* ============ EXPO / EVENTS BAND ============ */
.expo{background:linear-gradient(120deg,var(--path-navy) 0%,#0a2747 60%,#0e3158 100%);color:#fff;overflow:hidden;padding:96px 0}
.expo .eyebrow{color:var(--path-silver-lo)}
.expo h2{font-family:var(--font-display);font-weight:700;font-size:clamp(30px,3.6vw,46px);line-height:1.1;color:#fff}
.events-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px}
.event-card{background:rgba(255,255,255,.04);border:1px solid var(--line-navy);border-radius:var(--r-lg);overflow:hidden;
  transition:border-color .22s,transform .22s,box-shadow .22s}
.event-card:hover{border-color:var(--path-silver-lo);transform:translateY(-3px);box-shadow:var(--sh-navy)}
.event-card image-slot{width:100%;height:320px}
.event-bd{padding:28px 30px 32px}
.event-bd h3{font-family:var(--font-display);font-weight:700;font-size:27px;color:#fff;line-height:1.12}
.event-bd p{font-weight:300;font-size:16px;line-height:1.6;color:var(--fg-on-navy-2);margin:14px 0 18px}
.event-bd ul{list-style:none;margin:0 0 24px;display:flex;flex-direction:column;gap:11px}
.event-bd li{display:flex;align-items:center;gap:12px;color:var(--fg-on-navy);font-size:15px}
.event-bd li i{color:var(--path-silver-hi);width:17px;height:17px;flex-shrink:0}

/* ============ QUOTE ============ */
.quote-sec{padding:104px 0}
.quote{max-width:900px;margin:0 auto;text-align:center}
.quote .mk{font-family:var(--font-display);font-size:80px;line-height:0;color:var(--path-silver);opacity:.5;display:block;height:42px}
.quote blockquote{font-family:var(--font-display);font-weight:400;font-style:italic;
  font-size:clamp(25px,3vw,38px);line-height:1.34;color:var(--fg-1)}
.quote .who{margin-top:30px;font-size:15px;color:var(--fg-2)}
.quote .who b{color:var(--fg-1);font-weight:600;font-style:normal}

/* ============ CONTACT ============ */
.contact{background:linear-gradient(180deg,var(--path-navy),#03234a);color:#fff}
.contact .grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;padding:96px 0;align-items:start}
.contact h2{font-family:var(--font-display);font-weight:700;font-size:clamp(30px,3.4vw,44px);color:#fff;line-height:1.1}
.contact .sub{font-weight:300;color:var(--fg-on-navy-2);font-size:18px;line-height:1.6;margin-top:18px;max-width:430px}
.contact .info{margin-top:34px;display:flex;flex-direction:column;gap:18px}
.contact .info .item{display:flex;align-items:flex-start;gap:14px;color:var(--fg-on-navy)}
.contact .info .item i{width:19px;height:19px;color:var(--path-silver-lo);margin-top:2px;flex-shrink:0}
.contact .info .item .k{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--fg-on-navy-2);margin-bottom:3px}
.contact .info .item .v{font-size:15.5px}
.form{background:rgba(255,255,255,.04);border:1px solid var(--line-navy);border-radius:var(--r-lg);padding:32px}
.field{margin-bottom:18px}
.field label{display:block;font-size:12px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--fg-on-navy-2);margin-bottom:8px}
.field input,.field textarea,.field select{width:100%;font-family:var(--font-sans);font-size:15px;color:#fff;
  background:rgba(255,255,255,.06);border:1px solid var(--line-navy);border-radius:var(--r-sm);padding:13px 14px}
.field textarea{resize:vertical}
.field input::placeholder,.field textarea::placeholder{color:rgba(157,176,198,.7)}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--path-azure);background:rgba(255,255,255,.09)}
.field select option{color:#111;background:#fff}
.sent{text-align:center;padding:36px 10px}
.sent .ck{width:56px;height:56px;border-radius:50%;background:var(--ok);color:#fff;display:flex;align-items:center;justify-content:center;margin:0 auto 18px}

/* ============ FOOTER ============ */
.ftr{background:#01122a;color:var(--fg-on-navy-2);border-top:1px solid var(--line-navy);padding:60px 0 40px}
.ftr .top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;margin-bottom:46px}
.ftr img.logo{height:28px;opacity:.95}
.ftr .blurb{font-size:14px;line-height:1.65;margin-top:18px;max-width:300px}
.ftr .socials{display:flex;gap:12px;margin-top:22px}
.ftr .socials a{width:38px;height:38px;border:1px solid var(--line-navy);border-radius:var(--r-sm);
  display:flex;align-items:center;justify-content:center;color:var(--fg-on-navy-2);transition:all .18s}
.ftr .socials a:hover{color:#fff;border-color:var(--path-silver-lo);background:rgba(255,255,255,.05)}
.ftr .col h4{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--path-silver-lo);margin-bottom:16px}
.ftr .col a{display:block;font-size:14px;color:var(--fg-on-navy-2);margin-bottom:10px;transition:color .15s}
.ftr .col a:hover{color:#fff}
.ftr .base{border-top:1px solid var(--line-navy);padding-top:26px;display:flex;justify-content:space-between;
  flex-wrap:wrap;gap:12px;font-size:12.5px;color:var(--path-silver-lo);line-height:1.6}

/* ============ ANIM ============ */
.fade-in{opacity:0;transform:translateY(14px);transition:opacity .6s cubic-bezier(.2,.6,.2,1),transform .6s cubic-bezier(.2,.6,.2,1)}
.fade-in.in{opacity:1;transform:none}
.fade-in.d1{transition-delay:.08s}.fade-in.d2{transition-delay:.16s}.fade-in.d3{transition-delay:.24s}

/* ============ RESPONSIVE ============ */
@media(max-width:980px){
  .hero .inner{grid-template-columns:1fr;gap:44px;padding:72px 0 80px}
  .hero-visual{order:-1;display:none}
  .approach .grid{grid-template-columns:1fr;gap:40px}
  .approach image-slot{height:auto;aspect-ratio:4/5;max-width:380px;margin:0 auto;order:-1}
  .kam-pts{grid-template-columns:1fr;gap:26px}
  .kam{padding:42px 32px 40px}
  .expo .grid,.contact .grid,.about .lead{grid-template-columns:1fr;gap:36px}
  .events-grid{grid-template-columns:1fr;gap:22px}
  .event-card image-slot{height:280px}
  .partners{grid-template-columns:1fr 1fr}
  .art-grid{grid-template-columns:1fr 1fr}
  .stats .row{grid-template-columns:1fr 1fr;gap:40px 24px}
  .ftr .top{grid-template-columns:1fr 1fr}
}
@media(max-width:880px){
  .hdr nav,.hdr .right .btn{display:none}
  .menu-btn{display:flex}
}
@media(max-width:620px){
  .wrap{padding:0 22px}
  .sec{padding:72px 0}
  .svc-grid{grid-template-columns:1fr}
  .art-grid{grid-template-columns:1fr}
  .partners{grid-template-columns:1fr}
  .disc-b .pad{padding-left:46px}
  .approach-deep{margin-top:60px;padding-top:54px}
  .stats .row{grid-template-columns:1fr 1fr;gap:34px 20px}
  .ftr .top{grid-template-columns:1fr}
}

/* Event card images */
.event-img {
  width: 100%;
  height: 220px;
  object-fit: cover;
  border-radius: 12px 12px 0 0;
  display: block;
}
