/* ===========================================================
   DPGM SECURITY — Design System (Premium-Discreet VIP)
   Concrete charcoal + tactical green #8FB02F · Playfair Display + Inter
   =========================================================== */
:root{
  /* Concrete / industrial charcoal base (was navy) */
  --navy:#15181b; --navy-700:#202327; --navy-800:#1b1e21; --navy-900:#0e1011;
  /* Accent: tactical green (was gold). Var names kept as --gold* for stability. */
  --gold:#8FB02F; --gold-light:#A8CB4D; --gold-dim:rgba(143,176,47,.16);
  --offwhite:#F4F1EA; --white:#FFFFFF; --steel:#9aa0a6; --steel-border:#33373c;
  --maxw:1200px; --r:14px;
  --serif:"Playfair Display",Georgia,"Times New Roman",serif;
  --sans:"Inter",system-ui,"Segoe UI",Arial,sans-serif;
  --t:.4s cubic-bezier(.2,.7,.2,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);color:var(--offwhite);
  background:#0f1113 url("../img/opt-wall.jpg") center/cover fixed;
  font-size:17px;line-height:1.6;-webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
h1,h2,h3,h4{font-family:var(--serif);font-weight:500;line-height:1.15;letter-spacing:.01em}
h1{font-size:clamp(38px,6vw,68px);color:var(--white)}
h2{font-size:clamp(28px,4vw,42px);color:var(--offwhite)}
h3{font-size:clamp(20px,2.4vw,26px)}
p{color:#cfd8e2}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.eyebrow{font-family:var(--sans);font-weight:600;font-size:13px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--gold);display:inline-block;margin-bottom:18px}
.lead{font-size:clamp(18px,2vw,21px);color:#d7dee7;max-width:62ch}
.muted{color:var(--steel)}
.center{text-align:center}
.gold{color:var(--gold)}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--sans);font-weight:600;
  font-size:15px;letter-spacing:.02em;padding:15px 28px;border-radius:40px;cursor:pointer;
  border:1.5px solid transparent;transition:var(--t);white-space:nowrap}
.btn-gold{background:var(--gold);color:var(--navy)}
.btn-gold:hover{background:var(--gold-light);transform:translateY(-2px);box-shadow:0 12px 30px -10px rgba(143,176,47,.55)}
.btn-outline{border-color:var(--gold);color:var(--gold)}
.btn-outline:hover{background:var(--gold-dim);transform:translateY(-2px)}
.btn-ghost{color:var(--offwhite);padding:14px 8px}
.btn-ghost:hover{color:var(--gold)}
.btn .arrow{transition:transform var(--t)}
.btn:hover .arrow{transform:translateX(4px)}
.btn-lg{padding:18px 36px;font-size:16px}

/* ---------- Top utility bar ---------- */
.topbar{background:var(--navy-900);border-bottom:1px solid var(--steel-border);font-size:13px}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;height:42px;gap:20px}
.topbar a{color:var(--steel);transition:var(--t)}
.topbar a:hover{color:var(--gold)}
.topbar .tb-left{display:flex;gap:22px;flex-wrap:wrap}
.topbar .tb-right{display:flex;gap:18px;align-items:center}
.topbar .dot{color:var(--gold)}

/* ---------- Header ---------- */
header.site{position:sticky;top:0;z-index:90;background:rgba(17,19,21,.80);
  backdrop-filter:blur(14px);border-bottom:1px solid var(--steel-border);transition:var(--t)}
header.site.scrolled{background:rgba(10,11,12,.96)}
.nav{display:flex;align-items:center;justify-content:space-between;height:78px;gap:24px}
.brand{display:flex;align-items:center;gap:14px;flex-shrink:0}
.brand img{width:52px;height:52px;border-radius:50%;box-shadow:0 0 0 1px var(--gold-dim)}
.brand .bn{font-family:var(--serif);font-size:20px;color:var(--white);line-height:1}
.brand .bn small{display:block;font-family:var(--sans);font-size:10px;letter-spacing:.32em;
  color:var(--gold);margin-top:4px;font-weight:600}
