:root{
  --bg:#FFFFFF;
  --bg-2:#F7F4EC;
  --bg-3:#F0EBDD;
  --ink:#0F1B2D;
  --ink-2:#1F2937;
  --ink-dim:#4A5568;
  --ink-mute:#6B7280;
  --ink-faint:#9CA3AF;
  --rule:#E5E1D8;
  --rule-soft:#EFEBE0;
  --rule-strong:#D1CDC4;
  --brand:#D8541C;
  --brand-2:#E66B2D;
  --brand-deep:#B23E08;
  --brand-soft:rgba(216,84,28,0.08);
  --brand-rgb:216,84,28;
  --green:#2E7D5C;
  --display:'Crimson Pro',ui-serif,'Times New Roman',Georgia,serif;
  --sans:'Plus Jakarta Sans',system-ui,-apple-system,sans-serif;
  --shadow-1:0 1px 2px rgba(15,27,45,0.04),0 4px 12px rgba(15,27,45,0.04);
  --shadow-2:0 4px 8px rgba(15,27,45,0.04),0 16px 40px rgba(15,27,45,0.08);
  --shadow-3:0 24px 60px -16px rgba(15,27,45,0.18);
  --container:1240px;
  --pad:clamp(20px,3.6vw,56px);
  --radius:10px;
  --radius-lg:14px;
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:hidden;max-width:100%}
body{
  margin:0;background:var(--bg);color:var(--ink);
  font-family:var(--sans);font-size:16px;line-height:1.65;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
  max-width:100%;width:100%;
}
::selection{background:var(--ink);color:#fff}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:var(--bg-2)}
::-webkit-scrollbar-thumb{background:var(--rule-strong);border-radius:6px}
::-webkit-scrollbar-thumb:hover{background:var(--ink-mute)}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;cursor:pointer;background:none;border:0;padding:0}
img,svg{display:block;max-width:100%}
input,select,textarea{font:inherit;color:inherit}
:focus-visible{outline:2px solid var(--brand);outline-offset:3px;border-radius:4px}

/* TYPE */
h1,h2,h3,h4,h5{font-family:var(--display);color:var(--ink);font-weight:600;letter-spacing:-0.01em;line-height:1.12;margin:0;overflow-wrap:break-word;word-wrap:break-word}
.kicker{display:inline-block;font-size:12px;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:var(--brand);margin-bottom:18px}
.visually-hidden{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}

