/* ============================================================
   TGV-CH — Main stylesheet
   Design system: Concept A · Serif Editorial
   ============================================================ */

:root{
  --ink-900:#0E1A35;
  --ink-700:#1F2A4A;
  --ink-500:#3A4669;
  --brass-500:#B89058;
  --brass-300:#D9BC8C;
  --paper:#F6F2EB;
  --paper-soft:#FBF8F2;
  --slate-700:#3D4147;
  --slate-400:#7A7D82;
  --line:#E5DFD2;
  --success:#3F7A4D;
  --warning:#B68A3E;
  --alert:#9A4A3C;
  --danger:#7C2D2D;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--paper);color:var(--slate-700);font-family:'Inter',system-ui,sans-serif;font-size:16px;line-height:1.55;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body.nav-open{overflow:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block;height:auto}

.serif{font-family:'Source Serif 4',Georgia,serif;font-optical-sizing:auto}
.mono{font-family:'JetBrains Mono',monospace}
.container{max-width:1240px;margin:0 auto;padding:0 32px}
.container-narrow{max-width:920px;margin:0 auto;padding:0 32px}
.micro{font-size:12px;letter-spacing:.14em;text-transform:uppercase;font-weight:600;color:var(--slate-400)}

/* ============ NAV ============ */
nav.top{position:sticky;top:0;z-index:9999;background:rgba(246,242,235,.86);backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid var(--line)}
nav.top .row{display:flex;align-items:center;gap:24px;height:76px}
.brand{display:flex;align-items:center;gap:12px;margin-right:auto}
.brand-logo{height:42px;width:auto;display:block}

/* Icon shortcuts (home, calculator) — bar variant on mobile, menu variant on desktop */
.nav-icon{display:flex;align-items:center;justify-content:center;padding:0;width:42px;height:42px;border:0;border-radius:6px;color:var(--ink-700);background:transparent;transition:color .2s,transform .2s;flex-shrink:0}
.nav-icon:hover{color:var(--brass-500);transform:translateY(-1px)}
.nav-icon svg{width:22px;height:22px;display:block}
.nav-home-bar,.nav-calc-bar{display:none}    /* hidden on desktop */
.nav-home-menu,.nav-calc-menu{display:flex}    /* visible on desktop */

nav.top .nav-panel{display:flex;align-items:center;gap:32px}
nav.top .nav-panel > ul{display:flex;align-items:center;gap:32px;list-style:none;margin:0;padding:0}
nav.top .nav-panel > ul > li{position:relative}
nav.top ul a{font-size:14px;font-weight:500;color:var(--ink-700)}
nav.top ul a:hover,nav.top ul a.active,nav.top .current-menu-item > a,nav.top .current-menu-ancestor > a{color:var(--brass-500)}
nav.top .nav-toggle{display:none}
.dropdown > a::after,.menu-item-has-children > a::after{content:" ▾";font-size:9px;color:var(--slate-400)}
nav.top ul.dropdown-menu,nav.top .sub-menu{display:none;position:absolute;top:100%;left:-20px;background:var(--paper-soft);border:1px solid var(--line);border-radius:6px;min-width:230px;padding:8px;box-shadow:0 20px 40px -15px rgba(14,26,53,.15);margin-top:14px;flex-direction:column;gap:0;z-index:60}
/* Invisible hover bridge — closes the 14px gap between parent menu item and dropdown so cursor can travel into submenu without losing :hover */
nav.top ul.dropdown-menu::before,nav.top .sub-menu::before{content:"";position:absolute;top:-14px;left:0;right:0;height:14px}
nav.top ul.dropdown-menu li,nav.top .sub-menu li{list-style:none;position:static}
nav.top ul.dropdown-menu a,nav.top .sub-menu a{display:block;padding:12px 16px;border-radius:4px;font-size:14px;color:var(--ink-700)}
nav.top ul.dropdown-menu a:hover,nav.top .sub-menu a:hover{background:rgba(184,144,88,.08);color:var(--ink-900)}
nav.top .dropdown:hover ul.dropdown-menu,nav.top .menu-item-has-children:hover .sub-menu{display:flex}
.nav-cta{background:var(--ink-900);color:var(--paper);padding:11px 20px;border-radius:4px;font-size:13.5px;font-weight:600;transition:background .2s}
.nav-cta:hover{background:var(--brass-500);color:var(--ink-900)}

/* ============ HERO ============ */
.hero{padding:80px 0 0;position:relative;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1fr 1.15fr;gap:48px;align-items:end}
.hero-copy{padding-bottom:100px}
.hero h1{font-family:'Source Serif 4',serif;font-weight:400;font-size:clamp(48px,6.2vw,80px);line-height:1.02;letter-spacing:-.02em;color:var(--ink-900)}
.hero h1 em{font-style:italic;color:var(--brass-500);font-weight:400}
.hero .lede{font-size:19px;line-height:1.6;color:var(--ink-500);max-width:560px;margin-top:28px}
.hero .cta-row{display:flex;gap:16px;margin-top:40px;align-items:center;flex-wrap:wrap}
.btn-primary{background:var(--brass-500);color:var(--ink-900);padding:16px 28px;border-radius:4px;font-weight:600;font-size:15px;border:0;cursor:pointer;transition:all .2s;display:inline-block;font-family:inherit}
.btn-primary:hover{background:var(--ink-900);color:var(--paper)}
.btn-secondary{border:1px solid var(--ink-900);color:var(--ink-900);padding:15px 26px;border-radius:4px;font-weight:600;font-size:15px;transition:all .2s;display:inline-block;background:transparent;cursor:pointer;font-family:inherit}
.btn-secondary:hover{background:var(--ink-900);color:var(--paper)}
.btn-ghost{color:var(--ink-900);font-weight:600;font-size:14px;border-bottom:1.5px solid var(--brass-500);padding-bottom:2px}

.hero-visual{position:relative;align-self:end;min-height:740px;display:flex;align-items:flex-end;justify-content:center}
.hero-visual::before{content:"";position:absolute;left:50%;bottom:6px;width:68%;height:20px;background:radial-gradient(ellipse at center,rgba(14,26,53,.22) 0%,transparent 70%);transform:translateX(-50%);filter:blur(6px);z-index:0}
.hero-visual picture{display:contents}
.hero-visual img{position:relative;z-index:1;display:block;width:auto;max-width:108%;height:100%;max-height:780px;object-fit:contain;object-position:center bottom}
.hero-badge{position:absolute;right:0;bottom:64px;z-index:2;background:var(--paper-soft);border:1px solid var(--line);padding:16px 20px;border-radius:4px;max-width:240px;box-shadow:0 18px 36px -18px rgba(14,26,53,.18)}
.hero-badge .micro{color:var(--brass-500);margin-bottom:4px}
.hero-badge strong{font-family:'Source Serif 4',serif;font-weight:600;font-size:16px;color:var(--ink-900);display:block;line-height:1.25}
.hero-badge span{font-size:12.5px;color:var(--slate-700);display:block;margin-top:2px}

/* ============ RESURSE / DOCUMENTE (homepage) ============ */
.resurse-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.resurse-card{display:flex;gap:18px;background:var(--paper);border:1px solid var(--line);border-radius:6px;padding:28px;transition:transform .25s,box-shadow .25s,border-color .25s;position:relative;overflow:hidden}
.resurse-card:hover{transform:translateY(-3px);box-shadow:0 20px 40px -18px rgba(14,26,53,.14);border-color:var(--brass-500)}
.rc-icon{width:48px;height:56px;background:var(--paper-soft);border:1.5px solid var(--alert);border-radius:4px;display:grid;place-items:center;flex-shrink:0}
.rc-icon span{background:var(--alert);color:white;padding:2px 6px;border-radius:2px;font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:700;letter-spacing:.02em}
.rc-body{min-width:0}
.rc-tag{font-family:'JetBrains Mono',monospace;font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--brass-500);font-weight:600;margin-bottom:6px}
.rc-title{font-family:'Source Serif 4',serif;font-weight:600;font-size:17px;color:var(--ink-900);line-height:1.3;margin-bottom:6px}
.rc-desc{font-size:13.5px;color:var(--ink-500);line-height:1.5;margin:0}