.menu{display:flex;gap:30px;align-items:center;list-style:none}
.menu a{font-size:15px;font-weight:500;color:#d7dee7;position:relative;padding:6px 0;transition:var(--t)}
.menu a::after{content:"";position:absolute;left:0;bottom:0;height:1.5px;width:0;background:var(--gold);transition:width var(--t)}
.menu a:hover,.menu a.active{color:var(--white)}
.menu a:hover::after,.menu a.active::after{width:100%}
.nav-cta{display:flex;gap:12px;align-items:center}
.nav-cta .btn{padding:11px 20px;font-size:14px}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.burger span{width:26px;height:2px;background:var(--gold);transition:var(--t)}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:92vh;display:flex;align-items:flex-end;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg picture{position:absolute;inset:0;display:block}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center 30%}
@media(max-width:760px){.hero-bg img{object-position:center 22%}}
.hero-bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(10,11,12,.55) 0%,rgba(10,11,12,.35) 40%,rgba(10,11,12,.94) 100%),
  linear-gradient(90deg,rgba(10,11,12,.72) 0%,rgba(10,11,12,0) 60%)}
.hero-inner{position:relative;z-index:1;padding-bottom:72px;padding-top:120px;max-width:820px}
.hero h1{margin-bottom:22px}
.hero .lead{margin-bottom:34px}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap;align-items:center}
.trust-strip{margin-top:40px;display:flex;gap:26px;flex-wrap:wrap;align-items:center;
  padding-top:26px;border-top:1px solid rgba(143,176,47,.28)}
.trust-strip span{font-size:12.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--steel);
  font-weight:600;display:flex;align-items:center;gap:9px}
.trust-strip span::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--gold)}

/* ---------- Sections ---------- */
section.s{padding:clamp(64px,9vw,120px) 0}
section.s.alt{background:linear-gradient(rgba(8,9,11,.40),rgba(8,9,11,.40))}
section.s.deep{background:linear-gradient(rgba(0,0,0,.62),rgba(0,0,0,.62))}
.s-head{max-width:680px;margin-bottom:54px}
.s-head.c{margin-left:auto;margin-right:auto;text-align:center}
.s-head p{margin-top:16px}

/* ---------- Stat band ---------- */
.cifre{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--steel-border);border-radius:var(--r);overflow:hidden}
.cifre .cell{padding:38px 26px;text-align:center;border-right:1px solid var(--steel-border)}
.cifre .cell:last-child{border-right:0}
.cifre .num{font-family:var(--serif);font-size:clamp(36px,4.5vw,52px);color:var(--gold);line-height:1}
.cifre .lbl{margin-top:12px;font-size:13.5px;color:var(--steel);letter-spacing:.04em}

