/* ===================================================================
   APICE — Merged Production Design System
   Base: v2 Industrial/Corporate (Acto-inspired)
   Enhancements: v1.1 nav, hero carousel, mobile bar, logo system
   Fixes: favicon, mobile nav completeness, static topbar, OG image
   =================================================================== */

:root {
  /* Brand */
  --navy:   #0E223D;
  --navy2:  #16325A;
  --navy3:  #081527;
  --gold:   #C9A84C;
  --gold-lt:#E0C068;
  --gold-dk:#A08030;

  /* Neutrals */
  --ink:    #0B1524;
  --slate:  #3A4A63;
  --muted:  #6B7A90;
  --line:   #E6E8EC;
  --bg:     #F6F7F9;
  --bg2:    #EEF1F5;
  --white:  #FFFFFF;

  /* Type */
  --ff-d: "Playfair Display", Georgia, serif;
  --ff-s: "DM Sans", system-ui, -apple-system, Roboto, sans-serif;

  /* UI */
  --r:   4px;
  --r-lg:10px;
  --sh-sm: 0 2px 10px rgba(14,34,61,.07);
  --sh:    0 12px 32px rgba(14,34,61,.13);
  --sh-lg: 0 28px 60px rgba(14,34,61,.20);

  /* Container */
  --maxw: 1240px;
  --pad:  clamp(18px,4vw,48px);

  /* Motion */
  --e: cubic-bezier(.4,0,.2,1);
}

/* ── RESET ── */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;font-family:var(--ff-s);color:var(--ink);background:var(--white);line-height:1.65;font-size:16px;-webkit-font-smoothing:antialiased}
img,svg,video{max-width:100%;display:block}
a{color:inherit;text-decoration:none;transition:color .2s var(--e)}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}
ul,ol{margin:0;padding:0;list-style:none}
h1,h2,h3,h4,h5,h6{margin:0;font-family:var(--ff-d);color:var(--navy);letter-spacing:-.015em;line-height:1.15}
p{margin:0 0 1em}
p:last-child{margin-bottom:0}
::selection{background:var(--gold);color:var(--navy)}

/* ── LAYOUT ── */
.W{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad)}
.W-wide{max-width:1400px;margin:0 auto;padding:0 var(--pad)}