/* ============ STATS ============ */
.stats{padding:60px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--paper-soft)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:32px}
.stat .num{font-family:'Source Serif 4',serif;font-weight:400;font-size:64px;line-height:1;color:var(--ink-900);letter-spacing:-.02em}
.stat .num .sup{font-size:24px;color:var(--brass-500);vertical-align:top;margin-left:2px}
.stat .label{margin-top:12px;font-size:13px;font-weight:600;color:var(--slate-400);letter-spacing:.08em;text-transform:uppercase}

/* ============ SECTION HEADER ============ */
section.section{padding:120px 0}
.section-head{display:grid;grid-template-columns:1fr 2fr;gap:40px;margin-bottom:60px;align-items:end}
.section-head .eyebrow{color:var(--brass-500);margin-bottom:18px}
.section-head h2{font-family:'Source Serif 4',serif;font-weight:400;font-size:clamp(36px,4.5vw,56px);line-height:1.06;letter-spacing:-.015em;color:var(--ink-900)}
.section-head h2 em{font-style:italic;color:var(--brass-500)}
.section-head .lede{font-size:17px;color:var(--ink-500);max-width:520px;line-height:1.65}

/* ============ SERVICES ============ */
.services{background:var(--paper)}
.svc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.svc{background:var(--paper-soft);border:1px solid var(--line);border-radius:6px;padding:42px 36px;transition:all .3s;cursor:pointer;position:relative;overflow:hidden;display:block}
.svc::before{content:"";position:absolute;top:0;left:0;width:3px;height:0;background:var(--brass-500);transition:height .3s}
.svc:hover{transform:translateY(-3px);box-shadow:0 20px 40px -15px rgba(14,26,53,.15)}
.svc:hover::before{height:100%}
.svc .num{font-family:'JetBrains Mono',monospace;color:var(--brass-500);font-size:13px;font-weight:500;margin-bottom:24px}
.svc h3{font-family:'Source Serif 4',serif;font-weight:600;font-size:26px;color:var(--ink-900);margin-bottom:14px;line-height:1.2}
.svc p{font-size:15px;color:var(--ink-500);line-height:1.6;margin-bottom:20px}
.svc ul{list-style:none;display:flex;flex-direction:column;gap:8px;margin-bottom:24px}
.svc ul li{font-size:14px;color:var(--slate-700);padding-left:18px;position:relative}
.svc ul li::before{content:"—";position:absolute;left:0;color:var(--brass-500);font-weight:600}
.svc .more{color:var(--ink-900);font-weight:600;font-size:14px;border-bottom:1.5px solid var(--brass-500);padding-bottom:2px;display:inline-block}