/* ---------- Service grid ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.svc-card{position:relative;border-radius:var(--r);overflow:hidden;background:var(--navy-800);
  border:1px solid var(--steel-border);min-height:380px;display:flex;flex-direction:column;
  justify-content:flex-end;transition:var(--t)}
.svc-card .ph{position:absolute;inset:0;z-index:0}
.svc-card .ph img{width:100%;height:100%;object-fit:cover;transition:transform .7s ease}
.svc-card .ph::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,11,12,.10) 0%,rgba(10,11,12,.55) 50%,rgba(10,11,12,.96) 100%)}
.svc-card .body{position:relative;z-index:1;padding:28px}
.svc-card h3{color:var(--white);margin-bottom:8px}
.svc-card p{font-size:14.5px;color:#c4cdd8;margin-bottom:16px}
.svc-card .more{color:var(--gold);font-weight:600;font-size:14px;display:inline-flex;gap:8px;align-items:center}
.svc-card:hover{transform:translateY(-6px);border-color:var(--gold)}
.svc-card:hover .ph img{transform:scale(1.06)}
.svc-card:hover .more .arrow{transform:translateX(4px)}

/* ---------- Steps ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;counter-reset:st}
.step{padding:30px 24px;border:1px solid var(--steel-border);border-radius:var(--r);background:var(--navy-800);position:relative}
.step::before{counter-increment:st;content:"0" counter(st);font-family:var(--serif);font-size:30px;color:var(--gold);display:block;margin-bottom:14px}
.step h4{font-family:var(--serif);font-size:19px;color:var(--white);margin-bottom:8px}
.step p{font-size:14px}

/* ---------- Split / feature ---------- */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center}
.split img{border-radius:var(--r);width:100%;height:100%;object-fit:cover;max-height:560px}
.split ul{list-style:none;margin-top:22px;display:flex;flex-direction:column;gap:14px}
.split li{display:flex;gap:12px;font-size:15.5px;color:#d7dee7}
.split li::before{content:"";flex:0 0 8px;height:8px;margin-top:9px;background:var(--gold);transform:rotate(45deg)}

/* ---------- Accreditations ---------- */
.acc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.acc{padding:26px 22px;border:1px solid var(--steel-border);border-radius:var(--r);background:var(--navy-800);transition:var(--t)}
.acc:hover{border-color:var(--gold)}
.acc .k{font-family:var(--serif);font-size:17px;color:var(--white);margin-bottom:6px}
.acc .v{font-size:13px;color:var(--steel)}
.acc a{color:var(--gold);font-size:13px;font-weight:600}

/* ---------- Quote ---------- */
.quote{max-width:820px;margin:0 auto;text-align:center}
.quote .q{font-family:var(--serif);font-size:clamp(22px,3vw,32px);color:var(--offwhite);line-height:1.4}
.quote .q::before{content:"“";color:var(--gold)}
.quote .q::after{content:"”";color:var(--gold)}
.quote .by{margin-top:22px;color:var(--steel);font-size:14px;letter-spacing:.08em;text-transform:uppercase}

/* ---------- CTA band ---------- */
.ctaband{background:linear-gradient(120deg,var(--navy-900),var(--navy-700));border:1px solid var(--steel-border);
  border-radius:20px;padding:clamp(40px,6vw,72px);text-align:center}
.ctaband h2{margin-bottom:16px}
.ctaband .hero-cta{justify-content:center;margin-top:30px}

/* ---------- Footer ---------- */
footer.site{background:var(--navy-900);border-top:1px solid var(--steel-border);padding:70px 0 30px}
.foot{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.1fr;gap:40px}
.foot .brand{margin-bottom:18px}
.foot p{font-size:14px;color:var(--steel);max-width:34ch}
.foot h5{font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-bottom:18px;font-weight:700}
.foot ul{list-style:none;display:flex;flex-direction:column;gap:11px}
.foot ul a{font-size:14.5px;color:#c4cdd8;transition:var(--t)}
.foot ul a:hover{color:var(--gold)}
.foot .legal-line{font-size:13px;color:var(--steel);line-height:1.8}
.foot-bottom{margin-top:50px;padding-top:24px;border-top:1px solid var(--steel-border);
  display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:12.5px;color:var(--steel)}

/* ---------- Page hero (interior) ---------- */
.pagehero{padding:140px 0 60px;background:linear-gradient(180deg,var(--navy-900),var(--navy));border-bottom:1px solid var(--steel-border)}
.crumbs{font-size:13px;color:var(--steel);margin-bottom:18px}
.crumbs a:hover{color:var(--gold)}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s ease,transform .8s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}html{scroll-behavior:auto}}

/* ---------- Wizard ---------- */
.wizard{max-width:780px;margin:0 auto}
.stepper{display:flex;gap:8px;margin-bottom:14px}
.stepper .sd{flex:1;height:5px;border-radius:4px;background:var(--steel-border);transition:var(--t)}
.stepper .sd.on{background:var(--gold)}
.stepper-meta{display:flex;justify-content:space-between;font-size:13px;color:var(--steel);margin-bottom:34px}
.wstep{display:none;animation:fade .5s ease}
.wstep.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.wstep h3{margin-bottom:8px}
.wstep .hint{color:var(--steel);font-size:14px;margin-bottom:26px}
.opt-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.opt{padding:22px;border:1.5px solid var(--steel-border);border-radius:var(--r);cursor:pointer;transition:var(--t);background:var(--navy-800)}
.opt:hover{border-color:var(--gold-light)}
.opt.sel{border-color:var(--gold);background:var(--gold-dim)}
.opt .ot{font-family:var(--serif);font-size:18px;color:var(--white);margin-bottom:6px}
.opt .od{font-size:13.5px;color:var(--steel)}
.field{margin-bottom:20px}
.field label{display:block;font-size:14px;font-weight:600;color:var(--offwhite);margin-bottom:8px}
.field input,.field select,.field textarea{width:100%;background:var(--navy-800);border:1.5px solid var(--steel-border);
  border-radius:10px;padding:14px 16px;color:var(--white);font-family:var(--sans);font-size:15px;transition:var(--t)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-dim)}