/* ── SECTIONS ── */
.s{padding:clamp(56px,9vw,120px) 0}
.s--tight{padding:clamp(40px,6vw,72px) 0}
.s--white{background:var(--white)}
.s--bg{background:var(--bg)}
.s--bg2{background:var(--bg2)}
.s--navy{background:var(--navy);color:#D7DBE4}
.s--navy h1,.s--navy h2,.s--navy h3,.s--navy h4{color:#fff}
.s--dark{background:var(--navy3);color:#B5BED0}

/* ── SKIP LINK ── */
.skip-link{position:absolute;top:-40px;left:0;background:var(--gold);color:var(--navy);padding:10px 14px;font-size:12px;font-weight:700;z-index:9999;transition:top .2s;border-radius:0 0 4px 0}
.skip-link:focus{top:0}

/* ── EYEBROWS + TYPOGRAPHY ── */
.ey{display:inline-flex;align-items:center;gap:12px;font-size:11px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:18px}
.ey::before{content:"";width:28px;height:2px;background:var(--gold)}
.ey--navy{color:var(--navy)}
.ey--navy::before{background:var(--navy)}
.ey--light{color:var(--gold-lt)}
.ey--light::before{background:var(--gold-lt)}

.h-dp{font-size:clamp(40px,5.4vw,68px);font-weight:800;color:var(--navy);line-height:1.05}
.h-dp em{font-style:italic;color:var(--gold)}
.h-xl{font-size:clamp(32px,4vw,52px);font-weight:800;line-height:1.1}
.h-xl em{font-style:italic;color:var(--gold);font-weight:800}
.h-l{font-size:clamp(24px,2.6vw,34px);font-weight:700;line-height:1.2}
.h-m{font-size:20px;font-weight:700;line-height:1.25}
.lead{font-size:clamp(16px,1.4vw,19px);color:var(--slate);max-width:68ch}

.section-title{max-width:760px;margin:0 auto clamp(36px,5vw,64px);text-align:center}
.section-title p{color:var(--muted);font-size:17px}
.section-title--l{text-align:left;margin-left:0;margin-right:0}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:10px;padding:15px 28px;font-weight:700;font-size:13px;letter-spacing:.06em;text-transform:uppercase;border-radius:var(--r);transition:all .25s var(--e);white-space:nowrap;border:2px solid transparent}
.btn svg{width:14px;height:14px;transition:transform .25s var(--e)}
.btn:hover svg{transform:translateX(4px)}
.btn-gold{background:var(--gold);color:var(--navy);border-color:var(--gold)}
.btn-gold:hover{background:var(--gold-lt);border-color:var(--gold-lt);transform:translateY(-2px);box-shadow:0 10px 26px rgba(201,168,76,.35)}
.btn-navy{background:var(--navy);color:#fff;border-color:var(--navy)}
.btn-navy:hover{background:var(--navy2);transform:translateY(-2px);box-shadow:var(--sh)}
.btn-outline{background:transparent;color:var(--navy);border-color:var(--navy)}
.btn-outline:hover{background:var(--navy);color:#fff}
.btn-outline-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
.btn-outline-light:hover{background:#fff;color:var(--navy);border-color:#fff}
.actions{display:flex;flex-wrap:wrap;gap:14px;align-items:center}

/* ── TOP BAR (static HTML) ── */
.topbar{background:var(--navy3);color:#B5BED0;font-size:12.5px;letter-spacing:.02em}
.topbar__in{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:10px 0;flex-wrap:wrap}
.topbar__l,.topbar__r{display:flex;align-items:center;gap:22px;flex-wrap:wrap}
.topbar__item{display:inline-flex;align-items:center;gap:8px;transition:color .2s}
.topbar__item svg{width:13px;height:13px;color:var(--gold);flex-shrink:0}
.topbar__item a{color:#B5BED0;transition:color .2s}
.topbar__item a:hover,.topbar__item:hover{color:var(--gold)}
.topbar__sep{width:1px;height:14px;background:rgba(255,255,255,.15)}
@media(max-width:720px){.topbar__r{display:none}.topbar__in{justify-content:center}}

/* ── NAVIGATION ── */
.nv{position:sticky;top:0;z-index:100;background:#fff;border-bottom:1px solid var(--line);transition:box-shadow .25s var(--e)}
.nv.sc{box-shadow:var(--sh-sm)}
.nv__in{display:flex;align-items:center;justify-content:space-between;padding:14px 0;gap:24px}
/* ── APICE LOGO — inline SVG via CSS data URI (zero HTTP request, site-wide reuse) ── */
:root{
  --apice-logo:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='210 170 760 900'><polygon points='447,203 639,203 917,1040 722,1040' fill='%231f2b59'/><polygon points='534,203 550,203 270,1045 255,1045' fill='%23b6b6b6'/><polygon points='577,203 593,203 323,1045 307,1045' fill='%23b6b6b6'/><rect x='253' y='594' width='677' height='21' fill='%23c5a157'/><rect x='253' y='630' width='677' height='21' fill='%23c5a157'/></svg>");
  --apice-logo-light:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='210 170 760 900'><polygon points='447,203 639,203 917,1040 722,1040' fill='%23ffffff'/><polygon points='534,203 550,203 270,1045 255,1045' fill='%23b6b6b6'/><polygon points='577,203 593,203 323,1045 307,1045' fill='%23b6b6b6'/><rect x='253' y='594' width='677' height='21' fill='%23c5a157'/><rect x='253' y='630' width='677' height='21' fill='%23c5a157'/></svg>");
}

.nv__logo{display:flex;align-items:center;gap:14px;text-decoration:none}
.nv__logo img{content:var(--apice-logo);height:56px;width:auto;display:block}
.nv__logo-t{display:flex;flex-direction:column;line-height:1;gap:6px}
.nv__logo-name{font-family:var(--ff-d);font-size:30px;font-weight:800;color:var(--navy);text-transform:uppercase;letter-spacing:.04em;line-height:1}
.nv__logo-tag{font-size:10.5px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);line-height:1}
@media(max-width:720px){
  .nv__logo img{height:46px}
  .nv__logo-name{font-size:24px}
  .nv__logo-tag{font-size:9px;letter-spacing:.15em}
}

.nv__menu{display:flex;align-items:center;gap:2px}
.nv__item{position:relative}
.nv__lk{display:inline-flex;align-items:center;gap:6px;padding:10px 14px;font-size:13.5px;font-weight:600;color:var(--navy);border-radius:var(--r);transition:all .2s var(--e)}
.nv__lk:hover,.nv__lk.ac{color:var(--gold)}
.nv__lk svg{width:10px;height:10px;opacity:.6;transition:transform .2s}
.nv__item:hover .nv__lk svg{transform:rotate(180deg)}

.nv__drop{position:absolute;top:calc(100% + 6px);left:0;min-width:260px;background:#fff;border-top:3px solid var(--gold);box-shadow:var(--sh);padding:10px;opacity:0;visibility:hidden;transform:translateY(-6px);transition:all .2s var(--e);z-index:50}
.nv__item:hover .nv__drop,.nv__item:focus-within .nv__drop{opacity:1;visibility:visible;transform:translateY(0)}
.nv__drop-h{display:block;padding:8px 14px 6px;font-size:10.5px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.nv__drop a{display:block;padding:9px 14px;font-size:13.5px;font-weight:500;color:var(--navy);border-radius:3px;border-left:2px solid transparent;transition:all .2s var(--e)}
.nv__drop a:hover{background:rgba(201,168,76,.08);color:var(--gold);border-left-color:var(--gold);padding-left:18px}

.nv__cta{background:var(--gold)!important;color:var(--navy)!important;padding:12px 22px!important;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;border-radius:var(--r);transition:all .25s var(--e)}
.nv__cta:hover{background:var(--gold-lt)!important;transform:translateY(-1px);box-shadow:0 6px 18px rgba(201,168,76,.35)}

/* Burger */
.burger{display:none;width:44px;height:44px;border-radius:var(--r);position:relative;background:var(--navy);flex-shrink:0}
.burger span{position:absolute;left:12px;right:12px;height:2px;background:#fff;transition:all .25s var(--e)}
.burger span:nth-child(1){top:16px}
.burger span:nth-child(2){top:21px}
.burger span:nth-child(3){top:26px}
.burger.on span:nth-child(1){top:21px;transform:rotate(45deg)}
.burger.on span:nth-child(2){opacity:0}
.burger.on span:nth-child(3){top:21px;transform:rotate(-45deg)}
@media(max-width:1080px){.nv__menu,.nv__cta{display:none}.burger{display:flex;align-items:center;justify-content:center}}

/* ── MOBILE MENU (slide-panel, v2 style) ── */
.mn{position:fixed;top:0;right:-100%;width:min(360px,88vw);height:100vh;background:#fff;z-index:200;padding:64px 26px 26px;overflow-y:auto;transition:right .3s var(--e);box-shadow:-20px 0 40px rgba(0,0,0,.15)}
.mn.on{right:0}
.mn__x{position:absolute;top:14px;right:14px;width:44px;height:44px;border-radius:var(--r);background:var(--bg);font-size:22px;color:var(--navy);display:inline-flex;align-items:center;justify-content:center;cursor:pointer}
.mn a{display:block;padding:13px 0;font-size:15px;font-weight:600;color:var(--navy);border-bottom:1px solid var(--line);transition:color .2s}
.mn a:hover{color:var(--gold)}
.mn__sec{font-size:10px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-top:18px;padding:6px 0;border-bottom:0}
.mn__sub{padding-left:12px!important;font-size:14px!important;font-weight:500!important}
.mn__cta{margin-top:18px;display:block;text-align:center;background:var(--gold);color:var(--navy)!important;padding:14px 18px!important;border-radius:var(--r);font-weight:700;border-bottom:0!important}
.mn__overlay{position:fixed;inset:0;background:rgba(8,21,39,.6);z-index:199;opacity:0;visibility:hidden;transition:all .25s var(--e)}
.mn__overlay.on{opacity:1;visibility:visible}

/* ── HERO SLIDER (v2 track-based, full-bleed) ── */
.hero{position:relative;color:#fff;overflow:hidden;background:var(--navy3)}
.hero__pager{position:absolute;top:40px;right:var(--pad);z-index:5;color:rgba(255,255,255,.7);font-size:12px;letter-spacing:.2em;font-weight:700;display:flex;align-items:center;gap:10px}
.hero__pager b{color:var(--gold-lt);font-size:16px}
.hero__pager i{font-style:normal}
.hero__pager::after{content:"";width:60px;height:1px;background:rgba(255,255,255,.25)}
.hero__track{display:flex;transition:transform .7s var(--e);will-change:transform}
.hero__slide{flex:0 0 100%;position:relative;min-height:min(88vh,720px);display:flex;align-items:center;background-size:cover;background-position:center}
.hero__slide::before{content:"";position:absolute;inset:0;background:linear-gradient(115deg,rgba(8,21,39,.92) 0%,rgba(14,34,61,.82) 45%,rgba(14,34,61,.38) 100%)}
.hero__in{position:relative;z-index:2;padding:clamp(80px,10vw,140px) 0;max-width:760px}
.hero__ey{display:inline-flex;align-items:center;gap:12px;font-size:12px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-lt);margin-bottom:20px}
.hero__ey::before{content:"";width:40px;height:2px;background:var(--gold-lt)}
.hero__h{font-size:clamp(40px,5.6vw,74px);font-weight:800;line-height:1.02;color:#fff;margin-bottom:22px;letter-spacing:-.02em}
.hero__h em{font-style:italic;color:var(--gold-lt);font-weight:800}
.hero__p{font-size:clamp(16px,1.5vw,20px);color:rgba(255,255,255,.82);max-width:60ch;margin-bottom:32px}
.hero__dots{position:absolute;bottom:52px;left:var(--pad);z-index:5;display:flex;gap:10px}
.hero__dot{width:32px;height:3px;background:rgba(255,255,255,.3);border:0;transition:all .25s var(--e);cursor:pointer;border-radius:2px}
.hero__dot.on{background:var(--gold);width:52px}
.hero__nav{position:absolute;bottom:40px;right:var(--pad);z-index:5;display:flex;gap:12px}
.hero__btn{width:52px;height:52px;border-radius:50%;background:rgba(255,255,255,.08);border:1.5px solid rgba(255,255,255,.25);color:#fff;display:inline-flex;align-items:center;justify-content:center;backdrop-filter:blur(6px);transition:all .25s var(--e)}
.hero__btn:hover{background:var(--gold);border-color:var(--gold);color:var(--navy)}
.hero__btn svg{width:18px;height:18px}
@media(max-width:600px){.hero__slide{min-height:min(80vh,640px)}}

/* ── PAGE HERO (inner pages) ── */
.page-hero{position:relative;color:#fff;background:var(--navy3);overflow:hidden;padding:clamp(64px,9vw,110px) 0 clamp(56px,7vw,88px);border-bottom:4px solid var(--gold)}
.page-hero::before{content:"";position:absolute;inset:0;background:linear-gradient(120deg,rgba(8,21,39,.92) 0%,rgba(14,34,61,.8) 60%,rgba(22,50,90,.55) 100%)}
.page-hero__bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.35}
.page-hero__in{position:relative;z-index:2;max-width:820px}
.page-hero h1{color:#fff;font-size:clamp(36px,5vw,60px);font-weight:800;line-height:1.05;margin-bottom:18px}
.page-hero h1 em{color:var(--gold-lt);font-style:italic}
.page-hero p{color:rgba(255,255,255,.82);font-size:clamp(15px,1.4vw,19px);max-width:60ch}
.crumb{display:flex;align-items:center;gap:10px;color:rgba(255,255,255,.7);font-size:12.5px;letter-spacing:.06em;margin-bottom:22px}
.crumb a{color:var(--gold-lt);transition:color .2s}
.crumb a:hover{color:#fff}
.crumb span{opacity:.5}

/* ── STATS RIBBON ── */
.stats{background:var(--navy);color:#fff;position:relative;margin-top:-60px;z-index:5;border-radius:6px;box-shadow:var(--sh-lg)}
.stats__g{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.stat{padding:38px 30px;text-align:center;border-right:1px solid rgba(255,255,255,.08)}
.stat:last-child{border-right:0}
.stat__n{font-family:var(--ff-d);font-size:clamp(36px,4vw,54px);font-weight:800;color:var(--gold-lt);line-height:1;margin-bottom:10px;display:block}
.stat__l{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.72);font-weight:600;display:block}
@media(max-width:780px){.stats__g{grid-template-columns:repeat(2,1fr)}.stat{border-right:0;border-bottom:1px solid rgba(255,255,255,.08)}.stat:nth-child(odd){border-right:1px solid rgba(255,255,255,.08)}}
@media(max-width:600px){.stats{margin-top:-40px}.stat{padding:26px 16px}}

/* ── GRID UTILS ── */
.g{display:grid;gap:28px}
.g-2{grid-template-columns:repeat(2,1fr)}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:960px){.g-3,.g-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.g-2,.g-3,.g-4{grid-template-columns:1fr}}

/* ── CARDS ── */
.card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:32px 28px;transition:all .3s var(--e);position:relative;overflow:hidden;height:100%;display:flex;flex-direction:column}
.card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--gold);transform:scaleY(0);transform-origin:top;transition:transform .35s var(--e)}
.card:hover{transform:translateY(-6px);box-shadow:var(--sh);border-color:transparent}
.card:hover::before{transform:scaleY(1)}
.card__ic{width:58px;height:58px;border-radius:8px;background:linear-gradient(135deg,var(--navy),var(--navy2));color:var(--gold-lt);display:inline-flex;align-items:center;justify-content:center;margin-bottom:20px;transition:all .3s var(--e)}
.card:hover .card__ic{background:linear-gradient(135deg,var(--gold),var(--gold-lt));color:var(--navy)}
.card__ic svg{width:28px;height:28px}
.card h3{font-size:20px;margin-bottom:10px;color:var(--navy)}
.card p{color:var(--slate);font-size:14.5px;margin-bottom:14px;flex:1}
.card__ul li{padding:5px 0 5px 18px;position:relative;font-size:13.5px;color:var(--slate)}
.card__ul li::before{content:"";position:absolute;left:0;top:12px;width:8px;height:2px;background:var(--gold)}
.card__lk{display:inline-flex;align-items:center;gap:8px;font-weight:700;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--navy);margin-top:auto;align-self:flex-start}
.card__lk::after{content:"→";transition:transform .25s var(--e);color:var(--gold);font-weight:900}
.card__lk:hover{color:var(--gold)}
.card__lk:hover::after{transform:translateX(4px)}

/* Numbered card (Acto NB) */
.nb{position:relative;border-radius:var(--r-lg);overflow:hidden;min-height:260px;background:linear-gradient(135deg,var(--navy),var(--navy3));color:#fff;padding:30px 28px;display:flex;flex-direction:column;justify-content:space-between;transition:all .35s var(--e)}
.nb::before{content:attr(data-n);position:absolute;top:18px;right:22px;font-family:var(--ff-d);font-size:96px;font-weight:800;color:rgba(201,168,76,.18);line-height:1}
.nb:hover{transform:translateY(-6px);box-shadow:var(--sh-lg)}
.nb__cat{font-size:10.5px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-lt)}
.nb h3{color:#fff;font-size:22px;margin:10px 0 14px;max-width:18ch}
.nb p{color:rgba(255,255,255,.75);font-size:14px;margin-bottom:18px;max-width:30ch}
.nb__lk{display:inline-flex;align-items:center;gap:8px;font-weight:700;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-lt)}
.nb__lk::after{content:"→";transition:transform .25s var(--e)}
.nb:hover .nb__lk::after{transform:translateX(4px)}

/* Stage block */
.stage{background:#fff;border:1px solid var(--line);border-top:4px solid var(--gold);border-radius:6px;padding:32px 28px;transition:all .3s var(--e);height:100%}
.stage:hover{transform:translateY(-4px);box-shadow:var(--sh);border-top-color:var(--navy)}
.stage__ey{font-size:11px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:10px}
.stage h3{font-size:22px;color:var(--navy);margin-bottom:10px}
.stage p{color:var(--slate);font-size:15px;margin-bottom:18px}
.stage__div{height:1px;background:var(--line);margin:18px 0}

/* ── SPLIT / ABOUT SECTION ── */
.split{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(32px,5vw,72px);align-items:center}
@media(max-width:900px){.split{grid-template-columns:1fr}}
.split__img-wrap{position:relative}
.split__img{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh);aspect-ratio:4/5;background:#ccc center/cover no-repeat;width:100%}
.split__img::after{content:"";position:absolute;left:-18px;bottom:-18px;width:58%;aspect-ratio:1;background:var(--gold);z-index:-1;border-radius:var(--r-lg);opacity:.9}
.split__badge{position:absolute;right:-18px;top:20%;background:var(--navy);color:#fff;padding:22px 26px;border-radius:6px;box-shadow:var(--sh);min-width:170px;z-index:3}
.split__badge b{display:block;font-family:var(--ff-d);font-size:44px;color:var(--gold-lt);line-height:1}
.split__badge span{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.72);font-weight:600}
.split ul.feat-list{margin-top:22px;display:grid;gap:12px}
.split ul.feat-list li{display:flex;gap:14px;font-size:15px;color:var(--slate);align-items:flex-start}
.split ul.feat-list li::before{content:"✓";flex:0 0 28px;height:28px;border-radius:50%;background:rgba(201,168,76,.14);color:var(--gold-dk);font-weight:900;font-size:13px;display:inline-flex;align-items:center;justify-content:center;margin-top:2px}

/* ── COUNTER SECTION ── */
.ctr{background:var(--navy3);color:#fff}
.ctr__g{display:grid;grid-template-columns:repeat(3,1fr);gap:44px}
@media(max-width:780px){.ctr__g{grid-template-columns:1fr}}
.ctr__it b{display:block;font-family:var(--ff-d);font-size:58px;font-weight:800;color:var(--gold-lt);line-height:1;margin-bottom:8px}
.ctr__it h4{color:#fff;font-size:18px;margin:0 0 10px}
.ctr__it p{color:rgba(255,255,255,.7);font-size:14px;margin-bottom:14px}
.ctr__bar{height:5px;background:rgba(255,255,255,.1);border-radius:99px;overflow:hidden}
.ctr__bar i{display:block;height:100%;background:linear-gradient(90deg,var(--gold),var(--gold-lt));border-radius:99px;width:0;transition:width 1.6s var(--e)}

/* ── PROCESS STEPS ── */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
@media(max-width:960px){.steps{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.steps{grid-template-columns:1fr}}
.step{background:#fff;border:1px solid var(--line);padding:32px 26px 28px;border-radius:var(--r-lg);position:relative;transition:all .3s var(--e)}
.step:hover{transform:translateY(-6px);box-shadow:var(--sh);border-color:transparent}
.step__n{font-family:var(--ff-d);font-size:72px;font-weight:800;color:var(--gold);line-height:.9;opacity:.22;position:absolute;top:8px;right:18px}
.step h3{font-size:19px;margin-bottom:8px;position:relative;color:var(--navy)}
.step h3::before{content:"";display:block;width:36px;height:3px;background:var(--gold);margin-bottom:14px}
.step p{color:var(--slate);font-size:14.5px}

/* ── CTA BAND ── */
.cta{background:var(--navy);color:#fff;position:relative;overflow:hidden}
.cta::before{content:"";position:absolute;right:-80px;top:-60px;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle,rgba(201,168,76,.22),transparent 60%)}
.cta__in{display:grid;grid-template-columns:1.2fr auto;gap:36px;align-items:center;padding:56px 0;position:relative;z-index:2}
@media(max-width:780px){.cta__in{grid-template-columns:1fr;text-align:center}}
.cta h2{color:#fff;font-size:clamp(26px,3vw,36px);font-weight:700;max-width:24ch}
.cta__r{display:flex;flex-direction:column;align-items:flex-end;gap:10px}
@media(max-width:780px){.cta__r{align-items:center}}
.cta__sub{font-size:12.5px;color:rgba(255,255,255,.65);letter-spacing:.1em}
@media(max-width:600px){.cta__in{padding:44px 0}}

/* ── TESTIMONIALS ── */
.quote{background:#fff;border-left:4px solid var(--gold);padding:30px 30px 26px;border-radius:6px;box-shadow:var(--sh-sm);position:relative;height:100%;display:flex;flex-direction:column}
.quote::before{content:"\201C";position:absolute;top:10px;right:22px;font-family:var(--ff-d);font-size:80px;line-height:1;color:var(--gold);opacity:.25}
.quote p{font-size:15.5px;color:var(--slate);font-style:italic;margin-bottom:20px;flex:1}
.quote__au{display:flex;align-items:center;gap:12px;border-top:1px solid var(--line);padding-top:16px}
.quote__av{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--navy),var(--gold));color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;flex-shrink:0}
.quote__n{font-weight:700;font-size:14.5px;color:var(--navy);line-height:1.2}
.quote__r{font-size:12px;color:var(--muted);letter-spacing:.02em}

/* ── FEATURE TILES ── */
.feat{display:flex;gap:16px;padding:22px;background:#fff;border:1px solid var(--line);border-radius:6px;transition:all .25s var(--e);text-decoration:none;color:inherit}
.feat:hover{border-color:var(--gold);transform:translateY(-2px);box-shadow:var(--sh-sm)}
.feat__ic{flex:0 0 44px;height:44px;border-radius:8px;background:rgba(201,168,76,.12);color:var(--gold-dk);display:inline-flex;align-items:center;justify-content:center}
.feat__ic svg{width:22px;height:22px}
.feat h4{font-size:16px;margin:0 0 6px;color:var(--navy)}
.feat p{font-size:14px;color:var(--slate);margin:0}

/* ── CONTACT INFO BLOCKS ── */
.ci{background:#fff;border:1px solid var(--line);border-radius:8px;padding:24px;display:flex;gap:16px;align-items:flex-start;transition:all .25s var(--e)}
.ci:hover{border-color:var(--gold);transform:translateY(-2px);box-shadow:var(--sh-sm)}
.ci__ic{flex:0 0 48px;height:48px;border-radius:8px;background:linear-gradient(135deg,var(--navy),var(--navy2));color:var(--gold-lt);display:inline-flex;align-items:center;justify-content:center}
.ci__ic svg{width:22px;height:22px}
.ci h4{font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--navy);margin:0 0 4px}
.ci__v{font-size:15px;color:var(--slate);font-weight:600}
.ci a{color:var(--navy)}
.ci a:hover{color:var(--gold)}

/* ── ECOSYSTEM STRIP ── */
.clients{display:grid;grid-template-columns:repeat(6,1fr);gap:14px;padding:28px 0;border-top:1px solid rgba(255,255,255,.1);border-bottom:1px solid rgba(255,255,255,.1)}
@media(max-width:900px){.clients{grid-template-columns:repeat(3,1fr)}}
.client{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:14px;opacity:.72;transition:opacity .2s;color:#fff;font-family:var(--ff-d);font-weight:700;font-size:18px;text-align:center;line-height:1.1;min-height:60px;text-decoration:none}
.client:hover{opacity:1;color:var(--gold-lt)}
.client small{display:block;font-family:var(--ff-s);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-dk);font-weight:600;margin-top:4px}

/* ── FAQ ACCORDION ── */
.acc__i{border-bottom:1px solid var(--line)}
.acc__q{width:100%;text-align:left;padding:20px 0;font-size:16px;font-weight:700;color:var(--navy);display:flex;justify-content:space-between;gap:20px;align-items:center;transition:color .2s var(--e)}
.acc__q:hover{color:var(--gold)}
.acc__q::after{content:"+";font-size:22px;color:var(--gold);transition:transform .25s var(--e);font-weight:400;flex-shrink:0}
.acc__i.on .acc__q::after{transform:rotate(45deg)}
.acc__a{max-height:0;overflow:hidden;transition:max-height .3s var(--e);color:var(--slate);font-size:15px}
.acc__a-in{padding:0 0 22px}
.acc__i.on .acc__a{max-height:500px}

/* ── FORM ── */
.form{background:#fff;border-radius:var(--r-lg);padding:clamp(26px,3vw,40px);box-shadow:var(--sh-sm);border:1px solid var(--line)}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
@media(max-width:680px){.form__row{grid-template-columns:1fr}}
.form label{display:block;font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--navy);margin-bottom:8px}
.form input,.form select,.form textarea{width:100%;padding:13px 14px;border:1.5px solid var(--line);border-radius:var(--r);font:inherit;font-size:14.5px;color:var(--ink);background:#fff;transition:all .2s var(--e)}
.form input:focus,.form select:focus,.form textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 4px rgba(201,168,76,.14)}
.form textarea{min-height:140px;resize:vertical}
.form__f{margin-bottom:16px}

/* ── PROSE ── */
.prose{max-width:780px}
.prose h2{font-size:clamp(24px,2.4vw,32px);margin:36px 0 14px}
.prose h3{font-size:20px;margin:26px 0 10px}
.prose p,.prose li{color:var(--slate);font-size:16px;line-height:1.75}
.prose ul{margin:14px 0;padding-left:0}
.prose ul li{padding:6px 0 6px 26px;position:relative;list-style:none}
.prose ul li::before{content:"";position:absolute;left:0;top:14px;width:14px;height:2px;background:var(--gold)}
.prose a{color:var(--navy);font-weight:600;border-bottom:1px solid var(--gold)}
.prose a:hover{color:var(--gold)}

/* ── TWO-COL LAYOUT ── */
.tc{display:grid;grid-template-columns:1fr 340px;gap:48px;align-items:flex-start}
@media(max-width:900px){.tc{grid-template-columns:1fr}}
.tc__aside{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:26px;box-shadow:var(--sh-sm);position:sticky;top:100px}
.tc__aside h4{font-size:14px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-bottom:12px;font-family:var(--ff-s);font-weight:700}

/* ── PILL ── */
.pill{display:inline-flex;align-items:center;padding:5px 12px;background:rgba(201,168,76,.12);color:var(--gold-dk);font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;border-radius:99px}

/* ── MOBILE ACTION BAR ── */
.mob-bar{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--navy);border-top:1px solid rgba(255,255,255,.08);padding:8px 0 calc(8px + env(safe-area-inset-bottom));z-index:90}
.mob-bar__g{display:grid;grid-template-columns:repeat(4,1fr);gap:4px;max-width:560px;margin:0 auto;padding:0 10px}
.mob-bar a{display:flex;flex-direction:column;align-items:center;gap:3px;padding:6px 2px;color:rgba(255,255,255,.85);font-size:10px;font-weight:600;letter-spacing:.04em;border-radius:6px;text-decoration:none;min-height:44px;justify-content:center}
.mob-bar a svg{width:18px;height:18px;color:var(--gold-lt);fill:none;stroke:currentColor;stroke-width:2}
.mob-bar a.ac{background:var(--gold);color:var(--navy)}
.mob-bar a.ac svg{color:var(--navy)}
@media(max-width:720px){.mob-bar{display:block}main{padding-bottom:72px}}

/* ── FOOTER ── */
.ft{background:var(--navy3);color:#B5BED0;padding:64px 0 0;margin-top:0}
.ft__t{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:38px}
@media(max-width:960px){.ft__t{grid-template-columns:1fr 1fr}}
@media(max-width:580px){.ft__t{grid-template-columns:1fr}}
.ft__lg{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.ft__lg img{content:var(--apice-logo-light);height:52px;width:auto;display:block}
.ft__lg-n{font-family:var(--ff-d);font-size:26px;font-weight:800;color:#fff;text-transform:uppercase;letter-spacing:.04em}
.ft__desc{font-size:14px;color:rgba(255,255,255,.6);margin-bottom:18px;max-width:42ch}
.ft__ci{font-size:13.5px;margin-bottom:6px;display:flex;gap:8px;align-items:center}
.ft__ci svg{width:14px;height:14px;color:var(--gold);flex-shrink:0}
.ft__ci--muted{font-size:11.5px;color:rgba(255,255,255,.4)}
.ft__h{font-size:11px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:#fff;margin-bottom:18px;padding-bottom:10px;border-bottom:1px solid rgba(255,255,255,.1);position:relative}
.ft__h::after{content:"";position:absolute;bottom:-1px;left:0;width:36px;height:1px;background:var(--gold)}
.ft__col ul{display:grid;gap:10px}
.ft__col a{font-size:13.5px;color:rgba(255,255,255,.65);transition:all .2s var(--e)}
.ft__col a:hover{color:var(--gold-lt);padding-left:6px}
.ft__eco{margin-top:24px;padding:16px;background:rgba(255,255,255,.03);border-radius:6px;border-left:3px solid var(--gold)}
.ft__eco-h{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);font-weight:700;margin-bottom:8px}
.ft__eco a{display:block;font-size:12px;color:rgba(255,255,255,.6);padding:2px 0;transition:color .2s}
.ft__eco a:hover{color:var(--gold-lt)}
.ft__b{border-top:1px solid rgba(255,255,255,.08);margin-top:48px;padding:20px 0;display:flex;flex-wrap:wrap;gap:14px;justify-content:space-between;align-items:center}
.ft__cp{font-size:12.5px;color:rgba(255,255,255,.5)}
.ft__lgs{display:flex;flex-wrap:wrap;gap:16px}
.ft__lgs a{font-size:12px;color:rgba(255,255,255,.55);transition:color .2s}
.ft__lgs a:hover{color:var(--gold-lt)}

/* ── FLOATING CONTACT BUBBLE (FAB) ── */
.fab{position:fixed;bottom:28px;right:28px;z-index:110;display:flex;flex-direction:column;align-items:flex-end;gap:12px;font-family:var(--ff-s)}
@media(max-width:720px){.fab{bottom:84px;right:16px}} /* clear mobile action bar */
.fab__btn{width:58px;height:58px;border-radius:50%;background:var(--gold);color:var(--navy);display:inline-flex;align-items:center;justify-content:center;box-shadow:0 10px 28px rgba(14,34,61,.28),0 2px 8px rgba(201,168,76,.35);border:0;cursor:pointer;transition:all .25s var(--e);position:relative}
.fab__btn:hover{background:var(--gold-lt);transform:translateY(-3px) scale(1.04);box-shadow:0 16px 34px rgba(14,34,61,.35),0 4px 12px rgba(201,168,76,.45)}
.fab__btn svg{width:26px;height:26px;fill:none;stroke:currentColor;stroke-width:2}
.fab__btn::after{content:"";position:absolute;inset:-6px;border-radius:50%;border:2px solid var(--gold);opacity:.5;animation:fabPulse 2s infinite}
@keyframes fabPulse{0%{transform:scale(1);opacity:.5}70%{transform:scale(1.4);opacity:0}100%{transform:scale(1.4);opacity:0}}
.fab.on .fab__btn::after{display:none}
.fab__menu{display:flex;flex-direction:column;gap:10px;opacity:0;visibility:hidden;transform:translateY(12px) scale(.92);transform-origin:bottom right;transition:all .25s var(--e);pointer-events:none}
.fab.on .fab__menu{opacity:1;visibility:visible;transform:translateY(0) scale(1);pointer-events:auto}
.fab__item{display:inline-flex;align-items:center;gap:10px;padding:10px 16px 10px 12px;background:#fff;color:var(--navy);border-radius:30px;font-size:13px;font-weight:700;letter-spacing:.04em;box-shadow:var(--sh);border:1px solid var(--line);transition:all .2s var(--e);white-space:nowrap;text-decoration:none}
.fab__item:hover{background:var(--navy);color:#fff;transform:translateX(-4px)}
.fab__item svg{width:18px;height:18px;flex-shrink:0;fill:none;stroke:currentColor;stroke-width:2}
.fab__item--wa{background:#25D366;color:#fff;border-color:#25D366}
.fab__item--wa:hover{background:#128C7E;color:#fff}
.fab__item--sms{background:#3B82F6;color:#fff;border-color:#3B82F6}
.fab__item--sms:hover{background:#2563EB;color:#fff}
.fab__item--call{background:var(--navy);color:#fff;border-color:var(--navy)}
.fab__item--call:hover{background:var(--navy2);color:#fff}
.fab__item--form{background:var(--gold);color:var(--navy);border-color:var(--gold)}
.fab__item--form:hover{background:var(--gold-lt);color:var(--navy)}
.fab__lbl{font-family:var(--ff-s);font-size:12.5px;font-weight:700;letter-spacing:.04em}
.fab__x{position:absolute;top:-10px;right:-10px;width:24px;height:24px;border-radius:50%;background:var(--navy);color:#fff;font-size:12px;font-weight:700;display:none;align-items:center;justify-content:center;border:0;cursor:pointer}
.fab.on .fab__x{display:inline-flex}

/* ── SCROLL REVEAL ── */
.rv{opacity:0;transform:translateY(20px);transition:opacity .7s var(--e),transform .7s var(--e)}
.rv.on{opacity:1;transform:none}

/* ── TABLES ── */
.tb{width:100%;border-collapse:collapse;background:#fff;border-radius:8px;overflow:hidden;box-shadow:var(--sh-sm);font-size:14.5px}
.tb th,.tb td{padding:14px 18px;text-align:left;border-bottom:1px solid var(--line)}
.tb th{background:var(--navy);color:#fff;font-size:12px;letter-spacing:.14em;text-transform:uppercase}
.tb tr:last-child td{border-bottom:0}
.tb tr:hover{background:var(--bg)}

/* ── MOTION REDUCED ── */
@media(prefers-reduced-motion:reduce){*,*::before,*::after{transition:none!important;animation:none!important}.hero__track{transition:none!important}}


/* merged enhancements */
.hp{position:absolute !important;left:-9999px !important;opacity:0 !important;pointer-events:none !important}
.mbar{display:none}
@media (max-width: 860px){.mbar{position:fixed;left:0;right:0;bottom:0;z-index:120;display:grid;grid-template-columns:1fr 1fr;background:#0e223f;border-top:1px solid rgba(255,255,255,.15);box-shadow:0 -8px 24px rgba(0,0,0,.12)}.mbar a{display:flex;align-items:center;justify-content:center;min-height:56px;padding:12px 14px;color:#fff;text-decoration:none;font-weight:700}.mbar a+a{border-left:1px solid rgba(255,255,255,.12)}body{padding-bottom:64px}}

/* ── PRE-FOOTER CTA ── */
.preft{position:relative;overflow:hidden;background:linear-gradient(120deg,var(--navy3),var(--navy),var(--navy2));color:#fff;padding:58px 0;border-top:4px solid var(--gold)}
.preft::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 85% 20%,rgba(201,168,76,.16),transparent 28%),radial-gradient(circle at 15% 80%,rgba(255,255,255,.06),transparent 24%)}
.preft .W{position:relative;z-index:1}
.preft__in{display:grid;grid-template-columns:1.4fr .9fr;gap:28px;align-items:center}
@media(max-width:780px){.preft__in{grid-template-columns:1fr}}
.preft__ey{display:inline-flex;align-items:center;gap:10px;font-size:11px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-lt);margin-bottom:12px}
.preft__ey::before{content:"";width:32px;height:2px;background:var(--gold-lt)}
.preft h2{color:#fff;font-size:clamp(28px,4vw,46px);margin-bottom:12px;font-family:var(--ff-d)}
.preft p{color:rgba(255,255,255,.78);max-width:62ch}
.preft__pts{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}
.preft__pts span{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border:1px solid rgba(255,255,255,.16);border-radius:999px;font-size:12px;color:#E8ECF4;background:rgba(255,255,255,.04)}
.preft__pts span::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--gold)}
.preft__cta{display:flex;flex-direction:column;gap:14px;align-items:flex-start;justify-self:end}
@media(max-width:780px){.preft__cta{justify-self:start}}
.preft__note{font-size:13px;color:rgba(255,255,255,.68);max-width:32ch}

/* ── AUDIENCE CARDS ── */
.aud-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:32px 28px;transition:all .3s var(--e);height:100%;display:flex;flex-direction:column}
.aud-card:hover{transform:translateY(-6px);box-shadow:var(--sh);border-color:transparent}
.aud-card:hover .card__ic{background:linear-gradient(135deg,var(--gold),var(--gold-lt));color:var(--navy)}
.aud-card h3{font-size:20px;margin:16px 0 10px;color:var(--navy)}
.aud-card p{color:var(--slate);font-size:14.5px;margin-bottom:16px;flex:1}
.aud-card ul{margin-bottom:18px}
.aud-card ul li{padding:5px 0 5px 18px;position:relative;font-size:13.5px;color:var(--slate)}
.aud-card ul li::before{content:"";position:absolute;left:0;top:12px;width:8px;height:2px;background:var(--gold)}

/* ── 4-column counter grid responsive ── */
@media(max-width:960px){.ctr__g[style*="repeat(4"]{grid-template-columns:repeat(2,1fr)!important}}
@media(max-width:560px){.ctr__g[style*="repeat(4"]{grid-template-columns:1fr!important}}

/* ==========================================================================
   APICE — SUPPLEMENTARY DESIGN SYSTEM
   Fixes broken layout on all inner pages (.ih hero, .v4-* grids, .cta-b, .pc*,
   .faq__*, .sh, .insight*, .s sections). Uses existing design tokens.
   ========================================================================== */

/* ── Generic section wrapper (.s) ─────────────────────────────────────────── */
.s{padding:clamp(56px,7vw,100px) 0;position:relative}
.s--white{background:#fff}
.s--off{background:var(--bg2,#F6F3EC)}
.s--navy{background:var(--navy);color:#fff}
.Wm{max-width:980px;margin:0 auto;padding:0 var(--pad)}

/* ── Inner-page Hero (.ih) — polished, on-brand, works on every page ──── */
.ih{position:relative;background:linear-gradient(135deg,var(--navy) 0%,var(--navy2) 55%,var(--navy3) 100%);color:#fff;padding:clamp(90px,11vw,150px) 0 clamp(60px,7vw,100px);overflow:hidden;border-bottom:4px solid var(--gold)}
.ih::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 80% 10%,rgba(197,161,87,.18),transparent 55%),radial-gradient(circle at 10% 90%,rgba(182,182,182,.08),transparent 50%);pointer-events:none}
.ih::after{content:"";position:absolute;right:-120px;top:50%;transform:translateY(-50%);width:520px;height:520px;background:var(--apice-logo-light);background-size:contain;background-repeat:no-repeat;background-position:center;opacity:.05;pointer-events:none}
.ih > .W{position:relative;z-index:2}
.ih__c{max-width:820px}
.ih .bc{margin-bottom:22px;font-size:13px;color:rgba(255,255,255,.6);display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.ih .bc a{color:rgba(255,255,255,.8);text-decoration:none;transition:color .2s}
.ih .bc a:hover{color:var(--gold-lt)}
.ih .bc .current{color:var(--gold-lt);font-weight:600}
.ih .ey{display:inline-block;color:var(--gold-lt);font-size:12px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;margin-bottom:18px;padding:6px 14px;border:1px solid rgba(197,161,87,.4);border-radius:999px}
.ih h1{color:#fff;font-family:var(--ff-d);font-size:clamp(34px,5vw,60px);font-weight:800;line-height:1.08;letter-spacing:-.01em;margin-bottom:22px}
.ih h1 em{color:var(--gold-lt);font-style:italic;font-weight:700}
.ih p{color:rgba(255,255,255,.82);font-size:clamp(16px,1.35vw,19px);line-height:1.65;max-width:62ch;margin-bottom:28px}
.ih .btn{margin-top:8px}
.ih .btn+.btn{margin-left:10px}
@media(max-width:720px){.ih::after{width:340px;height:340px;opacity:.04}}

/* Breadcrumb standalone */
.bc{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:13px}
.bc a{color:var(--slate);text-decoration:none}
.bc .current{color:var(--ink);font-weight:600}

/* ── Display type helper ─────────────────────────────────────────────────── */
.dp{font-family:var(--ff-d);font-weight:800;line-height:1.05;letter-spacing:-.01em;color:var(--navy)}

/* ── Section header (.sh) ────────────────────────────────────────────────── */
.sh{display:flex;justify-content:space-between;align-items:flex-end;gap:32px;margin-bottom:48px;flex-wrap:wrap}
.sh__left{max-width:720px}
.sh__left .ey{display:block;margin-bottom:12px}
.sh h2{font-family:var(--ff-d);font-size:clamp(28px,3.4vw,44px);font-weight:800;color:var(--navy);line-height:1.1}
.sh p{margin-top:14px;color:var(--slate);font-size:16.5px;line-height:1.6;max-width:60ch}

/* ── v4 grids ───────────────────────────────────────────────────────────── */
.v4-grid{display:grid;gap:28px}
.v4-grid--2{grid-template-columns:repeat(2,1fr)}
.v4-grid--3{grid-template-columns:repeat(3,1fr)}
.v4-grid--4{grid-template-columns:repeat(4,1fr)}
@media(max-width:960px){.v4-grid--3,.v4-grid--4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.v4-grid--2,.v4-grid--3,.v4-grid--4{grid-template-columns:1fr}}

/* ── v4 card ─────────────────────────────────────────────────────────────── */
.v4-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:32px 30px;transition:all .3s var(--e);position:relative}
.v4-card:hover{box-shadow:var(--sh);border-color:rgba(197,161,87,.35);transform:translateY(-2px)}
.v4-card h3{font-family:var(--ff-d);font-size:22px;font-weight:700;color:var(--navy);margin-bottom:14px;line-height:1.25}
.v4-card p{color:var(--slate);font-size:15.5px;line-height:1.65;margin-bottom:14px}
.v4-card ul{list-style:none;padding:0;margin:14px 0 0}
.v4-card ul li{position:relative;padding:6px 0 6px 22px;font-size:14.5px;color:var(--ink);line-height:1.55}
.v4-card ul li::before{content:"";position:absolute;left:0;top:14px;width:10px;height:2px;background:var(--gold)}

/* ── v4 steps ───────────────────────────────────────────────────────────── */
.v4-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
@media(max-width:960px){.v4-steps{grid-template-columns:repeat(2,1fr)}}
@media(max-width:540px){.v4-steps{grid-template-columns:1fr}}
.v4-step{background:#fff;border:1px solid var(--line);border-left:3px solid var(--gold);border-radius:var(--r);padding:26px 22px;position:relative}
.v4-step__n{font-family:var(--ff-d);font-size:38px;font-weight:800;color:var(--gold);line-height:1;margin-bottom:14px;opacity:.85}
.v4-step h3{font-family:var(--ff-d);font-size:18px;font-weight:700;color:var(--navy);margin-bottom:10px;line-height:1.3}
.v4-step p{font-size:14px;color:var(--slate);line-height:1.6}

/* ── v4 misc ─────────────────────────────────────────────────────────────── */
.v4-section-title{max-width:760px;margin:0 auto 56px;text-align:center}
.v4-section-title h2{font-family:var(--ff-d);font-size:clamp(28px,3.4vw,44px);font-weight:800;color:var(--navy);margin-bottom:14px;line-height:1.1}
.v4-section-title p{color:var(--slate);font-size:16.5px;line-height:1.6}
.v4-band{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:42px 38px;text-align:center;max-width:920px;margin:0 auto}
.v4-band h3{font-family:var(--ff-d);font-size:24px;font-weight:700;color:var(--navy);margin:10px 0 14px;line-height:1.3}
.v4-band p{color:var(--slate);font-size:15.5px;line-height:1.65;max-width:60ch;margin:0 auto}
.v4-mini{display:inline-block;color:var(--gold);font-size:11px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;margin-bottom:6px}
.v4-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:22px;align-items:center}
.v4-links{display:flex;gap:22px;flex-wrap:wrap;margin-top:14px}
.v4-links a{color:var(--navy);font-weight:600;text-decoration:underline;text-decoration-color:var(--gold);text-underline-offset:4px;font-size:14.5px}
.v4-row{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
@media(max-width:860px){.v4-row{grid-template-columns:1fr;gap:28px}}
.v4-note{padding:14px 18px;background:rgba(197,161,87,.08);border-left:3px solid var(--gold);border-radius:4px;font-size:14px;color:var(--ink);margin-top:18px}
.v4-help{color:var(--slate);font-size:14px;margin-top:12px}
.v4-contact{display:grid;gap:10px;margin-top:18px}
.v4-contact a{color:var(--navy);font-weight:600;font-size:15px}

/* ── v4 form ─────────────────────────────────────────────────────────────── */
.v4-form{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:32px 30px;display:grid;gap:18px}
.v4-form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
@media(max-width:640px){.v4-form-grid{grid-template-columns:1fr}}
.fg{display:flex;flex-direction:column;gap:6px}
.fg--full{grid-column:1/-1}
.fg label{font-size:13px;font-weight:600;color:var(--ink);letter-spacing:.02em}
.fg input,.fg select,.fg textarea{padding:12px 14px;font-family:inherit;font-size:15px;border:1px solid var(--line);border-radius:6px;background:#fff;color:var(--ink);transition:border-color .2s}
.fg input:focus,.fg select:focus,.fg textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(197,161,87,.15)}
.fg textarea{min-height:120px;resize:vertical}
.form-note{font-size:13px;color:var(--slate);margin-top:8px}
.form-ok{background:rgba(34,139,87,.08);color:#1E7A4D;padding:14px 16px;border-radius:6px;font-size:14px;display:none}

/* ── CTA Banner (.cta-b) ─────────────────────────────────────────────────── */
.cta-b{background:linear-gradient(135deg,var(--navy) 0%,var(--navy2) 100%);color:#fff;padding:clamp(50px,6vw,80px) 0;position:relative;overflow:hidden}
.cta-b::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 90% 50%,rgba(197,161,87,.15),transparent 50%)}
.cta-b > .W{position:relative;z-index:2}
.cta-b__i{display:flex;justify-content:space-between;align-items:center;gap:40px;flex-wrap:wrap}
.cta-b__title{font-family:var(--ff-d);font-size:clamp(22px,2.8vw,34px);font-weight:700;line-height:1.25;max-width:34ch;color:#fff;margin:0}
.cta-b__right{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.cta-b__sub{font-size:13px;color:rgba(255,255,255,.7)}

/* ── Portfolio Cards (.pc) ───────────────────────────────────────────────── */
.fr{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
@media(max-width:960px){.fr{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.fr{grid-template-columns:1fr}}
.pc{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;transition:all .3s var(--e);text-decoration:none;color:inherit;display:block}
.pc:hover{box-shadow:var(--sh);transform:translateY(-3px);border-color:rgba(197,161,87,.4)}
.pc--wide{grid-column:span 2}
@media(max-width:960px){.pc--wide{grid-column:span 1}}
.pc__img{position:relative;height:220px;background-size:cover;background-position:center;background-color:var(--navy3)}
.pc__ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(14,34,61,.6),transparent 50%)}
.pc__ct{padding:22px 24px}
.pc__cat{font-size:11px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:8px}
.pc__name{font-family:var(--ff-d);font-size:19px;font-weight:700;color:var(--navy);line-height:1.3;margin-bottom:8px}
.pc__detail{font-size:14px;color:var(--slate);line-height:1.55}
.pc__arr{display:inline-flex;align-items:center;gap:6px;margin-top:14px;font-size:13px;font-weight:700;color:var(--navy);letter-spacing:.05em}
.pc__arr::after{content:"→";color:var(--gold);font-weight:700}
.pf-btn{display:inline-flex;align-items:center;padding:9px 18px;font-size:13px;font-weight:600;color:var(--slate);background:#fff;border:1px solid var(--line);border-radius:999px;cursor:pointer;transition:all .2s}
.pf-btn:hover,.pf-btn.ac{background:var(--navy);color:#fff;border-color:var(--navy)}

/* ── FAQ (.faq / .faq__*) ────────────────────────────────────────────────── */
.faq{display:grid;gap:14px;max-width:900px;margin:0 auto}
.faq__item{background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;transition:border-color .2s}
.faq__item.on{border-color:var(--gold)}
.faq__q{width:100%;display:flex;justify-content:space-between;align-items:center;gap:18px;padding:20px 24px;background:none;border:none;text-align:left;font-family:var(--ff-d);font-size:17px;font-weight:700;color:var(--navy);cursor:pointer;line-height:1.35}
.faq__q:hover{color:var(--gold-dk)}
.faq__ic{width:18px;height:18px;flex-shrink:0;color:var(--gold);transition:transform .3s}
.faq__item.on .faq__ic{transform:rotate(45deg)}
.faq__a{max-height:0;overflow:hidden;transition:max-height .35s ease,padding .35s ease;padding:0 24px}
.faq__item.on .faq__a{max-height:700px;padding:0 24px 22px}
.faq__a-i{color:var(--slate);font-size:15px;line-height:1.7}
.faq__a-i p{margin-bottom:10px}
.faq__a-i p:last-child{margin-bottom:0}

/* ── Insights / Resources cards (.insight) ──────────────────────────────── */
.insight{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:26px;transition:all .3s var(--e);display:flex;flex-direction:column;height:100%}
.insight:hover{box-shadow:var(--sh-sm);transform:translateY(-2px);border-color:rgba(197,161,87,.4)}
.insight__cat{font-size:11px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:10px}
.insight__title{font-family:var(--ff-d);font-size:19px;font-weight:700;color:var(--navy);line-height:1.3;margin-bottom:10px}
.insight__excerpt{font-size:14.5px;color:var(--slate);line-height:1.6;flex-grow:1;margin-bottom:14px}
.insight__body{font-size:14.5px;color:var(--slate);line-height:1.7;margin-bottom:12px}
.insight__lk{font-size:13px;font-weight:700;color:var(--navy);text-decoration:none;letter-spacing:.04em;display:inline-flex;align-items:center;gap:6px}
.insight__lk::after{content:"→";color:var(--gold)}

/* ── Misc helpers ───────────────────────────────────────────────────────── */
.g3{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
@media(max-width:900px){.g3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.g3{grid-template-columns:1fr}}
.fp{padding:clamp(56px,7vw,96px) 0}
.fm{margin:clamp(40px,5vw,72px) 0}
.hl{color:var(--gold-dk);font-weight:700}
.pg{padding:clamp(40px,5vw,72px) 0}
.cta-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:32px;text-align:center}
.card__lbl{font-size:11px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:8px;display:block}
.ptable{width:100%;border-collapse:collapse;margin:18px 0}
.ptable th,.ptable td{padding:12px 14px;text-align:left;border-bottom:1px solid var(--line);font-size:14.5px}
.ptable th{background:var(--bg2,#F6F3EC);font-weight:700;color:var(--navy);font-size:13px;letter-spacing:.04em}
.review-note{background:rgba(197,161,87,.08);border-left:3px solid var(--gold);padding:14px 18px;border-radius:4px;font-size:14px;color:var(--ink);margin:18px 0}

/* ── Topbar right cluster (for when license badge removed) ──────────────── */
.topbar__r{display:flex;align-items:center;gap:16px}
@media(max-width:720px){.topbar__l .topbar__item:nth-child(3),.topbar__l .topbar__sep{display:none}}

/* ── Mobile bar (consolidated) ──────────────────────── */

/* ── FAQ JS hook (click handler for .faq__q in addition to .acc__q) ─────── */

/* _standard.css — Phase 3 corporate identity block (2026-04-27) */
.footer-corporate-block{padding:1rem 1rem;margin-top:1.5rem;border-top:1px solid currentColor;border-color:rgba(128,128,128,.25);font-size:.85rem;text-align:center;line-height:1.5;opacity:.85}
.footer-corporate-block .corporate-identity{display:flex;flex-direction:column;gap:.4rem;align-items:center}
.footer-corporate-block .entity{font-weight:600}
.footer-corporate-block address{font-style:normal;display:flex;flex-direction:column;gap:.25rem}
.footer-corporate-block address a{color:inherit;text-decoration:none;border-bottom:1px dotted currentColor}
.footer-corporate-block address a:hover{opacity:.7}
.footer-corporate-block .copyright{margin-top:.5rem;font-size:.78rem;opacity:.85}
.footer-corporate-block .securities-notice{margin-top:1rem;padding:.85rem 1rem;background:rgba(0,0,0,.04);border-left:3px solid currentColor;border-color:rgba(128,128,128,.4);font-size:.75rem;line-height:1.5;text-align:left;max-width:880px;margin-left:auto;margin-right:auto}
@media (max-width:600px){.footer-corporate-block{font-size:.78rem}.footer-corporate-block .securities-notice{font-size:.7rem}}