/* ============ CALCULATOR BAND ============ */
.calc-band{background:var(--ink-900);color:var(--paper);padding:100px 0;position:relative;overflow:hidden}
.calc-band::before{content:"";position:absolute;top:-150px;right:-150px;width:500px;height:500px;background:radial-gradient(circle,rgba(184,144,88,.15),transparent 70%)}
.calc-grid{display:grid;grid-template-columns:2fr 1.2fr;gap:80px;align-items:center;position:relative}
.calc-band .eyebrow{color:var(--brass-300)}
.calc-band h2{font-family:'Source Serif 4',serif;font-weight:400;font-size:clamp(36px,4.5vw,52px);line-height:1.08;letter-spacing:-.015em;color:var(--paper);margin:18px 0 24px}
.calc-band h2 em{font-style:italic;color:var(--brass-300)}
.calc-band p{font-size:17px;color:rgba(246,242,235,.78);max-width:520px;line-height:1.65;margin-bottom:36px}
.calc-steps{list-style:none;display:flex;gap:24px;margin-bottom:40px;flex-wrap:wrap}
.calc-steps li{font-size:13px;font-family:'JetBrains Mono',monospace;color:var(--brass-300)}
.calc-mockup{background:rgba(246,242,235,.04);border:1px solid rgba(217,188,140,.2);border-radius:6px;padding:28px}
.calc-mockup .micro{color:var(--brass-300);margin-bottom:18px}
.calc-q{font-family:'Source Serif 4',serif;font-size:22px;font-weight:600;color:var(--paper);margin-bottom:24px;line-height:1.25}
.calc-progress{display:flex;gap:6px;margin-bottom:24px}
.calc-progress span{flex:1;height:4px;border-radius:2px;background:rgba(246,242,235,.12)}
.calc-progress span.active{background:var(--brass-500)}
.calc-options{display:flex;flex-direction:column;gap:10px}
.calc-options label{display:flex;align-items:center;gap:12px;padding:14px 16px;border:1px solid rgba(246,242,235,.15);border-radius:4px;cursor:pointer;font-size:14px;transition:all .2s;color:rgba(246,242,235,.85)}
.calc-options label:hover{border-color:var(--brass-500);background:rgba(184,144,88,.06)}
.calc-options label.checked{border-color:var(--brass-500);background:rgba(184,144,88,.1)}
.calc-options .radio{width:14px;height:14px;border-radius:50%;border:1.5px solid var(--brass-300);position:relative;flex-shrink:0}
.calc-options label.checked .radio::after{content:"";position:absolute;inset:2.5px;border-radius:50%;background:var(--brass-500)}

/* ============ PRACTICIAN ============ */
.practician{background:var(--paper-soft);padding:120px 0;border-top:1px solid var(--line)}
.prac-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:80px;align-items:center}
.prac-portrait{aspect-ratio:4/5;border-radius:6px;overflow:hidden;box-shadow:0 30px 60px -25px rgba(14,26,53,.28);position:relative}
.prac-portrait img{width:100%;height:100%;object-fit:cover;object-position:center 30%}
.prac-portrait::after{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(180deg,transparent 55%,rgba(14,26,53,.55) 100%)}
.prac-portrait .tag{position:absolute;left:20px;bottom:20px;background:var(--paper);padding:10px 14px;border-radius:4px}
.prac-portrait .tag .micro{color:var(--brass-500);margin-bottom:2px}
.prac-portrait .tag strong{font-family:'Source Serif 4',serif;font-size:15px;color:var(--ink-900);font-weight:600}
.prac h3{font-family:'Source Serif 4',serif;font-weight:400;font-size:clamp(36px,4vw,52px);line-height:1.08;letter-spacing:-.015em;color:var(--ink-900);margin:20px 0 28px}
.prac h3 em{font-style:italic;color:var(--brass-500)}
.prac blockquote{border-left:3px solid var(--brass-500);padding:8px 0 8px 24px;font-family:'Source Serif 4',serif;font-style:italic;font-size:21px;color:var(--ink-700);line-height:1.45;margin:32px 0}
.prac .meta{display:flex;gap:32px;margin-top:32px;flex-wrap:wrap}
.prac .meta div .micro{color:var(--slate-400);margin-bottom:4px}
.prac .meta div strong{font-family:'Source Serif 4',serif;font-size:18px;color:var(--ink-900);font-weight:600}

/* ============ PROCEDURA ============ */
.procedura{background:var(--paper)}
.proc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.proc-step{padding:48px 32px;border-right:1px solid var(--line);position:relative}
.proc-step:last-child{border-right:0}
.proc-step .num{font-family:'Source Serif 4',serif;font-size:48px;font-weight:400;color:var(--brass-500);letter-spacing:-.02em;margin-bottom:16px;line-height:1}
.proc-step h4{font-family:'Source Serif 4',serif;font-size:22px;font-weight:600;color:var(--ink-900);margin-bottom:12px}
.proc-step p{font-size:14.5px;line-height:1.6;color:var(--ink-500)}

/* ============ JURNAL ============ */
.jurnal{background:var(--paper-soft);border-top:1px solid var(--line)}
.jurnal-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.jurnal-card{cursor:pointer;display:block}
.jurnal-card .thumb{aspect-ratio:4/3;background:linear-gradient(135deg,var(--ink-700),var(--ink-900));border-radius:4px;margin-bottom:20px;position:relative;overflow:hidden}
.jurnal-card .thumb::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 70%,rgba(184,144,88,.25),transparent 60%)}
.jurnal-card .thumb img{width:100%;height:100%;object-fit:cover;position:relative;z-index:1}
.jurnal-card .thumb .label{position:absolute;left:18px;top:18px;color:var(--brass-300);font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.1em;z-index:2}
.jurnal-card .date{font-family:'JetBrains Mono',monospace;color:var(--slate-400);font-size:12px;margin-bottom:8px;letter-spacing:.06em}
.jurnal-card h4{font-family:'Source Serif 4',serif;font-size:22px;font-weight:600;color:var(--ink-900);line-height:1.25;margin-bottom:12px}
.jurnal-card p{font-size:14.5px;color:var(--ink-500);line-height:1.55}
.jurnal-card:hover h4{color:var(--brass-500)}