.field textarea{min-height:120px;resize:vertical}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.wnav{display:flex;justify-content:space-between;margin-top:30px;gap:14px}
.estimate{background:var(--navy-900);border:1px solid var(--gold);border-radius:var(--r);padding:24px;margin-top:8px}
.estimate .eh{display:flex;justify-content:space-between;align-items:baseline}
.estimate .ev{font-family:var(--serif);font-size:32px;color:var(--gold)}
.estimate .en{font-size:12.5px;color:var(--steel);margin-top:10px}
.confirm{text-align:center;padding:30px 0}
.confirm .check{width:70px;height:70px;border-radius:50%;border:2px solid var(--gold);color:var(--gold);
  display:flex;align-items:center;justify-content:center;font-size:34px;margin:0 auto 22px}
.refno{font-family:var(--serif);color:var(--gold);font-size:22px;letter-spacing:.1em}

/* ---------- Course catalog ---------- */
.filters{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:36px}
.filters select{background:var(--navy-800);border:1.5px solid var(--steel-border);border-radius:30px;
  padding:11px 18px;color:var(--offwhite);font-family:var(--sans);font-size:14px}
.course-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.course{border:1px solid var(--steel-border);border-radius:var(--r);overflow:hidden;background:var(--navy-800);transition:var(--t);display:flex;flex-direction:column}
.course:hover{transform:translateY(-5px);border-color:var(--gold)}
.course .ci{height:200px;overflow:hidden}
.course .ci img{width:100%;height:100%;object-fit:cover}
.course .cb{padding:26px;display:flex;flex-direction:column;flex:1}
.badge{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:var(--gold);border:1px solid var(--gold);border-radius:20px;padding:4px 12px;margin-bottom:14px;align-self:flex-start}
.course h3{color:var(--white);margin-bottom:8px}
.course .meta{display:flex;gap:16px;flex-wrap:wrap;font-size:13px;color:var(--steel);margin:14px 0}
.course .price{font-family:var(--serif);font-size:24px;color:var(--gold);margin-top:auto}
.course .price small{font-size:13px;color:var(--steel);font-family:var(--sans)}
.course .cb .btn{margin-top:18px;justify-content:center}

/* ---------- Forms / generic ---------- */
.formcard{max-width:720px;margin:0 auto;background:var(--navy-800);border:1px solid var(--steel-border);border-radius:var(--r);padding:clamp(28px,4vw,48px)}
.gate{display:flex;gap:12px;align-items:flex-start;margin-bottom:14px;font-size:14.5px;color:#d7dee7}
.gate input{margin-top:5px;accent-color:var(--gold);width:18px;height:18px;flex-shrink:0}
.notice{background:var(--gold-dim);border-left:3px solid var(--gold);padding:14px 18px;border-radius:8px;font-size:14px;color:var(--offwhite);margin:18px 0}

/* ---------- Misc ---------- */
.tag-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px}
.tag{font-size:12.5px;color:var(--steel);border:1px solid var(--steel-border);border-radius:20px;padding:6px 14px}
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.gallery img{border-radius:var(--r);height:240px;width:100%;object-fit:cover;transition:var(--t)}
.gallery img:hover{transform:scale(1.02)}

/* ---------- Responsive ---------- */
@media(max-width:980px){
  .menu,.nav-cta .btn-line{display:none}
  .burger{display:flex}
  .svc-grid,.steps,.cifre,.acc-grid{grid-template-columns:repeat(2,1fr)}
  .cifre .cell:nth-child(2){border-right:0}
  .split,.foot{grid-template-columns:1fr;gap:32px}
  .course-grid,.gallery{grid-template-columns:1fr}
  .menu.open{display:flex;position:fixed;inset:78px 0 auto 0;flex-direction:column;background:var(--navy-900);
    padding:24px;gap:20px;border-bottom:1px solid var(--steel-border)}
}
@media(max-width:560px){
  .svc-grid,.steps,.cifre,.acc-grid,.opt-grid,.row2{grid-template-columns:1fr}
  .cifre .cell{border-right:0;border-bottom:1px solid var(--steel-border)}
  .topbar{display:none}
  .hero-cta .btn{width:100%;justify-content:center}
  .menu.open a{display:block;padding:14px 0;font-size:17px}
}

/* ---------- Accessibility: focus-visible + skip link ---------- */
a:focus-visible,button:focus-visible,.btn:focus-visible,.menu a:focus-visible,
.burger:focus-visible,.opt:focus-visible,input:focus-visible,select:focus-visible,
textarea:focus-visible,[tabindex]:focus-visible{
  outline:2px solid var(--gold-light);outline-offset:3px;border-radius:4px}