/* LAYOUT */
.container{max-width:var(--container);margin:0 auto;padding:0 var(--pad)}
section{position:relative}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:13px 22px;border-radius:8px;font-weight:600;font-size:14px;letter-spacing:0;transition:transform .2s ease,background .2s ease,color .2s ease,box-shadow .2s ease,border-color .2s;border:1px solid transparent;cursor:pointer}
.btn-primary{background:var(--brand);color:#fff;border-color:var(--brand)}
.btn-primary:hover{background:var(--brand-deep);border-color:var(--brand-deep);transform:translateY(-1px);box-shadow:0 8px 16px -4px rgba(var(--brand-rgb),0.45)}
.btn-ink{background:var(--ink);color:#fff;border-color:var(--ink)}
.btn-ink:hover{background:#06111E;transform:translateY(-1px);box-shadow:0 8px 16px -4px rgba(15,27,45,0.25)}
.btn-white{background:#fff;color:var(--ink);border-color:var(--rule)}
.btn-white:hover{border-color:var(--ink);transform:translateY(-1px)}
.btn-ghost{border-color:var(--rule);color:var(--ink-2);background:transparent}
.btn-ghost:hover{border-color:var(--ink);color:var(--ink);background:#fff}
.btn-link{display:inline-flex;align-items:center;gap:8px;color:var(--brand);font-weight:600;font-size:14px;transition:gap .2s,color .2s}
.btn-link:hover{gap:14px;color:var(--brand-deep)}
.btn-link svg{width:14px;height:14px}

/* UTILITY BAR */
.util{background:var(--bg-2);border-bottom:1px solid var(--rule);font-size:12.5px;color:var(--ink-dim);padding:9px 0}
.util__inner{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}
.util__left{display:flex;gap:24px;align-items:center}
.util__left a{color:var(--ink-dim);transition:color .2s;display:inline-flex;align-items:center;gap:6px}
.util__left a:hover{color:var(--brand)}
.util__left svg{width:12px;height:12px}
.util__right{display:flex;gap:18px;align-items:center}
.util__right .live{display:inline-flex;align-items:center;gap:8px;color:var(--ink)}
.util__right .live::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 0 0 rgba(46,125,92,0.5);animation:liveDot 2.4s infinite}
@keyframes liveDot{0%{box-shadow:0 0 0 0 rgba(46,125,92,0.5)}70%{box-shadow:0 0 0 8px rgba(46,125,92,0)}100%{box-shadow:0 0 0 0 rgba(46,125,92,0)}}
.util__right .socials{display:flex;gap:10px}
.util__right .socials a{color:var(--ink-mute)}
.util__right .socials a:hover{color:var(--brand)}
.util__right .socials svg{width:14px;height:14px}
.util__portal{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:5px;background:var(--ink);color:#fff !important;font-weight:600;font-size:11.5px;letter-spacing:0.02em;transition:background .2s,color .2s}
.util__portal:hover{background:var(--brand);color:#fff !important}
.util__portal svg{width:11px;height:11px}
.util__portal:nth-of-type(2){background:var(--brand)}
.util__portal:nth-of-type(2):hover{background:var(--ink)}
@media (max-width:760px){.util{display:none}}

/* NAV */
.nav{position:sticky;top:0;z-index:40;background:rgba(255,255,255,0.94);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--rule);transition:box-shadow .3s ease,border-color .3s}
.nav.scrolled{box-shadow:0 1px 0 var(--rule),0 8px 16px -8px rgba(15,27,45,0.08)}
.nav__inner{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:32px;padding:18px 0}
.nav__brand{display:flex;align-items:center;gap:12px}
.nav__seal{width:38px;height:38px;border-radius:8px;background:var(--ink);color:var(--brand-2);display:grid;place-items:center;font-family:var(--display);font-weight:600;font-size:20px;letter-spacing:-0.02em}
.nav__name{display:flex;flex-direction:column;line-height:1.1}
.nav__name strong{font-family:var(--display);font-weight:600;font-size:19px;letter-spacing:-0.015em;color:var(--ink)}
.nav__name small{font-size:10.5px;letter-spacing:0.16em;text-transform:uppercase;color:var(--ink-mute);font-weight:500;margin-top:3px}
.nav__links{display:flex;justify-content:center;gap:2px;list-style:none;padding:0;margin:0}
.nav__links > li{position:relative}
.nav__links a{display:inline-flex;align-items:center;gap:6px;padding:10px 14px;border-radius:6px;font-size:14px;font-weight:500;color:var(--ink-2);transition:background .2s,color .2s}
.nav__links a:hover{color:var(--ink);background:var(--bg-2)}
.nav__links a.active{color:var(--brand)}
.nav__links .has-sub > a::after{content:"";width:5px;height:5px;border-right:1.5px solid currentColor;border-bottom:1.5px solid currentColor;transform:rotate(45deg) translateY(-2px);margin-left:2px}
.nav__sub{position:absolute;top:100%;left:0;min-width:280px;background:#fff;border:1px solid var(--rule);border-radius:10px;padding:8px;list-style:none;margin:8px 0 0 0;opacity:0;visibility:hidden;transform:translateY(8px);transition:all .25s;box-shadow:var(--shadow-2)}
.nav__links .has-sub:hover .nav__sub,.nav__links .has-sub:focus-within .nav__sub{opacity:1;visibility:visible;transform:translateY(0)}
.nav__sub a{display:flex;justify-content:space-between;padding:10px 12px;border-radius:6px;color:var(--ink-2);font-size:13.5px}
.nav__sub a:hover{background:var(--bg-2);color:var(--ink)}
.nav__sub a span{font-size:11px;color:var(--brand);font-weight:600}
.nav__actions{display:flex;align-items:center;gap:10px}
.nav__cta{padding:11px 18px;font-size:13.5px}
.nav__links .nav__portal-link{color:var(--ink) !important;font-weight:600;padding:8px 14px;border:1px solid var(--rule);border-radius:6px;transition:all .2s}
.nav__links .nav__portal-link:hover{background:var(--ink);color:#fff !important;border-color:var(--ink)}
.nav__links .nav__portal-link--client{background:var(--brand-soft);color:var(--brand) !important;border-color:transparent}
.nav__links .nav__portal-link--client:hover{background:var(--brand);color:#fff !important;border-color:var(--brand)}
.nav__links > li:nth-last-child(2){margin-left:8px}
.nav__burger{display:none;width:42px;height:42px;border-radius:8px;border:1px solid var(--rule);align-items:center;justify-content:center}
.nav__burger span{width:18px;height:1.5px;background:var(--ink);position:relative}
.nav__burger span::before,.nav__burger span::after{content:"";position:absolute;left:0;width:18px;height:1.5px;background:var(--ink)}
.nav__burger span::before{top:-6px}.nav__burger span::after{top:6px}
@media (max-width:1280px){.nav__links .nav__portal-link{display:none}.nav__links > li:nth-last-child(2){margin-left:0}}
@media (max-width:1180px){
  .nav__links{display:none}
  .nav__cta{display:none}
  .nav__burger{display:inline-flex}
  /* mobile-only extra padding on the nav so the burger sits comfortably away from the edge */
  .nav .container{padding-left:24px;padding-right:24px}
}
@media (max-width:380px){
  .nav__name strong{font-size:17px}
  .nav__name small{font-size:9.5px;letter-spacing:0.14em}
  .nav .container{padding-left:18px;padding-right:18px}
}

/* DRAWER */
.drawer{position:fixed;inset:0;z-index:60;background:#fff;transform:translateX(100%);transition:transform .35s cubic-bezier(.77,0,.18,1);display:flex;flex-direction:column;overflow-y:auto}
.drawer.open{transform:translateX(0)}
.drawer__head{display:flex;justify-content:space-between;align-items:center;padding:18px var(--pad);border-bottom:1px solid var(--rule)}
.drawer__close{width:42px;height:42px;border-radius:8px;border:1px solid var(--rule);position:relative}
.drawer__close::before,.drawer__close::after{content:"";position:absolute;left:50%;top:50%;width:18px;height:1.5px;background:var(--ink)}
.drawer__close::before{transform:translate(-50%,-50%) rotate(45deg)}
.drawer__close::after{transform:translate(-50%,-50%) rotate(-45deg)}
.drawer__list{list-style:none;padding:24px var(--pad);margin:0;display:flex;flex-direction:column;gap:0;flex:1}
.drawer__list a{display:flex;align-items:center;justify-content:space-between;padding:18px 0;border-bottom:1px solid var(--rule);font-family:var(--display);font-size:24px;font-weight:500;letter-spacing:-0.01em;color:var(--ink)}
.drawer__list a small{font-size:12px;color:var(--ink-mute);letter-spacing:0.12em;font-weight:500}
.drawer__portals{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:16px var(--pad);border-top:1px solid var(--rule);background:var(--bg-2)}
.drawer__portals a{padding:18px 14px;border-radius:10px;font-weight:600;font-size:14px;display:flex;flex-direction:column;gap:4px;color:#fff}
.drawer__portals .small{font-size:11px;letter-spacing:0.14em;text-transform:uppercase;opacity:0.7;font-weight:600}
.drawer__portals a.cand{background:var(--ink)}
.drawer__portals a.cli{background:var(--brand)}

/* HOMEPAGE HERO */
.hero{padding:clamp(48px,7vw,90px) 0 clamp(40px,6vw,72px);position:relative;overflow:hidden}
.hero__bg{position:absolute;inset:0;z-index:0;pointer-events:none}
.hero__bg::before{content:"";position:absolute;top:-200px;right:-200px;width:700px;height:700px;border-radius:50%;background:radial-gradient(circle,rgba(var(--brand-rgb),0.08) 0%,transparent 60%)}
.hero__grid{position:relative;z-index:2;display:grid;grid-template-columns:minmax(0,1.4fr) minmax(0,1fr);gap:clamp(36px,4.5vw,72px);align-items:center}
.hero__left .kicker{margin-bottom:22px}
.hero__h1{font-family:var(--display);font-weight:600;font-size:clamp(40px,5.4vw,68px);letter-spacing:-0.015em;line-height:1.06;margin:0 0 24px;color:var(--ink)}
.hero__h1 .accent{color:var(--brand)}
.hero__sub{font-size:17.5px;line-height:1.65;color:var(--ink-dim);margin:0 0 32px;max-width:54ch}
.hero__ctas{display:flex;gap:12px;flex-wrap:wrap;align-items:center;margin-bottom:40px}
.hero__trust{display:flex;gap:32px;flex-wrap:wrap;align-items:center;padding-top:28px;border-top:1px solid var(--rule)}
.hero__trust-item{display:flex;flex-direction:column;gap:6px}
.hero__trust-item .v{font-family:var(--display);font-weight:600;font-size:28px;letter-spacing:-0.02em;line-height:1;color:var(--ink)}
.hero__trust-item .l{font-size:12.5px;color:var(--ink-mute);letter-spacing:0.04em;font-weight:500;text-transform:uppercase}
.hero__rec{display:inline-flex;align-items:center;gap:8px;font-size:12.5px;color:var(--ink-dim)}
.hero__rec .star{color:var(--brand)}
.hero__portals{background:var(--bg-2);border:1px solid var(--rule);border-radius:var(--radius-lg);padding:24px}
.hero__portals-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:16px}
.hero__portals-head h3{font-family:var(--display);font-weight:600;font-size:20px;letter-spacing:-0.01em}
.hero__portals-head small{font-size:12px;color:var(--ink-mute);letter-spacing:0.06em;text-transform:uppercase;font-weight:500}
.portal{display:flex;flex-direction:column;background:#fff;border:1px solid var(--rule);border-radius:var(--radius);padding:22px;margin-bottom:12px;transition:transform .25s ease,border-color .25s ease,box-shadow .25s ease;position:relative;overflow:hidden}
.portal:last-of-type{margin-bottom:0}
.portal::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:transparent;transition:background .25s}
.portal:hover{transform:translateY(-2px);border-color:var(--rule-strong);box-shadow:var(--shadow-1)}
.portal--candidate:hover::before{background:var(--brand)}
.portal--client:hover::before{background:var(--ink)}
.portal__top{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:14px}
.portal__icon{width:44px;height:44px;border-radius:8px;display:grid;place-items:center;flex-shrink:0}
.portal__icon svg{width:20px;height:20px}
.portal--candidate .portal__icon{background:var(--brand-soft);color:var(--brand)}
.portal--client .portal__icon{background:var(--ink);color:#fff}
.portal__count{display:inline-flex;align-items:center;gap:8px;font-size:11.5px;color:var(--ink-dim);font-weight:500;background:var(--bg-2);border:1px solid var(--rule);padding:5px 10px;border-radius:999px}
.portal__count .dot{width:6px;height:6px;border-radius:50%;background:var(--green);animation:liveDot 2.4s infinite}
.portal h4{font-family:var(--display);font-weight:600;font-size:20px;letter-spacing:-0.015em;margin:0 0 6px;color:var(--ink)}
.portal p{font-size:13.5px;color:var(--ink-dim);margin:0 0 18px;line-height:1.55;max-width:42ch}
.portal__actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.portal__actions .btn{flex:1;min-width:120px;padding:12px 16px;font-size:13.5px}
.portal__foot{display:flex;justify-content:space-between;font-size:12px;color:var(--ink-mute);margin-top:14px;padding-top:12px;border-top:1px solid var(--rule)}
.portal__foot a{color:var(--brand);font-weight:600}
.portals__support{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-top:16px;padding-top:16px;border-top:1px solid var(--rule);font-size:13px;color:var(--ink-dim);flex-wrap:wrap}
.portals__support a{color:var(--brand);font-weight:600}
@media (max-width:1080px){.hero__grid{grid-template-columns:1fr;gap:32px}.hero__portals{order:-1;max-width:560px}}
@media (max-width:560px){.hero__h1{font-size:clamp(34px,9vw,46px)}.hero__trust{gap:20px}.hero__trust-item .v{font-size:24px}.portal{padding:18px}}

/* INNER PAGE HERO */
.page-hero{padding:clamp(40px,6vw,72px) 0 clamp(40px,5vw,56px);position:relative;overflow:hidden;background:var(--bg-2);border-bottom:1px solid var(--rule)}
.page-hero::before{content:"";position:absolute;top:-160px;right:-160px;width:520px;height:520px;border-radius:50%;background:radial-gradient(circle,rgba(var(--brand-rgb),0.10) 0%,transparent 60%);pointer-events:none}
.page-hero__inner{position:relative;z-index:2;display:grid;grid-template-columns:minmax(0,1.4fr) minmax(0,1fr);gap:48px;align-items:end}
.page-hero__inner--center{grid-template-columns:1fr;text-align:center;max-width:780px;margin:0 auto}
.page-hero__inner--center .breadcrumb{justify-content:center}
.page-hero__inner--center .page-hero__sub{margin-left:auto;margin-right:auto}
.breadcrumb{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:12.5px;color:var(--ink-mute);font-weight:500;margin-bottom:18px}
.breadcrumb a{color:var(--ink-dim);transition:color .2s}
.breadcrumb a:hover{color:var(--brand)}
.breadcrumb .sep{color:var(--ink-faint)}
.breadcrumb .current{color:var(--ink);font-weight:600}
.page-hero h1{font-family:var(--display);font-weight:600;font-size:clamp(30px,5vw,62px);letter-spacing:-0.015em;line-height:1.1;color:var(--ink);margin:0 0 18px;overflow-wrap:break-word;word-wrap:break-word;hyphens:auto}
.page-hero h1 .accent{color:var(--brand)}
.page-hero__sub{font-size:17px;color:var(--ink-dim);line-height:1.65;margin:0;max-width:58ch}
.page-hero__right{display:flex;flex-direction:column;gap:16px;align-items:flex-end;justify-self:end}
.page-hero__stats{display:grid;grid-template-columns:1fr 1fr;gap:14px;width:100%;max-width:380px}
.page-hero__stat{background:#fff;border:1px solid var(--rule);border-radius:var(--radius);padding:18px 18px}
.page-hero__stat .v{font-family:var(--display);font-weight:700;font-size:30px;letter-spacing:-0.02em;line-height:1;color:var(--ink)}
.page-hero__stat .v .accent{color:var(--brand)}
.page-hero__stat .l{font-size:12px;color:var(--ink-mute);letter-spacing:0.04em;font-weight:500;margin-top:8px;text-transform:uppercase}
@media (max-width:880px){.page-hero__inner{grid-template-columns:1fr;gap:24px}.page-hero__right{align-items:flex-start;justify-self:start}}

/* TRUST STRIP */
.trust{border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);padding:32px 0;background:var(--bg-2)}
.trust__inner{display:flex;align-items:center;gap:48px;flex-wrap:wrap;justify-content:space-between}
.trust__lead{font-size:13px;color:var(--ink-dim);max-width:240px;font-weight:500}
.trust__lead strong{color:var(--ink);font-weight:600;display:block;margin-bottom:4px;font-family:var(--display);font-size:15px}
.trust__logos{display:flex;align-items:center;gap:48px;flex-wrap:wrap;flex:1;justify-content:center}
.trust__logo{font-family:var(--display);font-weight:600;font-size:18px;color:var(--ink-2);letter-spacing:-0.01em;opacity:0.7;transition:opacity .2s}
.trust__logo:hover{opacity:1}
.trust__logo small{font-size:10px;display:block;color:var(--ink-mute);letter-spacing:0.14em;text-transform:uppercase;font-weight:500;font-family:var(--sans);margin-top:2px}

/* SERVICES (cards) */
.services{padding:clamp(70px,9vw,120px) 0;background:var(--bg)}
.section-head{display:grid;grid-template-columns:1fr auto;gap:32px;align-items:end;margin-bottom:48px}
.section-head h2{font-family:var(--display);font-weight:600;font-size:clamp(32px,4vw,48px);letter-spacing:-0.015em;line-height:1.1;color:var(--ink)}
.section-head h2 .accent{color:var(--brand)}
.section-head p{font-size:15.5px;color:var(--ink-dim);margin:14px 0 0;max-width:48ch;line-height:1.65}
.section-head__r{display:flex;flex-direction:column;align-items:flex-end;gap:14px}
.services__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.service{position:relative;background:#fff;border:1px solid var(--rule);border-radius:var(--radius-lg);padding:28px 26px 26px;transition:transform .25s ease,border-color .25s ease,box-shadow .25s ease;display:flex;flex-direction:column}
.service:hover{transform:translateY(-3px);border-color:var(--rule-strong);box-shadow:var(--shadow-2)}
.service__icon{width:52px;height:52px;border-radius:10px;background:var(--bg-2);color:var(--brand);display:grid;place-items:center;margin-bottom:24px;transition:background .25s,color .25s}
.service:hover .service__icon{background:var(--brand);color:#fff}
.service__icon svg{width:22px;height:22px}
.service h3{font-family:var(--display);font-weight:600;font-size:21px;letter-spacing:-0.01em;margin:0 0 10px;line-height:1.2}
.service p{font-size:14px;color:var(--ink-dim);line-height:1.6;margin:0 0 24px;flex:1}
.service__foot{display:flex;justify-content:space-between;align-items:center;padding-top:16px;border-top:1px solid var(--rule)}
.service__tag{font-size:11.5px;color:var(--ink-mute);letter-spacing:0.06em;text-transform:uppercase;font-weight:500}
.service__arrow{width:34px;height:34px;border-radius:50%;background:var(--bg-2);color:var(--ink);display:inline-flex;align-items:center;justify-content:center;transition:all .25s}
.service:hover .service__arrow{background:var(--ink);color:#fff;transform:translateX(2px)}
.service__arrow svg{width:13px;height:13px}
.service__badge{position:absolute;top:18px;right:18px;font-size:10px;letter-spacing:0.12em;text-transform:uppercase;font-weight:600;color:var(--brand);background:var(--brand-soft);padding:4px 8px;border-radius:4px}
@media (max-width:1080px){.services__grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.services__grid{grid-template-columns:1fr}.section-head{grid-template-columns:1fr}.section-head__r{align-items:flex-start}}

/* ABOUT */
.about{padding:clamp(70px,9vw,120px) 0;background:var(--bg-2);border-top:1px solid var(--rule);border-bottom:1px solid var(--rule)}
.about__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,5vw,80px);align-items:start}
.about__head h2{font-family:var(--display);font-weight:600;font-size:clamp(34px,4.4vw,54px);letter-spacing:-0.015em;line-height:1.08;margin-bottom:24px}
.about__head h2 .accent{color:var(--brand)}
.about__head p{font-size:16px;color:var(--ink-dim);margin:0 0 16px;line-height:1.7}
.about__head p strong{color:var(--ink);font-weight:600}
.about__signature{display:flex;align-items:center;gap:14px;margin-top:32px;padding-top:24px;border-top:1px solid var(--rule)}
.about__signature-photo{width:52px;height:52px;border-radius:50%;background:var(--ink);color:#fff;display:grid;place-items:center;font-family:var(--display);font-weight:600;font-size:18px;letter-spacing:-0.02em;flex-shrink:0}
.about__signature-meta strong{font-family:var(--display);font-weight:600;font-size:15.5px;display:block;letter-spacing:-0.01em}
.about__signature-meta small{font-size:12.5px;color:var(--ink-mute)}
.about__cards{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.about__card{background:#fff;border:1px solid var(--rule);border-radius:var(--radius);padding:24px 22px;transition:transform .25s,border-color .25s}
.about__card:hover{transform:translateY(-2px);border-color:var(--rule-strong)}
.about__card .v{font-family:var(--display);font-weight:600;font-size:38px;letter-spacing:-0.025em;line-height:1;color:var(--ink);margin-bottom:10px}
.about__card .v .accent{color:var(--brand)}
.about__card .l{font-size:13px;color:var(--ink-dim);line-height:1.5;margin-bottom:6px;font-weight:500}
.about__card-wide{grid-column:1/-1;background:var(--ink);color:#fff;padding:28px 24px}
.about__card-wide .v,.about__card-wide .v .accent{color:#fff}
.about__card-wide .v .accent{color:var(--brand-2)}
.about__card-wide .l{color:rgba(255,255,255,0.7)}
.about__card-wide .body{font-size:15px;color:rgba(255,255,255,0.85);line-height:1.65;margin-top:10px}
@media (max-width:880px){.about__grid{grid-template-columns:1fr;gap:32px}}
@media (max-width:480px){.about__cards{grid-template-columns:1fr}}

/* DEEP SERVICES (row list) */
.deep{padding:clamp(70px,9vw,120px) 0}
.deep__rows{border-top:1px solid var(--rule)}
.deep__row{display:grid;grid-template-columns:64px minmax(0,1.4fr) minmax(0,1fr) 56px;gap:32px;align-items:center;padding:26px 0;border-bottom:1px solid var(--rule);transition:padding .25s,background .25s;position:relative}
.deep__row:hover{padding-left:18px;background:var(--bg-2)}
.deep__row:hover .deep__arrow{background:var(--brand);color:#fff;border-color:var(--brand)}
.deep__num{font-size:14px;color:var(--ink-mute);font-weight:600;letter-spacing:0.04em}
.deep__row h3{font-family:var(--display);font-weight:600;font-size:clamp(20px,2.2vw,26px);letter-spacing:-0.015em;line-height:1.2}
.deep__row p{font-size:14.5px;color:var(--ink-dim);margin:0;line-height:1.55}
.deep__arrow{justify-self:end;width:44px;height:44px;border-radius:50%;border:1px solid var(--rule);display:inline-flex;align-items:center;justify-content:center;color:var(--ink);transition:all .25s;background:#fff}
.deep__arrow svg{width:14px;height:14px}
@media (max-width:880px){.deep__row{grid-template-columns:48px 1fr 44px;gap:14px;padding:20px 0}.deep__row p{display:none}.deep__arrow{width:44px;height:44px}}

/* AWARDS (dark band) */
.awards{padding:clamp(70px,9vw,120px) 0;background:var(--ink);color:#fff}
.awards .kicker{color:var(--brand-2)}
.awards .section-head h2{color:#fff}
.awards .section-head h2 .accent{color:var(--brand-2)}
.awards .section-head p{color:rgba(255,255,255,0.7)}
.awards__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.award{background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.10);border-radius:var(--radius-lg);padding:30px 26px;transition:all .3s ease;position:relative}
.award:hover{background:rgba(255,255,255,0.06);border-color:var(--brand-2);transform:translateY(-3px)}
.award__year{font-family:var(--display);font-weight:600;font-size:48px;letter-spacing:-0.03em;color:var(--brand-2);line-height:1;margin-bottom:14px}
.award h3{font-family:var(--display);font-weight:600;font-size:18px;line-height:1.3;letter-spacing:-0.01em;color:#fff;margin-bottom:8px}
.award__org{font-size:12.5px;color:rgba(255,255,255,0.55);letter-spacing:0.04em;font-weight:500;text-transform:uppercase}
.award__seal{position:absolute;top:22px;right:22px;width:42px;height:42px;border:1px solid rgba(255,255,255,0.20);border-radius:50%;display:grid;place-items:center;color:var(--brand-2)}
.award__seal svg{width:18px;height:18px}
@media (max-width:880px){.awards__grid{grid-template-columns:1fr}}

/* CV WRITING */
.cv{padding:clamp(70px,9vw,120px) 0}
.cv__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,80px);align-items:center}
.cv__visual{position:relative;aspect-ratio:1/1.05}

/* CV before/after — shared shell */
.cv__doc{
  position:absolute;inset:0;
  border:1px solid var(--rule);border-radius:var(--radius);
  padding:22px 24px;
  box-shadow:var(--shadow-2);
  display:flex;flex-direction:column;
  overflow:hidden;
}
.cv__tag{
  font-size:9.5px;letter-spacing:0.18em;text-transform:uppercase;font-weight:700;
  padding:4px 9px;border-radius:4px;
  align-self:flex-start;flex-shrink:0;
}

/* BEFORE — amateur, dense, faded */
.cv__doc--before{
  background:#FBF8F1;
  transform:rotate(-5deg) translate(-22px,22px);
  gap:8px;
}
.cv__doc--before::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg,rgba(0,0,0,0) 60%,rgba(0,0,0,0.04) 100%);
}
.cv__tag--before{background:rgba(0,0,0,0.08);color:var(--ink-mute)}
.cv__bf-title{
  font-family:var(--display);font-weight:400;font-style:italic;
  font-size:20px;color:var(--ink-2);text-align:center;
  padding:4px 0 6px;border-bottom:1px solid rgba(0,0,0,0.15);
}
.cv__bf-sub{text-align:center;font-size:12px;color:var(--ink-dim);font-weight:600;margin-bottom:4px}
.cv__bf-block{font-size:10.5px;line-height:1.55;color:var(--ink-dim);margin:0}
.cv__bf-block strong{color:var(--ink-2);font-weight:700}

/* AFTER — looks like a real professional CV */
.cv__doc--after{
  background:#fff;
  transform:rotate(4deg) translate(30px,-18px);
  gap:10px;
  z-index:2;
  padding:20px 22px;
}
.cv__doc--after::before{
  content:"";position:absolute;left:0;top:0;right:0;height:4px;
  background:linear-gradient(90deg,var(--brand),var(--brand-2));
}
.cv__af-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;padding-top:6px;padding-bottom:6px;border-bottom:1px solid var(--rule)}
.cv__af-name h4{font-family:var(--display);font-weight:700;font-size:19px;color:var(--ink);margin:0;letter-spacing:-0.01em;line-height:1.1}
.cv__af-name small{display:block;font-size:10.5px;color:var(--ink-dim);font-weight:600;letter-spacing:0.04em;margin-top:2px;text-transform:uppercase}
.cv__tag--after{background:var(--brand-soft);color:var(--brand)}

.cv__af-contact{
  display:flex;flex-wrap:wrap;gap:10px;
  font-size:9.5px;color:var(--ink-mute);font-weight:500;letter-spacing:0.02em;
  padding-bottom:6px;border-bottom:1px solid var(--rule);
}
.cv__af-contact span{display:inline-flex;align-items:center;gap:4px;line-height:1}
.cv__af-contact svg{width:9px;height:9px;color:var(--brand);flex-shrink:0}

.cv__af-section{display:flex;flex-direction:column;gap:5px}
.cv__af-section-title{
  font-size:8.5px;letter-spacing:0.2em;text-transform:uppercase;
  font-weight:700;color:var(--brand);
  padding-bottom:3px;border-bottom:1px solid var(--rule);
}
.cv__af-profile{
  font-size:10px;line-height:1.5;color:var(--ink-2);margin:0;
  font-family:var(--display);font-style:italic;font-weight:400;
}
.cv__af-job{display:flex;flex-direction:column;gap:1px;margin-bottom:4px}
.cv__af-job:last-child{margin-bottom:0}
.cv__af-job-line{display:flex;justify-content:space-between;align-items:baseline;gap:8px}
.cv__af-job-line strong{font-family:var(--display);font-weight:600;font-size:12.5px;color:var(--ink)}
.cv__af-job-line span{font-size:9.5px;color:var(--ink-mute);font-weight:600;letter-spacing:0.04em;white-space:nowrap}
.cv__af-job-co{font-size:10px;color:var(--ink-dim);font-style:italic;line-height:1.3}
.cv__af-bullets{list-style:none;padding:0;margin:3px 0 0;display:flex;flex-direction:column;gap:2px}
.cv__af-bullets li{
  font-size:9.5px;line-height:1.45;color:var(--ink-dim);
  padding-left:9px;position:relative;
}
.cv__af-bullets li::before{
  content:"";position:absolute;left:0;top:6px;
  width:3px;height:3px;border-radius:50%;background:var(--brand);
}

.cv__af-tags{display:flex;flex-wrap:wrap;gap:3px}
.cv__af-tags span{
  font-size:8.5px;font-weight:600;color:var(--ink-2);letter-spacing:0.04em;
  padding:2px 6px;border-radius:3px;
  background:var(--bg-2);border:1px solid var(--rule);
}

.cv__af-edu{font-size:9.5px;line-height:1.45;color:var(--ink-dim);margin:0}
.cv__af-edu strong{color:var(--ink-2);font-weight:600}
.cv__head h2{font-family:var(--display);font-weight:600;font-size:clamp(32px,4vw,48px);letter-spacing:-0.015em;line-height:1.08;margin-bottom:20px}
.cv__head h2 .accent{color:var(--brand)}
.cv__head p{font-size:16px;color:var(--ink-dim);margin:0 0 16px;line-height:1.7}
.cv__list{list-style:none;padding:0;margin:24px 0 28px;display:flex;flex-direction:column;gap:12px}
.cv__list li{display:flex;gap:12px;font-size:14.5px;color:var(--ink-2);align-items:flex-start;line-height:1.55}
.cv__list li::before{content:"";width:20px;height:20px;border-radius:50%;background:var(--brand-soft);flex-shrink:0;margin-top:1px;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23D8541C' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>");background-size:12px;background-position:center;background-repeat:no-repeat}
@media (max-width:880px){.cv__grid{grid-template-columns:1fr}.cv__visual{order:-1;max-width:480px;aspect-ratio:5/4}}

/* VACANCIES */
.vacancies{padding:clamp(70px,9vw,120px) 0;background:var(--bg-2);border-top:1px solid var(--rule);border-bottom:1px solid var(--rule)}
.jobs{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:32px}
.job{position:relative;background:#fff;border:1px solid var(--rule);border-radius:var(--radius);padding:22px;transition:all .25s;cursor:pointer}
.job:hover{border-color:var(--rule-strong);transform:translateY(-2px);box-shadow:var(--shadow-1)}
.job__head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;font-size:12px}
.job__loc{color:var(--ink-dim);display:flex;align-items:center;gap:6px;font-weight:500;letter-spacing:0.04em;text-transform:uppercase}
.job__loc::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--brand)}
.job__type{color:var(--brand);background:var(--brand-soft);padding:4px 9px;border-radius:5px;font-size:10.5px;letter-spacing:0.1em;text-transform:uppercase;font-weight:600}
.job h4{font-family:var(--display);font-weight:600;font-size:18px;letter-spacing:-0.01em;line-height:1.25;margin:0 0 8px;color:var(--ink)}
.job__meta{display:flex;align-items:center;gap:10px;color:var(--ink-mute);font-size:13px;font-weight:500;margin-bottom:18px}
.job__meta strong{color:var(--ink);font-weight:600}
.job__meta .dot{width:3px;height:3px;border-radius:50%;background:var(--ink-mute)}
.job__foot{display:flex;justify-content:space-between;align-items:center;padding-top:14px;border-top:1px solid var(--rule)}
.job__salary{font-family:var(--display);font-weight:600;font-size:17px;letter-spacing:-0.01em;color:var(--ink)}
.job__arrow{width:34px;height:34px;border-radius:50%;background:var(--bg-2);display:inline-flex;align-items:center;justify-content:center;color:var(--ink);transition:all .25s}
.job:hover .job__arrow{background:var(--brand);color:#fff;transform:translateX(2px)}
.vacancies__cta{display:flex;justify-content:space-between;align-items:center;padding:24px 28px;background:#fff;border:1px solid var(--rule);border-radius:var(--radius);flex-wrap:wrap;gap:18px}
.vacancies__cta-left{display:flex;align-items:center;gap:14px;font-size:14.5px;color:var(--ink-dim);max-width:60ch}
.vacancies__cta-left strong{color:var(--ink)}
.vacancies__cta-left .badge{font-size:10.5px;letter-spacing:0.12em;text-transform:uppercase;background:var(--ink);color:#fff;padding:5px 9px;border-radius:5px;font-weight:600;flex-shrink:0}
@media (max-width:1080px){.jobs{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.jobs{grid-template-columns:1fr}}

/* CTA BANNER */
.cta-banner{padding:clamp(70px,9vw,120px) 0;background:#fff}
.cta-banner__inner{position:relative;border-radius:var(--radius-lg);overflow:hidden;background:var(--ink);color:#fff;padding:clamp(40px,6vw,72px) clamp(28px,4vw,60px);display:grid;grid-template-columns:1.4fr 1fr;gap:40px;align-items:center}
.cta-banner__inner::before{content:"";position:absolute;top:-30%;right:-15%;width:480px;height:480px;border-radius:50%;background:radial-gradient(circle,rgba(var(--brand-rgb),0.20) 0%,transparent 60%);pointer-events:none}
.cta-banner__copy{position:relative;z-index:2}
.cta-banner .kicker{color:var(--brand-2)}
.cta-banner h2{font-family:var(--display);font-weight:600;font-size:clamp(32px,4.2vw,52px);letter-spacing:-0.015em;line-height:1.08;color:#fff;margin:0 0 18px}
.cta-banner h2 .accent{color:var(--brand-2)}
.cta-banner__copy p{font-size:16px;margin:0 0 26px;max-width:520px;color:rgba(255,255,255,0.78);line-height:1.65}
.cta-banner__phones{position:relative;z-index:2;display:flex;flex-direction:column;gap:12px}
.cta-phone{display:flex;align-items:center;justify-content:space-between;gap:16px;background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.12);border-radius:var(--radius);padding:18px 22px;transition:all .25s}
.cta-phone:hover{background:#fff;color:var(--ink);border-color:#fff}
.cta-phone__lbl{font-size:11.5px;letter-spacing:0.1em;text-transform:uppercase;font-weight:600;color:rgba(255,255,255,0.65)}
.cta-phone:hover .cta-phone__lbl{color:var(--ink-mute)}
.cta-phone__num{font-family:var(--display);font-weight:600;font-size:22px;letter-spacing:-0.015em;line-height:1;margin-top:6px}
.cta-phone__icon{width:42px;height:42px;border-radius:50%;background:var(--brand);color:#fff;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .25s}
.cta-phone:hover .cta-phone__icon{background:var(--ink);color:var(--brand-2)}
.cta-banner .ctas{display:flex;gap:10px;flex-wrap:wrap}
@media (max-width:880px){.cta-banner__inner{grid-template-columns:1fr;gap:28px}}

/* FOOTER */
footer{background:var(--bg-2);border-top:1px solid var(--rule);padding:clamp(60px,7vw,90px) 0 24px}
.footer__top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:48px;padding-bottom:48px;border-bottom:1px solid var(--rule)}
.footer__brand .nav__name strong{color:var(--ink)}
.footer__tag{margin:18px 0 26px;color:var(--ink-dim);font-size:14.5px;line-height:1.65;max-width:38ch}
.footer__contact{display:flex;flex-direction:column;gap:11px;font-size:14px;color:var(--ink-dim)}
.footer__contact a{display:flex;align-items:center;gap:10px;transition:color .2s}
.footer__contact a:hover{color:var(--brand)}
.footer__contact svg{width:14px;height:14px;color:var(--brand)}
.footer__col h5{font-size:12px;letter-spacing:0.14em;text-transform:uppercase;color:var(--ink);margin:0 0 22px;font-weight:700}
.footer__col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:11px;font-size:14px;color:var(--ink-dim)}
.footer__col a:hover{color:var(--brand)}
.footer__newsletter form{position:relative;margin-top:12px}
.footer__newsletter input{width:100%;background:#fff;border:1px solid var(--rule);border-radius:8px;padding:14px 56px 14px 16px;color:var(--ink);font:inherit;font-size:14px;transition:border-color .2s}
.footer__newsletter input:focus{outline:0;border-color:var(--brand)}
.footer__newsletter button{position:absolute;right:5px;top:5px;width:42px;height:42px;border-radius:6px;background:var(--brand);color:#fff;display:inline-flex;align-items:center;justify-content:center;transition:background .2s}
.footer__newsletter button:hover{background:var(--brand-deep)}
.footer__newsletter small{font-size:11.5px;color:var(--ink-mute);margin-top:14px;display:block}
.footer__bottom{display:flex;justify-content:space-between;align-items:center;padding-top:24px;flex-wrap:wrap;gap:14px;font-size:13px;color:var(--ink-mute)}
.footer__badges{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.footer__badge{border:1px solid var(--rule);background:#fff;border-radius:999px;padding:6px 14px;font-size:11.5px;color:var(--ink-dim);font-weight:500;letter-spacing:0.04em;display:inline-flex;align-items:center;gap:6px;transition:border-color .2s,color .2s}
.footer__badge .star{color:var(--brand);font-weight:700}
.footer__badge--credit strong{color:var(--ink);font-weight:700;margin-left:2px;transition:color .2s}
.footer__badge--credit:hover{border-color:var(--brand);color:var(--ink)}
.footer__badge--credit:hover strong{color:var(--brand)}
.footer__socials{display:flex;gap:8px}
.footer__socials a{width:36px;height:36px;border-radius:8px;background:#fff;border:1px solid var(--rule);display:inline-flex;align-items:center;justify-content:center;color:var(--ink-2);transition:all .2s}
.footer__socials a:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.footer__socials svg{width:14px;height:14px}
@media (max-width:1080px){.footer__top{grid-template-columns:1fr 1fr;gap:36px}}
@media (max-width:560px){.footer__top{grid-template-columns:1fr}.footer__bottom{flex-direction:column;align-items:flex-start}}

/* FLOATING DOCK */
.dock{position:fixed;right:20px;bottom:20px;z-index:30;display:flex;flex-direction:column;gap:8px;align-items:flex-end}
.dock__main{display:flex;background:#fff;border-radius:999px;padding:5px;gap:4px;box-shadow:var(--shadow-3);border:1px solid var(--rule);opacity:0;transform:translateY(14px);transition:all .3s ease}
.dock__main.show{opacity:1;transform:translateY(0)}
.dock__btn{display:inline-flex;align-items:center;gap:8px;padding:9px 14px;border-radius:999px;font-size:13px;font-weight:600;color:var(--ink);transition:all .2s}
.dock__btn svg{width:13px;height:13px}
.dock__btn.cand{background:var(--ink);color:#fff}
.dock__btn.cand:hover{background:#06111E}
.dock__btn.cli{background:var(--brand);color:#fff}
.dock__btn.cli:hover{background:var(--brand-deep)}
.dock__top{width:42px;height:42px;border-radius:50%;background:#fff;color:var(--ink);display:inline-flex;align-items:center;justify-content:center;box-shadow:var(--shadow-1);border:1px solid var(--rule);opacity:0;transform:translateY(14px);transition:all .3s}
.dock__top.show{opacity:1;transform:translateY(0)}
.dock__top:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.dock__top svg{width:13px;height:13px}
@media (max-width:560px){.dock{right:12px;bottom:12px}.dock__btn{padding:9px 12px;font-size:12px}}

/* REVEALS */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
.reveal-d1{transition-delay:.08s}.reveal-d2{transition-delay:.16s}.reveal-d3{transition-delay:.24s}.reveal-d4{transition-delay:.32s}

/* GALLERY */
.gallery{padding:clamp(70px,9vw,120px) 0;background:var(--bg-2);border-top:1px solid var(--rule);border-bottom:1px solid var(--rule)}
.gallery__grid{display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:200px;gap:14px}
.gallery__item{position:relative;overflow:hidden;border-radius:var(--radius);cursor:pointer;background:var(--ink);transition:transform .35s ease}
.gallery__item:nth-child(1){grid-column:span 6;grid-row:span 2}
.gallery__item:nth-child(2){grid-column:span 3}
.gallery__item:nth-child(3){grid-column:span 3}
.gallery__item:nth-child(4){grid-column:span 3}
.gallery__item:nth-child(5){grid-column:span 3}
.gallery__item:nth-child(6){grid-column:span 4;grid-row:span 2}
.gallery__item:nth-child(7){grid-column:span 4}
.gallery__item:nth-child(8){grid-column:span 4}
.gallery__item:hover{transform:translateY(-3px)}
.gallery__item img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease,filter .4s ease;display:block}
.gallery__item:hover img{transform:scale(1.06)}
.gallery__item::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(15,27,45,0.85) 100%);z-index:1;opacity:0.85;transition:opacity .3s}
.gallery__item:hover::before{opacity:1}
.gallery__caption{position:absolute;left:18px;right:18px;bottom:16px;z-index:2;color:#fff}
.gallery__caption strong{font-family:var(--display);font-weight:600;font-size:18px;letter-spacing:-0.01em;line-height:1.2;display:block;margin-bottom:4px}
.gallery__caption small{font-size:12px;color:rgba(255,255,255,0.75);letter-spacing:0.06em;text-transform:uppercase;font-weight:500}
.gallery__zoom{position:absolute;top:14px;right:14px;z-index:2;width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,0.92);color:var(--ink);display:inline-flex;align-items:center;justify-content:center;opacity:0;transform:scale(0.9);transition:all .25s}
.gallery__item:hover .gallery__zoom{opacity:1;transform:scale(1)}
.gallery__zoom svg{width:14px;height:14px}
@media (max-width:880px){.gallery__grid{grid-template-columns:repeat(6,1fr);grid-auto-rows:160px}.gallery__item:nth-child(1){grid-column:span 6;grid-row:span 2}.gallery__item:nth-child(n+2){grid-column:span 3;grid-row:span 1}.gallery__item:nth-child(6){grid-column:span 6;grid-row:span 2}}
@media (max-width:560px){.gallery__grid{grid-template-columns:1fr;grid-auto-rows:200px}.gallery__item,.gallery__item:nth-child(n){grid-column:span 1;grid-row:span 1}}

/* LIGHTBOX */
.lb{position:fixed;inset:0;z-index:100;background:rgba(15,27,45,0.92);display:none;align-items:center;justify-content:center;padding:clamp(20px,5vw,60px)}
.lb.open{display:flex}
.lb__inner{position:relative;max-width:1100px;width:100%;max-height:90vh;display:flex;flex-direction:column;align-items:center;gap:14px}
.lb__img{max-width:100%;max-height:78vh;border-radius:var(--radius);box-shadow:var(--shadow-3);object-fit:contain;background:var(--ink)}
.lb__cap{color:#fff;text-align:center}
.lb__cap strong{font-family:var(--display);font-weight:600;font-size:18px;letter-spacing:-0.01em;display:block}
.lb__cap small{font-size:12.5px;color:rgba(255,255,255,0.65);letter-spacing:0.06em;text-transform:uppercase;font-weight:500}
.lb__close{position:absolute;top:-46px;right:0;width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,0.10);color:#fff;display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,0.2);transition:all .2s}
.lb__close:hover{background:#fff;color:var(--ink)}
.lb__nav{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,0.10);color:#fff;display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,0.2);transition:all .2s;z-index:2}
.lb__nav:hover{background:#fff;color:var(--ink)}
.lb__nav--prev{left:-66px}
.lb__nav--next{right:-66px}
.lb__nav svg{width:18px;height:18px}
@media (max-width:880px){.lb__nav--prev{left:8px}.lb__nav--next{right:8px}.lb__close{top:8px;right:8px}}

/* REVIEWS */
.reviews{padding:clamp(70px,9vw,120px) 0;background:var(--bg)}
.reviews__head{display:grid;grid-template-columns:1fr auto;gap:32px;align-items:end;margin-bottom:32px;border-bottom:1px solid var(--rule);padding-bottom:32px}
.reviews__head h2{font-size:clamp(30px,3.8vw,46px);letter-spacing:-0.015em;line-height:1.1}
.reviews__head h2 .accent{color:var(--brand)}
.reviews__head p{font-size:15px;color:var(--ink-dim);margin:12px 0 0;max-width:50ch;line-height:1.6}
.reviews__rating{display:flex;flex-direction:column;align-items:flex-end;gap:8px;background:var(--bg-2);border:1px solid var(--rule);border-radius:var(--radius);padding:18px 22px}
.reviews__rating-row{display:flex;align-items:center;gap:14px}
.reviews__rating .v{font-family:var(--display);font-weight:700;font-size:36px;letter-spacing:-0.02em;line-height:1;color:var(--ink)}
.reviews__rating .stars{display:flex;gap:2px;color:#FBBF24}
.reviews__rating .stars svg{width:18px;height:18px}
.reviews__rating small{font-size:12px;color:var(--ink-mute);letter-spacing:0.04em}
.reviews__rating small strong{color:var(--ink-2);font-weight:600}
.reviews__rating .g-logo{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--ink-dim);font-weight:600;padding-top:8px;margin-top:6px;border-top:1px solid var(--rule);width:100%;justify-content:flex-end}
.reviews__rating .g-logo svg{width:14px;height:14px}
.reviews__filters{display:flex;gap:8px;margin-bottom:28px;flex-wrap:wrap}
.reviews__filter{padding:8px 16px;border-radius:999px;border:1px solid var(--rule);background:#fff;font-size:13px;font-weight:600;color:var(--ink-2);cursor:pointer;transition:all .2s}
.reviews__filter:hover{border-color:var(--ink)}
.reviews__filter--active{background:var(--ink);color:#fff;border-color:var(--ink)}
.reviews__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.review{background:#fff;border:1px solid var(--rule);border-radius:var(--radius-lg);padding:26px;display:flex;flex-direction:column;gap:14px;transition:transform .25s,border-color .25s,box-shadow .25s}
.review:hover{transform:translateY(-2px);border-color:var(--rule-strong);box-shadow:var(--shadow-1)}
.review__top{display:flex;justify-content:space-between;align-items:center}
.review__stars{display:flex;gap:2px;color:#FBBF24}
.review__stars svg{width:15px;height:15px}
.review__g{display:inline-flex;align-items:center;gap:5px;font-size:11px;color:var(--ink-mute);font-weight:600;letter-spacing:0.04em}
.review__g svg{width:12px;height:12px}
.review__quote{font-family:var(--display);font-size:17px;line-height:1.5;color:var(--ink);margin:0;letter-spacing:-0.005em;font-weight:500;flex:1}
.review__person{display:flex;align-items:center;gap:12px;padding-top:14px;border-top:1px solid var(--rule)}
.review__photo{width:42px;height:42px;border-radius:50%;flex-shrink:0;display:grid;place-items:center;font-family:var(--display);font-weight:600;font-size:15px;color:#fff;letter-spacing:-0.02em;background:var(--ink)}
.review--client .review__photo{background:var(--brand)}
.review__meta{display:flex;flex-direction:column;line-height:1.2;min-width:0}
.review__meta strong{font-size:14px;color:var(--ink);font-weight:600;font-family:var(--display);letter-spacing:-0.005em}
.review__meta small{font-size:12px;color:var(--ink-mute);letter-spacing:0.02em;margin-top:2px}
.review__date{font-size:11px;color:var(--ink-faint);font-weight:500;letter-spacing:0.04em;margin-left:auto}
.review__tag{display:inline-flex;font-size:10px;letter-spacing:0.12em;text-transform:uppercase;font-weight:600;padding:3px 8px;border-radius:4px;background:var(--brand-soft);color:var(--brand);width:fit-content}
.review--client .review__tag{background:rgba(15,27,45,0.07);color:var(--ink)}
.reviews__cta{display:flex;justify-content:center;margin-top:32px}
@media (max-width:1080px){.reviews__grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.reviews__grid{grid-template-columns:1fr}.reviews__head{grid-template-columns:1fr}.reviews__rating{align-items:flex-start;width:100%}.reviews__rating .g-logo{justify-content:flex-start}}

/* FIND US / MAP */
.find{padding:clamp(60px,8vw,100px) 0;background:var(--bg-2);border-top:1px solid var(--rule)}
.find__grid{display:grid;grid-template-columns:1fr 1.3fr;gap:36px;align-items:stretch}
.find__info{display:flex;flex-direction:column;background:#fff;border:1px solid var(--rule);border-radius:var(--radius-lg);padding:36px 32px;gap:20px}
.find__info h2{font-size:clamp(28px,3.4vw,40px);letter-spacing:-0.015em;line-height:1.1;margin-bottom:6px}
.find__info p{font-size:15px;color:var(--ink-dim);margin:0;line-height:1.65}
.find__rows{display:flex;flex-direction:column;gap:14px;margin-top:6px}
.find__row{display:grid;grid-template-columns:36px 1fr;gap:14px;align-items:start;padding:14px 0;border-top:1px solid var(--rule)}
.find__row:first-of-type{border-top:0;padding-top:0}
.find__row-icon{width:36px;height:36px;border-radius:8px;background:var(--brand-soft);color:var(--brand);display:grid;place-items:center;flex-shrink:0}
.find__row-icon svg{width:16px;height:16px}
.find__row-body{display:flex;flex-direction:column;gap:2px}
.find__row-body strong{font-family:var(--display);font-size:15px;font-weight:600;color:var(--ink);letter-spacing:-0.005em}
.find__row-body span{font-size:13.5px;color:var(--ink-dim);line-height:1.5}
.find__row-body a{color:var(--ink-2);font-weight:500}
.find__row-body a:hover{color:var(--brand)}
.find__cta{display:flex;gap:10px;margin-top:auto;padding-top:18px;border-top:1px solid var(--rule);flex-wrap:wrap}
.find__map{position:relative;border:1px solid var(--rule);border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-3);min-height:440px}
.find__map iframe{width:100%;height:100%;border:0;display:block;min-height:440px;filter:saturate(0.85) contrast(0.96)}
.find__map-pin{position:absolute;top:18px;left:18px;z-index:2;background:#fff;border:1px solid var(--rule);border-radius:8px;padding:10px 14px;display:flex;align-items:center;gap:10px;box-shadow:var(--shadow-1);font-size:13px;color:var(--ink);font-weight:500}
.find__map-pin svg{width:14px;height:14px;color:var(--brand)}
@media (max-width:880px){.find__grid{grid-template-columns:1fr;gap:18px}.find__map{min-height:320px}.find__map iframe{min-height:320px}}

/* WHATSAPP WIDGET */
.wa{position:fixed;left:20px;bottom:20px;z-index:35;display:flex;flex-direction:column;align-items:flex-start;gap:10px}
.wa__btn{position:relative;display:inline-flex;align-items:center;gap:11px;padding:11px 20px 11px 12px;background:#25D366;color:#fff;border-radius:999px;font-family:var(--sans);font-size:13.5px;font-weight:600;letter-spacing:0;box-shadow:0 14px 30px -10px rgba(37,211,102,0.5),0 2px 6px rgba(0,0,0,0.10);transition:background .25s ease,transform .25s ease,box-shadow .25s ease;cursor:pointer;border:0;isolation:isolate}
.wa__btn:hover{background:#1FB856;transform:translateY(-2px);box-shadow:0 18px 36px -10px rgba(37,211,102,0.6),0 4px 10px rgba(0,0,0,0.14)}
.wa__btn:active{transform:translateY(0)}
.wa__btn::before{content:"";position:absolute;inset:0;border-radius:999px;box-shadow:0 0 0 0 rgba(37,211,102,0.55);animation:waRing 2.8s cubic-bezier(0.4,0,0.6,1) infinite;pointer-events:none;z-index:-1}
@keyframes waRing{0%{box-shadow:0 0 0 0 rgba(37,211,102,0.55)}70%{box-shadow:0 0 0 16px rgba(37,211,102,0)}100%{box-shadow:0 0 0 0 rgba(37,211,102,0)}}
.wa.open .wa__btn::before{animation:none}
.wa__btn-ico{width:30px;height:30px;border-radius:50%;background:#fff;color:#25D366;display:grid;place-items:center;flex-shrink:0}
.wa__btn:hover .wa__btn-ico{color:#1FB856}
.wa__btn-ico svg{width:18px;height:18px}
.wa__btn-lbl{line-height:1;white-space:nowrap}
.wa__btn-status{width:7px;height:7px;border-radius:50%;background:#fff;flex-shrink:0;margin-left:2px;animation:waStatusDot 2s ease-in-out infinite}
@keyframes waStatusDot{0%,100%{opacity:1}50%{opacity:0.5}}
.wa.open .wa__btn-lbl{display:none}
.wa.open .wa__btn-status{display:none}
.wa.open .wa__btn{padding:14px}
@media (max-width:420px){.wa__btn-lbl{display:none}.wa__btn{padding:14px}}
.wa__panel{position:absolute;left:0;bottom:64px;width:320px;background:#fff;border:1px solid var(--rule);border-radius:var(--radius-lg);box-shadow:var(--shadow-3);opacity:0;visibility:hidden;transform:translateY(10px) scale(0.96);transform-origin:left bottom;transition:all .25s ease;overflow:hidden}
.wa.open .wa__panel{opacity:1;visibility:visible;transform:translateY(0) scale(1)}
.wa__head{background:#075E54;color:#fff;padding:18px 18px 16px;display:flex;align-items:center;gap:12px;position:relative}
.wa__head-avatar{width:44px;height:44px;border-radius:50%;background:var(--brand);color:#fff;display:grid;place-items:center;font-family:var(--display);font-weight:700;font-size:18px;letter-spacing:-0.02em;flex-shrink:0}
.wa__head-name{display:flex;flex-direction:column;line-height:1.2;flex:1;min-width:0}
.wa__head-name strong{font-family:var(--display);font-weight:600;font-size:15px;letter-spacing:-0.005em}
.wa__head-name small{font-size:11.5px;color:rgba(255,255,255,0.75);display:flex;align-items:center;gap:6px;margin-top:2px}
.wa__head-name small::before{content:"";width:7px;height:7px;border-radius:50%;background:#3FE08C}
.wa__head-close{background:rgba(255,255,255,0.15);color:#fff;width:28px;height:28px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}
.wa__head-close svg{width:12px;height:12px}
.wa__body{padding:18px;background:#ECE5DD url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='60' height='60'><circle cx='30' cy='30' r='1' fill='%23000' opacity='0.05'/></svg>")}
.wa__msg{background:#fff;border-radius:0 10px 10px 10px;padding:12px 14px;font-size:13.5px;color:var(--ink-2);line-height:1.5;box-shadow:0 1px 2px rgba(0,0,0,0.08);max-width:90%}
.wa__msg small{display:block;font-size:10.5px;color:var(--ink-mute);margin-top:6px;text-align:right}
.wa__foot{padding:12px 14px;background:#F0F2F5;display:flex;gap:8px;border-top:1px solid rgba(0,0,0,0.04)}
.wa__quick{flex:1;padding:9px 12px;background:#fff;border:1px solid #d1d7db;border-radius:18px;font-size:13px;color:var(--ink-mute);font-weight:500}
.wa__send{background:#25D366;color:#fff;padding:10px 18px;border-radius:18px;font-size:13px;font-weight:600;display:inline-flex;align-items:center;gap:6px}
.wa__send:hover{background:#1ebe5d}
.wa__send svg{width:13px;height:13px}
@media (max-width:560px){.wa{left:12px;bottom:12px}.wa__panel{width:calc(100vw - 24px);max-width:340px}}
@media (max-width:560px){.dock{bottom:88px}}

/* INNER PAGE: CONTACT FORM */
.contact-section{padding:clamp(60px,8vw,100px) 0}
.contact-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:48px;align-items:start}
.contact-form{background:#fff;border:1px solid var(--rule);border-radius:var(--radius-lg);padding:clamp(28px,4vw,44px);box-shadow:var(--shadow-1)}
.contact-form h2{font-size:clamp(28px,3.4vw,40px);letter-spacing:-0.015em;line-height:1.1;margin-bottom:10px}
.contact-form p{font-size:15px;color:var(--ink-dim);margin:0 0 28px;line-height:1.6}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.form-row--full{grid-template-columns:1fr}
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-size:12.5px;font-weight:600;color:var(--ink-2);letter-spacing:0.04em}
.field label .req{color:var(--brand)}
.field input,.field select,.field textarea{background:var(--bg-2);border:1px solid var(--rule);border-radius:8px;padding:12px 14px;font-size:14.5px;color:var(--ink);transition:border-color .2s,background .2s;outline:0;font-family:var(--sans)}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--brand);background:#fff}
.field textarea{resize:vertical;min-height:120px}
.field-checkbox{display:flex;align-items:flex-start;gap:10px;font-size:13.5px;color:var(--ink-dim);margin:8px 0 18px;line-height:1.5;cursor:pointer}
.field-checkbox input{margin-top:3px;flex-shrink:0;accent-color:var(--brand)}
.contact-form button[type=submit]{width:100%;margin-top:6px;padding:16px}
.contact-aside{display:flex;flex-direction:column;gap:14px}
.contact-aside h3{font-size:18px;letter-spacing:-0.005em;margin-bottom:14px}
.contact-card{background:var(--bg-2);border:1px solid var(--rule);border-radius:var(--radius);padding:22px 24px}
.contact-card .lbl{font-size:11.5px;letter-spacing:0.1em;text-transform:uppercase;color:var(--brand);font-weight:600;margin-bottom:6px}
.contact-card h3{font-size:20px;letter-spacing:-0.005em;margin:0 0 10px}
.contact-card p{font-size:14px;color:var(--ink-dim);line-height:1.6;margin:0}
.contact-card a{color:var(--ink-2);font-weight:500}
.contact-card a:hover{color:var(--brand)}
.contact-card ul{list-style:none;padding:0;margin:8px 0 0 0;display:flex;flex-direction:column;gap:8px;font-size:14px;color:var(--ink-dim)}
@media (max-width:880px){.contact-grid{grid-template-columns:1fr;gap:24px}.form-row{grid-template-columns:1fr}}

/* INNER PAGE: PORTAL LOGIN */
.portal-login{padding:clamp(60px,8vw,100px) 0}
.portal-login__grid{display:grid;grid-template-columns:1fr 1.1fr;gap:48px;align-items:start}
.portal-login__form{background:#fff;border:1px solid var(--rule);border-radius:var(--radius-lg);padding:clamp(28px,4vw,44px);box-shadow:var(--shadow-1)}
.portal-login__form h2{font-size:clamp(26px,3vw,34px);letter-spacing:-0.015em;margin-bottom:8px}
.portal-login__form p{font-size:14.5px;color:var(--ink-dim);margin:0 0 26px;line-height:1.6}
.portal-login__form .field{margin-bottom:14px}
.portal-login__form button[type=submit]{width:100%;margin-top:8px;padding:14px}
.portal-login__divider{display:flex;align-items:center;gap:12px;margin:20px 0;font-size:12px;color:var(--ink-mute);letter-spacing:0.04em;text-transform:uppercase}
.portal-login__divider::before,.portal-login__divider::after{content:"";flex:1;height:1px;background:var(--rule)}
.portal-login__sso{display:flex;flex-direction:column;gap:10px}
.portal-login__sso button{display:flex;align-items:center;justify-content:center;gap:10px;padding:11px;border:1px solid var(--rule);border-radius:8px;font-size:13.5px;font-weight:600;color:var(--ink-2);background:#fff;transition:border-color .2s,background .2s;cursor:pointer}
.portal-login__sso button:hover{border-color:var(--ink);background:var(--bg-2)}
.portal-login__sso svg{width:16px;height:16px}
.portal-login__benefits{background:var(--ink);color:#fff;border-radius:var(--radius-lg);padding:clamp(28px,4vw,44px);position:relative;overflow:hidden}
.portal-login__benefits::before{content:"";position:absolute;top:-30%;right:-15%;width:340px;height:340px;border-radius:50%;background:radial-gradient(circle,rgba(var(--brand-rgb),0.18) 0%,transparent 60%);pointer-events:none}
.portal-login__benefits .kicker{color:var(--brand-2)}
.portal-login__benefits h3{font-size:clamp(24px,3vw,32px);color:#fff;letter-spacing:-0.015em;line-height:1.1;margin-bottom:14px;position:relative}
.portal-login__benefits > p{font-size:15px;color:rgba(255,255,255,0.78);margin:0 0 26px;line-height:1.65;position:relative}
.portal-login__benefits ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:14px;position:relative}
.portal-login__benefits li{display:flex;align-items:flex-start;gap:12px;font-size:14.5px;color:rgba(255,255,255,0.92);line-height:1.5}
.portal-login__benefits li::before{content:"";width:20px;height:20px;border-radius:50%;background:var(--brand);flex-shrink:0;margin-top:1px;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>");background-size:12px;background-position:center;background-repeat:no-repeat}
@media (max-width:880px){.portal-login__grid{grid-template-columns:1fr;gap:24px}}

/* PROCESS STEPS (used on service pages) */
.process{padding:clamp(60px,8vw,100px) 0;background:var(--bg-2);border-top:1px solid var(--rule);border-bottom:1px solid var(--rule)}
.process__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.process__step{background:#fff;border:1px solid var(--rule);border-radius:var(--radius-lg);padding:30px 26px;display:flex;flex-direction:column;gap:12px;transition:transform .25s,border-color .25s,box-shadow .25s;position:relative}
.process__step:hover{transform:translateY(-3px);border-color:var(--rule-strong);box-shadow:var(--shadow-2)}
.process__num{font-family:var(--display);font-weight:700;font-size:44px;color:var(--brand);letter-spacing:-0.03em;line-height:1}
.process__step h3{font-size:20px;letter-spacing:-0.01em;margin-bottom:4px}
.process__step p{font-size:14px;color:var(--ink-dim);line-height:1.6;margin:0}
@media (max-width:880px){.process__grid{grid-template-columns:1fr}}

/* TEAM (about page) */
.team{padding:clamp(60px,8vw,100px) 0}
.team__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;max-width:960px;margin:0 auto}
.team__member{background:#fff;border:1px solid var(--rule);border-radius:var(--radius-lg);padding:28px 22px;display:flex;flex-direction:column;gap:10px;text-align:center;align-items:center;transition:transform .25s,border-color .25s,box-shadow .25s}
.team__member:hover{transform:translateY(-3px);border-color:var(--rule-strong);box-shadow:var(--shadow-1)}
.team__photo{width:88px;height:88px;border-radius:50%;background:var(--ink);color:#fff;display:grid;place-items:center;font-family:var(--display);font-weight:600;font-size:32px;letter-spacing:-0.02em}
.team__member:nth-child(2) .team__photo{background:var(--brand)}
.team__member:nth-child(3) .team__photo{background:var(--ink-2)}
.team__member h3{font-size:19px;letter-spacing:-0.005em;margin:6px 0 2px}
.team__member small{font-size:12.5px;color:var(--ink-mute);letter-spacing:0.04em;text-transform:uppercase;font-weight:500}
.team__member p{font-size:13.5px;color:var(--ink-dim);line-height:1.55;margin:8px 0 0}
@media (max-width:880px){.team__grid{grid-template-columns:repeat(2,1fr);max-width:640px}}
@media (max-width:520px){.team__grid{grid-template-columns:1fr;max-width:380px}}

/* FAQ */
.faq{padding:clamp(60px,8vw,100px) 0}
.faq__list{max-width:880px;margin:0 auto;border-top:1px solid var(--rule)}
.faq__item{border-bottom:1px solid var(--rule)}
.faq__q{width:100%;display:flex;justify-content:space-between;align-items:center;padding:22px 0;font-family:var(--display);font-weight:600;font-size:18px;letter-spacing:-0.005em;color:var(--ink);text-align:left;gap:24px}
.faq__q .plus{width:28px;height:28px;border-radius:50%;border:1px solid var(--rule);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .25s,background .25s,border-color .25s}
.faq__q .plus::before,.faq__q .plus::after{content:"";position:absolute;width:12px;height:1.5px;background:var(--ink);transition:transform .25s}
.faq__q .plus{position:relative}
.faq__q .plus::after{transform:rotate(90deg)}
.faq__item.open .faq__q .plus{background:var(--brand);color:#fff;border-color:var(--brand)}
.faq__item.open .faq__q .plus::before,.faq__item.open .faq__q .plus::after{background:#fff}
.faq__item.open .faq__q .plus::after{transform:rotate(0)}
.faq__a{font-size:15px;color:var(--ink-dim);line-height:1.7;max-height:0;overflow:hidden;transition:max-height .35s ease,padding .35s ease}
.faq__item.open .faq__a{max-height:320px;padding:0 0 22px}

/* REDUCED MOTION */
@media (prefers-reduced-motion:reduce){*{animation:none !important;transition:none !important}.reveal{opacity:1;transform:none}}