/* ============ CTA FINAL ============ */
.cta-final{padding:140px 0;background:var(--paper);text-align:center}
.cta-final .eyebrow{color:var(--brass-500);margin-bottom:24px}
.cta-final h2{font-family:'Source Serif 4',serif;font-weight:400;font-size:clamp(40px,5.5vw,68px);line-height:1.05;letter-spacing:-.02em;color:var(--ink-900);max-width:900px;margin:0 auto}
.cta-final h2 em{font-style:italic;color:var(--brass-500)}
.cta-final p{font-size:18px;color:var(--ink-500);max-width:600px;margin:28px auto 40px;line-height:1.6}
.cta-final .cta-row{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* ============ FOOTER ============ */
footer.site-footer{background:var(--ink-900);color:var(--paper);padding:80px 0 32px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:48px;margin-bottom:60px}
footer.site-footer .brand-logo{filter:brightness(0) invert(1);height:42px}
footer.site-footer .foot-col h5{font-family:'Inter';font-weight:600;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--brass-300);margin-bottom:20px}
footer.site-footer .foot-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
footer.site-footer .foot-col li a{font-size:14px;color:rgba(246,242,235,.78);transition:color .2s}
footer.site-footer .foot-col li a:hover{color:var(--brass-300)}
.foot-about{max-width:340px;font-size:14px;color:rgba(246,242,235,.7);line-height:1.6;margin:20px 0 24px}
.foot-contact{font-size:14px;color:rgba(246,242,235,.85);line-height:1.7}
.foot-contact a{color:inherit;transition:color .2s}
.foot-contact a:hover strong{color:var(--brass-300)}
.foot-contact strong{color:var(--paper);display:block;font-weight:600;margin-top:6px}
.foot-office-label{display:block;font-family:'Inter';font-weight:600;font-size:10.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--brass-300);margin-bottom:6px}
.foot-contact-branch{margin-top:22px;padding-top:20px;border-top:1px solid rgba(246,242,235,.12)}

/* Footer newsletter strip */
.foot-nl{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;padding:32px 36px;background:rgba(184,144,88,.08);border:1px solid rgba(184,144,88,.25);border-radius:8px;margin-bottom:48px}
.foot-nl h4{font-family:'Source Serif 4',serif;font-weight:400;font-size:24px;color:var(--paper);line-height:1.2;margin-bottom:6px}
.foot-nl p{font-size:13.5px;color:rgba(246,242,235,.7);line-height:1.5;margin:0}
.foot-nl-form{display:flex;gap:8px;align-items:stretch;flex-wrap:wrap;position:relative}
.foot-nl-form input[type=email]{flex:1;min-width:220px;padding:13px 16px;border:1px solid rgba(246,242,235,.18);background:rgba(14,26,53,.4);color:var(--paper);font-family:inherit;font-size:15px;border-radius:4px;transition:border-color .2s,background .2s}
.foot-nl-form input[type=email]::placeholder{color:rgba(246,242,235,.4)}
.foot-nl-form input[type=email]:focus{outline:none;border-color:var(--brass-300);background:rgba(14,26,53,.6)}
.foot-nl-form button{background:var(--brass-500);color:var(--ink-900);border:0;padding:13px 22px;border-radius:4px;font-family:'Inter',sans-serif;font-weight:600;font-size:14px;cursor:pointer;transition:background .2s,transform .15s;white-space:nowrap}
.foot-nl-form button:hover:not(:disabled){background:var(--brass-300);transform:translateY(-1px)}
.foot-nl-form button:disabled{opacity:.6;cursor:wait}
.foot-nl-status{flex-basis:100%;font-size:12.5px;margin-top:6px}
.foot-nl-status.ok{color:var(--brass-300)}
.foot-nl-status.err{color:#FFB1A8}
@media (max-width:880px){.foot-nl{grid-template-columns:1fr;padding:24px 22px;gap:18px;margin-bottom:36px}.foot-nl h4{font-size:20px}}

/* Sticky mobile CTA bar */
#mobile-sticky-cta{display:none}
@media (max-width:880px){
  #mobile-sticky-cta{position:fixed;left:0;right:0;bottom:0;z-index:9990;display:flex;gap:0;background:var(--ink-900);box-shadow:0 -12px 30px -10px rgba(14,26,53,.35);transform:translateY(110%);transition:transform .35s cubic-bezier(.2,.85,.3,1);padding:env(safe-area-inset-bottom,0) 0 0 0}
  #mobile-sticky-cta.visible{transform:translateY(0)}
  #mobile-sticky-cta .msc-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 10px;font-family:'Inter',sans-serif;font-weight:600;font-size:14px;color:var(--paper);text-decoration:none;transition:background .2s}
  #mobile-sticky-cta .msc-btn svg{width:18px;height:18px;flex-shrink:0}
  #mobile-sticky-cta .msc-call{background:var(--ink-900);color:var(--paper);border-right:1px solid rgba(246,242,235,.1)}
  #mobile-sticky-cta .msc-call:hover,#mobile-sticky-cta .msc-call:active{background:#1a2748}
  #mobile-sticky-cta .msc-eval{background:var(--brass-500);color:var(--ink-900)}
  #mobile-sticky-cta .msc-eval:hover,#mobile-sticky-cta .msc-eval:active{background:var(--brass-300)}
  /* Push footer & back-to-top up so they don't get covered */
  body{padding-bottom:54px}
  #back-to-top{bottom:70px}
}

/* Social media links */
.social-links{display:flex;gap:10px;margin-top:24px}
.social-links a{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;border:1px solid rgba(246,242,235,.2);color:rgba(246,242,235,.78);transition:transform .2s,color .2s,border-color .2s,background .2s}
.social-links a:hover{border-color:var(--brass-500);color:var(--brass-300);transform:translateY(-2px)}
.social-links a svg{width:17px;height:17px;display:block}
.social-links.social-light{margin-top:8px}
.social-links.social-light a{border-color:var(--line);color:var(--ink-700)}
.social-links.social-light a:hover{border-color:var(--brass-500);color:var(--brass-500);background:rgba(184,144,88,.07)}
.info-row .social-links{margin-top:6px}
.foot-legal{border-top:1px solid rgba(246,242,235,.1);padding-top:32px;display:flex;flex-direction:column;gap:24px}
.foot-legal-top{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:20px}
.foot-badges{display:flex;gap:14px;align-items:center;flex-wrap:wrap}
.foot-badges a{display:block;transition:opacity .2s,transform .2s}
.foot-badges a:hover{opacity:.85;transform:translateY(-2px)}
.foot-badges img{height:38px;width:auto;display:block}
.foot-legal-bottom{display:flex;justify-content:space-between;align-items:center;border-top:1px solid rgba(246,242,235,.08);padding-top:20px;flex-wrap:wrap;gap:16px}
.foot-legal-bottom p{font-size:12px;color:rgba(246,242,235,.55);line-height:1.5}
.dev-by{display:flex;align-items:center;gap:12px;font-size:11px;color:rgba(246,242,235,.5);font-family:'JetBrains Mono',monospace;letter-spacing:.04em;transition:color .2s}
.dev-by img{height:24px;width:auto;opacity:.7;transition:opacity .2s}
.dev-by:hover{color:rgba(246,242,235,.85)}
.dev-by:hover img{opacity:1}

/* ============ SUB-HERO (subpage hero compact) ============ */
.sub-hero{background:var(--paper-soft);border-bottom:1px solid var(--line);padding:64px 0 56px}
.sub-hero .breadcrumb{font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--slate-400);letter-spacing:.04em;margin-bottom:24px}
.sub-hero .breadcrumb a:hover{color:var(--brass-500)}
.sub-hero .breadcrumb .sep{margin:0 8px;color:var(--line)}
.sub-hero .breadcrumb .current{color:var(--ink-900)}
.sub-hero h1{font-family:'Source Serif 4',serif;font-weight:400;font-size:clamp(44px,5.5vw,72px);line-height:1.02;letter-spacing:-.02em;color:var(--ink-900);max-width:920px}
.sub-hero h1 em{font-style:italic;color:var(--brass-500)}
.sub-hero .lede{font-size:19px;line-height:1.6;color:var(--ink-500);max-width:720px;margin-top:24px}
.sub-hero .meta{display:flex;gap:24px;margin-top:24px;flex-wrap:wrap;font-family:'JetBrains Mono',monospace;font-size:12.5px;color:var(--slate-400);letter-spacing:.04em}
.sub-hero .meta strong{color:var(--brass-500);font-weight:500}