.skip-link{position:absolute;left:-9999px;top:0;z-index:200;background:var(--gold);color:#0e1011;
  padding:12px 20px;font-weight:600;border-radius:0 0 8px 0}
.skip-link:focus{left:0}
.opt[aria-checked="true"]{border-color:var(--gold);background:var(--gold-dim)}
button.opt{font:inherit;text-align:left;width:100%;color:inherit;display:block}
.opt .ot,.opt .od{display:block}

/* ---------- Floating WhatsApp button ---------- */
.wa-float{position:fixed;right:22px;bottom:22px;z-index:120;display:flex;align-items:center;gap:0;
  background:#25D366;color:#fff;height:60px;width:60px;border-radius:40px;overflow:hidden;
  box-shadow:0 10px 30px -8px rgba(0,0,0,.6);transition:width .35s cubic-bezier(.2,.7,.2,1),transform .2s;
  padding-left:15px}
.wa-float svg{flex:0 0 30px}
.wa-label{white-space:nowrap;font-weight:600;font-size:15px;opacity:0;margin-left:12px;padding-right:22px;transition:opacity .25s}
.wa-float:hover{width:268px}
.wa-float:hover .wa-label{opacity:1}
.wa-float:focus-visible{outline:3px solid var(--gold-light);outline-offset:3px}
@media(max-width:560px){.wa-float{right:16px;bottom:16px;height:56px;width:56px;padding-left:13px}.wa-float:hover{width:56px}.wa-float .wa-label{display:none}}

/* ---------- Course video hero + document checklist ---------- */
.course-hero{position:relative;min-height:80vh;display:flex;align-items:flex-end;overflow:hidden;border-bottom:1px solid var(--steel-border)}
.course-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.course-hero::after{content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(10,11,12,.45) 0%,rgba(10,11,12,.5) 40%,rgba(10,11,12,.96) 100%)}
.course-hero-inner{position:relative;z-index:2;padding:140px 0 66px;max-width:820px}
.course-hero-inner h1{margin-bottom:18px}
.doclist{list-style:none;display:grid;gap:12px;margin-top:18px}
.doclist li{display:flex;gap:12px;font-size:15.5px;color:#d7dee7;line-height:1.5}
.doclist li::before{content:"✓";color:var(--gold);font-weight:800;flex:0 0 auto}
.doc-cols{display:grid;grid-template-columns:1fr 1fr;gap:40px}
.doc-card{background:var(--navy-800);border:1px solid var(--steel-border);border-radius:var(--r);padding:30px}
.doc-card h3{color:#fff;margin-bottom:6px}
@media(max-width:760px){.doc-cols{grid-template-columns:1fr}}

/* ---------- Premium inline SVG icons ---------- */
.ico{width:1.05em;height:1.05em;vertical-align:-0.18em;stroke:var(--gold);fill:none;
  stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;display:inline-block;flex:0 0 auto}
.ico-lg{width:46px;height:46px;stroke-width:1.4;vertical-align:middle}
.course .meta span{display:inline-flex;align-items:center;gap:7px}
.legal-line .ico{stroke:var(--gold);margin-right:6px}

/* ---------- Mobile optimization pass ---------- */
html{-webkit-text-size-adjust:100%;text-size-adjust:100%}
img,video{max-width:100%;height:auto}
@media(max-width:900px){
  /* fundal fix = jank + consum mare pe mobil -> scroll normal */
  body{background-attachment:scroll}
  .hero-bg{position:absolute}
}
@media(max-width:760px){
  .hero{min-height:84vh}
  .course-hero{min-height:64vh}
  .course-hero-inner{padding-top:120px;padding-bottom:48px}
  .split img{max-height:380px}
}
@media(max-width:560px){
  .hero-inner{padding-top:100px;padding-bottom:56px}
  h1{font-size:clamp(31px,8.5vw,42px)}
  .pagehero{padding:112px 0 48px}
  .lead{font-size:16.5px}
  .btn-lg{padding:15px 26px;font-size:15px}
  .wrap{padding:0 18px}
  .cifre .num{font-size:40px}
  .gallery img{height:200px}
}

/* ---------- Mobile CTAs inside the menu ---------- */
.menu-cta{display:none}
@media(max-width:980px){
  .menu.open .menu-cta{display:flex;flex-direction:column;gap:12px;margin-top:8px;width:100%}
  .menu.open .menu-cta .btn{width:100%;justify-content:center}
}