/* ============ DOC LAYOUT (2-col with sticky sidebar) ============ */
.doc-wrap{padding:80px 0 120px}
.doc-grid{display:grid;grid-template-columns:1fr 320px;gap:80px;align-items:start}
.doc-grid.narrow-side{grid-template-columns:1fr 280px}
article.doc section{margin-bottom:80px;scroll-margin-top:100px}
article.doc h2{font-family:'Source Serif 4',serif;font-weight:400;font-size:clamp(32px,3.5vw,44px);line-height:1.1;letter-spacing:-.015em;color:var(--ink-900);margin-bottom:24px;position:relative;padding-top:8px;display:flex;gap:18px;align-items:baseline}
article.doc h2 em{font-style:italic;color:var(--brass-500)}
article.doc h2 .n{font-family:'JetBrains Mono',monospace;font-size:14px;font-weight:500;color:var(--brass-500);letter-spacing:.04em;flex-shrink:0;width:36px}
article.doc h2::before{content:"";position:absolute;top:-32px;left:0;width:40px;height:2px;background:var(--brass-500)}
article.doc h3{font-family:'Source Serif 4',serif;font-weight:600;font-size:24px;color:var(--ink-900);margin:36px 0 14px;line-height:1.25}
article.doc h4{font-family:'Source Serif 4',serif;font-weight:600;font-size:19px;color:var(--ink-900);margin:24px 0 12px;line-height:1.3}
article.doc p{font-size:16.5px;line-height:1.75;color:var(--slate-700);margin-bottom:18px;max-width:720px}
article.doc p strong{color:var(--ink-900);font-weight:600}
article.doc ul.bullets{list-style:none;margin:24px 0;padding:0;max-width:720px;counter-reset:b}
article.doc ul.bullets li{position:relative;padding:14px 0 14px 56px;border-bottom:1px solid var(--line);font-size:15.5px;color:var(--slate-700);line-height:1.55}
article.doc ul.bullets li::before{content:counter(b, decimal-leading-zero);counter-increment:b;position:absolute;left:0;top:14px;font-family:'JetBrains Mono',monospace;font-size:13px;color:var(--brass-500);font-weight:500;letter-spacing:.04em}
article.doc ul.bullets li:last-child{border-bottom:0}
article.doc ul.plain,article.doc ol.plain{margin:16px 0 16px 24px;max-width:680px}
article.doc ul.plain li,article.doc ol.plain li{font-size:15.5px;line-height:1.7;color:var(--slate-700);margin-bottom:8px;padding-left:6px}
article.doc ul.plain li::marker{color:var(--brass-500)}
article.doc ol.plain li::marker{color:var(--brass-500);font-family:'JetBrains Mono',monospace;font-size:13px}
article.doc a.inline{color:var(--ink-900);font-weight:500;border-bottom:1px solid var(--brass-500);padding-bottom:1px}
article.doc a.inline:hover{color:var(--brass-500)}
.pullquote{border-left:3px solid var(--brass-500);padding:8px 0 8px 32px;margin:40px 0;font-family:'Source Serif 4',serif;font-style:italic;font-weight:400;font-size:24px;line-height:1.4;color:var(--ink-900);max-width:720px}
.pullquote em{color:var(--brass-500);font-style:italic}
.callout{background:rgba(184,144,88,.08);border-left:3px solid var(--brass-500);padding:18px 22px;margin:20px 0;border-radius:0 4px 4px 0;font-size:15px;color:var(--ink-900);line-height:1.65;max-width:720px}
.callout strong{color:var(--brass-500)}
.definitions{background:var(--paper-soft);border:1px solid var(--line);border-radius:6px;padding:24px 28px;margin:20px 0;max-width:680px}
.definitions dt{font-family:'Source Serif 4',serif;font-weight:600;font-size:15px;color:var(--ink-900);margin-bottom:4px;margin-top:14px}
.definitions dt:first-child{margin-top:0}
.definitions dd{font-size:14.5px;color:var(--slate-700);line-height:1.65;margin-bottom:8px;padding-left:0}

/* Instrument card (for Restructurare 3 instrumente) */
.instrument{background:var(--paper-soft);border:1px solid var(--line);border-radius:6px;padding:48px;margin:32px 0 48px;position:relative;overflow:hidden}
.instrument::before{content:"";position:absolute;top:0;left:0;width:3px;height:100%;background:var(--brass-500)}
.instrument .tag{font-family:'JetBrains Mono',monospace;color:var(--brass-500);font-size:12px;letter-spacing:.1em;margin-bottom:14px}
.instrument h3{font-family:'Source Serif 4',serif;font-weight:400;font-size:34px;color:var(--ink-900);margin:0 0 18px;line-height:1.1;letter-spacing:-.015em}
.instrument h3 em{font-style:italic;color:var(--brass-500)}
.instrument p{font-size:16px;line-height:1.7;margin-bottom:14px}
.benefits{background:var(--ink-900);color:var(--paper);border-radius:6px;padding:32px 36px;margin:24px 0;position:relative;overflow:hidden}
.benefits::before{content:"";position:absolute;top:-80px;right:-80px;width:240px;height:240px;background:radial-gradient(circle,rgba(184,144,88,.16),transparent 70%)}
.benefits-inner{position:relative;z-index:1}
.benefits .micro{color:var(--brass-300);margin-bottom:14px}
.benefits h4{font-family:'Source Serif 4',serif;font-weight:600;font-size:20px;color:var(--paper);margin-bottom:14px}
.benefits ul{list-style:none;padding:0;margin:0}
.benefits li{padding:10px 0;font-size:14.5px;color:rgba(246,242,235,.88);border-bottom:1px solid rgba(217,188,140,.18);display:flex;gap:10px;align-items:flex-start;line-height:1.55}
.benefits li:last-child{border-bottom:0}
.benefits li::before{content:"→";color:var(--brass-300);font-weight:600;flex-shrink:0}

/* TOC sidebar */
.doc-aside{position:sticky;top:100px;align-self:start}
.toc{background:var(--paper-soft);border:1px solid var(--line);border-radius:6px;padding:24px;margin-bottom:20px}
.toc .micro{margin-bottom:16px}
.toc ol{list-style:none;counter-reset:t;padding:0;margin:0}
.toc li{counter-increment:t;padding:10px 0;border-bottom:1px solid var(--line);font-size:14px}
.toc li:last-child{border-bottom:0}
.toc li a{display:flex;gap:12px;color:var(--ink-700);font-weight:500;transition:color .2s}
.toc li a:hover,.toc li a.active{color:var(--brass-500)}
.toc li a::before{content:counter(t, decimal-leading-zero);font-family:'JetBrains Mono',monospace;color:var(--slate-400);font-size:11px;letter-spacing:.06em;flex-shrink:0;width:24px;padding-top:1px}
.toc li a:hover::before,.toc li a.active::before{color:var(--brass-500)}

.cta-box{background:var(--ink-900);color:var(--paper);border-radius:6px;padding:28px;position:relative;overflow:hidden;margin-bottom:20px}
.cta-box::before{content:"";position:absolute;top:-80px;right:-80px;width:200px;height:200px;background:radial-gradient(circle,rgba(184,144,88,.2),transparent 70%)}
.cta-box-inner{position:relative;z-index:1}
.cta-box .micro{color:var(--brass-300);margin-bottom:10px}
.cta-box h4{font-family:'Source Serif 4',serif;font-weight:600;font-size:22px;color:var(--paper);line-height:1.2;margin-bottom:10px}
.cta-box h4 em{font-style:italic;color:var(--brass-300)}
.cta-box p{font-size:13.5px;color:rgba(246,242,235,.78);line-height:1.55;margin-bottom:20px}
.cta-box .btn{display:block;text-align:center;background:var(--brass-500);color:var(--ink-900);padding:13px 18px;border-radius:4px;font-weight:600;font-size:13.5px;transition:all .2s}
.cta-box .btn:hover{background:var(--paper);color:var(--ink-900)}
.cta-box .phone{display:block;text-align:center;margin-top:14px;font-family:'JetBrains Mono',monospace;font-size:13px;color:var(--brass-300);letter-spacing:.03em}
.cta-box .phone:hover{color:var(--paper)}

.side-card{background:var(--paper-soft);border:1px solid var(--line);border-radius:6px;padding:22px;margin-bottom:20px}
.side-card h4{font-family:'Source Serif 4',serif;font-weight:600;font-size:17px;color:var(--ink-900);margin-bottom:8px}
.side-card p{font-size:13.5px;color:var(--slate-700);line-height:1.55;margin-bottom:14px}
.side-card a.btn{display:inline-block;font-size:13px;font-weight:600;color:var(--ink-900);border-bottom:1.5px solid var(--brass-500);padding-bottom:2px}

/* Related cross-link grid */
.related{background:var(--paper-soft);border-top:1px solid var(--line);padding:80px 0}
.related h3{font-family:'Source Serif 4',serif;font-weight:400;font-size:32px;color:var(--ink-900);margin-bottom:32px;letter-spacing:-.015em}
.related h3 em{font-style:italic;color:var(--brass-500)}
.related-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.related-card{background:var(--paper);border:1px solid var(--line);border-radius:6px;padding:36px;transition:all .3s;display:block;position:relative;overflow:hidden}
.related-card::before{content:"";position:absolute;top:0;left:0;width:3px;height:0;background:var(--brass-500);transition:height .3s}
.related-card:hover{transform:translateY(-3px);box-shadow:0 20px 40px -15px rgba(14,26,53,.15)}
.related-card:hover::before{height:100%}
.related-card .micro{color:var(--brass-500);margin-bottom:14px}
.related-card h4{font-family:'Source Serif 4',serif;font-weight:600;font-size:24px;color:var(--ink-900);margin-bottom:10px;line-height:1.25}
.related-card p{font-size:14.5px;color:var(--ink-500);line-height:1.55;margin-bottom:18px}
.related-card .arrow{color:var(--ink-900);font-weight:600;font-size:14px;border-bottom:1.5px solid var(--brass-500);padding-bottom:2px;display:inline-block}

/* CTA band */
.cta-band{padding:120px 0;text-align:center;background:var(--paper)}
.cta-band .micro{color:var(--brass-500);margin-bottom:20px}
.cta-band h2{font-family:'Source Serif 4',serif;font-weight:400;font-size:clamp(36px,5vw,60px);line-height:1.05;letter-spacing:-.02em;color:var(--ink-900);max-width:780px;margin:0 auto}
.cta-band h2 em{font-style:italic;color:var(--brass-500)}
.cta-band p{font-size:17px;color:var(--ink-500);max-width:560px;margin:22px auto 36px;line-height:1.6}
.cta-band .cta-row{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

@media (max-width:980px){
  .doc-grid,.doc-grid.narrow-side,.related-grid{grid-template-columns:1fr;gap:40px}
  .doc-aside{position:static}
  article.doc h2{flex-direction:column;gap:6px}
  article.doc h2 .n{width:auto}
  article.doc section{margin-bottom:56px}
  .doc-wrap{padding:48px 0 80px}
  .sub-hero{padding:48px 0 40px}
  .instrument{padding:32px 24px}
  .benefits{padding:24px}
}

/* ============ PARTENERI (dark theme — light logos) ============ */
.parteneri{padding:100px 0;background:var(--ink-900);color:var(--paper);position:relative;overflow:hidden}
.parteneri::before{content:"";position:absolute;top:-200px;right:-150px;width:600px;height:600px;background:radial-gradient(circle,rgba(184,144,88,.12),transparent 70%);pointer-events:none}
.parteneri::after{content:"";position:absolute;bottom:-150px;left:-100px;width:400px;height:400px;background:radial-gradient(circle,rgba(184,144,88,.08),transparent 70%);pointer-events:none}
.parteneri-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:80px;align-items:center;position:relative;z-index:1}
.parteneri-intro .micro{color:var(--brass-300);margin-bottom:14px}
.parteneri-intro h3{font-family:'Source Serif 4',serif;font-weight:400;font-size:clamp(28px,3.5vw,40px);line-height:1.1;letter-spacing:-.015em;color:var(--paper);margin-bottom:16px}
.parteneri-intro h3 em{font-style:italic;color:var(--brass-300)}
.parteneri-intro p{font-size:16px;line-height:1.65;color:rgba(246,242,235,.75);max-width:380px}
.parteneri-logos{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.partener-card{background:rgba(246,242,235,.04);border:1px solid rgba(217,188,140,.18);border-radius:6px;padding:40px 32px;display:flex;flex-direction:column;align-items:center;gap:18px;transition:all .25s;text-align:center;position:relative;overflow:hidden}
.partener-card::before{content:"";position:absolute;top:0;left:0;width:0;height:3px;background:var(--brass-500);transition:width .3s}
.partener-card:hover{transform:translateY(-3px);background:rgba(246,242,235,.07);border-color:var(--brass-300)}
.partener-card:hover::before{width:100%}
.partener-logo{height:64px;max-width:80%;width:auto;object-fit:contain;transition:opacity .25s,filter .25s;opacity:.92;filter:brightness(0) invert(1)}
.partener-card:hover .partener-logo{opacity:1;filter:brightness(0) invert(1) drop-shadow(0 0 8px rgba(184,144,88,.35))}
.partener-meta{display:flex;flex-direction:column;gap:4px;align-items:center}
.partener-meta .micro{color:var(--brass-300)}
.partener-meta strong{font-family:'Source Serif 4',serif;font-size:16px;color:var(--paper);font-weight:600;line-height:1.3}
.partener-meta span{font-size:12.5px;color:rgba(246,242,235,.6);line-height:1.5;max-width:240px}
.partener-link{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;color:var(--brass-300);font-weight:600;border-bottom:1.5px solid var(--brass-500);padding-bottom:1px;margin-top:4px;transition:color .2s}
.partener-card:hover .partener-link{color:var(--paper)}
.partener-link svg{width:11px;height:11px}
@media (max-width:880px){.parteneri-grid{grid-template-columns:1fr;gap:48px}.parteneri-logos{grid-template-columns:1fr;gap:16px}}

/* ============ BACK TO TOP ============ */
#back-to-top{position:fixed;left:24px;bottom:24px;z-index:90;width:52px;height:52px;border-radius:50%;background:var(--ink-900);color:var(--paper);border:0;cursor:pointer;display:grid;place-items:center;opacity:0;pointer-events:none;transform:translateY(8px);transition:opacity .3s,transform .3s,background .2s,color .2s;box-shadow:0 12px 28px -10px rgba(14,26,53,.45)}
#back-to-top.visible{opacity:1;pointer-events:auto;transform:translateY(0)}
#back-to-top:hover{background:var(--brass-500);color:var(--ink-900)}
#back-to-top .prog{position:absolute;inset:0;width:100%;height:100%;transform:rotate(-90deg);pointer-events:none}
#back-to-top .prog-bg{fill:none;stroke:rgba(246,242,235,.14);stroke-width:2}
#back-to-top .prog-fg{fill:none;stroke:var(--brass-500);stroke-width:2;stroke-linecap:round;stroke-dasharray:138.23;stroke-dashoffset:138.23;transition:stroke-dashoffset .12s linear}
#back-to-top:hover .prog-fg{stroke:var(--ink-900)}
#back-to-top .arrow{width:18px;height:18px;display:block;position:relative;z-index:1}

/* ============ MOBILE ============ */
@media (max-width:980px){
  /* Disable backdrop-filter on mobile — creates containing block that traps position:fixed children (the drawer). */
  nav.top{backdrop-filter:none !important;-webkit-backdrop-filter:none !important;background:var(--paper) !important}
  nav.top .brand-logo{height:36px}
  nav.top .row{height:64px;gap:2px}
  /* Swap icon visibility on mobile: bar variants visible in navbar, menu hidden */
  /* All 3 mobile icons (home / calc / menu-toggle) standardized to 44x44 with svg 22x22 for visual alignment */
  nav.top .nav-home-bar{display:flex;margin-left:auto;width:44px;height:44px;border-radius:6px}
  nav.top .nav-calc-bar{display:flex;width:44px;height:44px;border-radius:6px}
  nav.top .nav-home-bar svg{width:20px;height:20px}
  nav.top .nav-calc-bar svg{width:22px;height:22px}
  nav.top .nav-home-menu,nav.top .nav-calc-menu{display:none}
  nav.top .nav-toggle{display:flex;align-items:center;justify-content:center;background:transparent;border:0;cursor:pointer;width:44px;height:44px;color:var(--ink-900);position:relative;border-radius:6px;transition:background .2s;padding:0;flex-shrink:0}
  nav.top .nav-toggle:hover{background:rgba(184,144,88,.12)}
  nav.top .nav-toggle svg{width:22px;height:22px;display:block;transition:opacity .25s,transform .25s;position:absolute}
  nav.top .nav-toggle .ic-close{opacity:0;transform:rotate(-45deg)}
  nav.top .nav-toggle.active .ic-burger{opacity:0;transform:rotate(45deg)}
  nav.top .nav-toggle.active .ic-close{opacity:1;transform:rotate(0)}
  nav.top .nav-panel{position:fixed;top:64px;left:0;right:0;bottom:0;background:var(--paper);flex-direction:column;align-items:stretch;padding:24px 28px 100px;gap:0;overflow-y:auto;transform:translateY(-12px);opacity:0;pointer-events:none;transition:transform .35s ease,opacity .25s;border-top:1px solid var(--line);z-index:9998}
  nav.top .nav-panel.open{transform:translateY(0);opacity:1;pointer-events:auto}
  nav.top .nav-panel > ul{flex-direction:column;width:100%;gap:0;align-items:stretch}
  nav.top .nav-panel > ul > li{width:100%;border-bottom:1px solid var(--line)}
  nav.top .nav-panel > ul > li > a{display:block;padding:18px 0;font-size:18px;font-family:'Source Serif 4',serif;font-weight:500;color:var(--ink-900)}
  nav.top .nav-panel > ul > li > a::after{display:none}
  nav.top .nav-panel > ul .menu-item-has-children > a::after,nav.top .nav-panel > ul .dropdown > a::after{content:"+";display:inline-block;float:right;font-size:22px;font-weight:300;color:var(--slate-400);line-height:1;position:static}
  nav.top .nav-panel > ul .menu-item-has-children.open > a::after,nav.top .nav-panel > ul .dropdown.open > a::after{content:"−"}
  nav.top .nav-panel > ul .sub-menu,nav.top .nav-panel > ul .dropdown-menu{display:none !important;position:static !important;background:transparent !important;border:0 !important;box-shadow:none !important;padding:0 0 16px 0 !important;margin:-4px 0 12px 0 !important;width:100% !important;flex-direction:column !important;gap:0}
  nav.top .nav-panel > ul .menu-item-has-children.open .sub-menu,nav.top .nav-panel > ul .dropdown.open .dropdown-menu{display:flex !important}
  nav.top .nav-panel > ul .sub-menu li,nav.top .nav-panel > ul .dropdown-menu li{border-bottom:0}
  nav.top .nav-panel > ul .sub-menu a,nav.top .nav-panel > ul .dropdown-menu a{padding:12px 0 12px 16px !important;font-size:15px !important;font-family:'Inter',sans-serif !important;color:var(--ink-700);border-left:2px solid var(--line);border-radius:0 !important;font-weight:500}
  nav.top .nav-panel > ul .sub-menu a:hover,nav.top .nav-panel > ul .dropdown-menu a:hover{color:var(--brass-500);border-left-color:var(--brass-500)}
  nav.top .nav-panel > .nav-cta{margin-top:28px;display:block;width:100%;text-align:center;padding:18px 20px;font-size:15px}
  .hero-grid,.section-head,.calc-grid,.prac-grid,.proc-grid,.jurnal-grid,.foot-grid,.stats-grid,.svc-grid,.resurse-grid{grid-template-columns:1fr;gap:40px}
  .resurse-grid{gap:14px}
  .resurse-card{padding:22px 20px;gap:14px}
  .rc-icon{width:42px;height:50px}
  .rc-title{font-size:15.5px;line-height:1.3}
  .rc-desc{font-size:13px}
  /* Hero — collapse desktop spacing that would leave a huge dead zone between text and photo on mobile */
  .hero{padding:48px 0 0}
  .hero-grid{gap:20px}
  .hero-copy{padding-bottom:0}
  .hero-visual{min-height:auto;padding-top:8px}
  .hero-visual::before{display:none}
  .hero-visual img{max-height:560px;max-width:100%;height:auto;width:auto;margin:0 auto}
  .hero-badge{right:12px;bottom:24px;max-width:200px;padding:12px 14px}
  .hero-badge strong{font-size:14px}
  .hero-badge span{font-size:11.5px}
  /* Stats — center on mobile since we stack vertically */
  .stats-grid{gap:32px}
  .stat{text-align:center}
  .stat .num{font-size:54px}
  .proc-step{border-right:0;border-bottom:1px solid var(--line)}
  section.section{padding:80px 0}
  #back-to-top{width:46px;height:46px;left:16px;bottom:70px}
  #back-to-top .arrow{width:16px;height:16px}
}
