/* ============================================================
   GxP Training — Light theme (BCG-inspired)
   Clean white canvas, generous whitespace, BCG-green accents
   ============================================================ */

:root{
  --bg:#f8fbf9;
  --bg-2:#eef6f2;
  --bg-3:#dfeae4;
  --surface:#ffffff;
  --surface-2:#f7f9f8;
  --surface-3:#eef2f0;
  --border:#dce9e1;
  --border-strong:#bdd1c6;
  --text:#0d1812;
  --text-soft:#384640;
  --text-mute:#7b867f;
  --green:#177b57;
  --green-dark:#0d5538;
  --green-bright:#1f9e6a;
  --accent:#177b57;
  --dark:#146b4e;          /* brand-green feature / footer */
  --dark-2:#0f5a42;
  --grad: linear-gradient(135deg,#177b57 0%,#1f9e6a 100%);
  --grad-soft: #e7f2ec;
  --gold:#b8893f;
  --danger:#d64545;
  --radius:14px;
  --radius-sm:10px;
  --radius-lg:22px;
  --shadow:0 26px 62px -32px rgba(13,60,40,.36);
  --shadow-sm:0 12px 30px -20px rgba(13,60,40,.30);
  --maxw:1200px;
  --font:'Manrope',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --display:'Manrope',system-ui,-apple-system,Segoe UI,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;background:var(--bg)}
body{
  font-family:var(--font);
  background:linear-gradient(180deg,#fbfdfb 0%,#f3f8f5 46%,#f8fbf9 100%);
  color:var(--text);
  line-height:1.62;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
body.no-scroll{overflow:hidden}
a{color:inherit;text-decoration:none;transition:color .2s}
img{max-width:100%;display:block}
ul{list-style:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,textarea,select{font-family:inherit}

/* soft tinted background layer (so the page isn't flat white) */
.bg-fx{position:fixed;inset:0;z-index:-1;pointer-events:none;overflow:hidden;
  background:
    radial-gradient(920px 620px at 88% -12%, rgba(31,158,106,.18), transparent 62%),
    radial-gradient(780px 560px at 8% 18%, rgba(184,137,63,.11), transparent 60%),
    radial-gradient(720px 560px at 88% 72%, rgba(6,182,212,.10), transparent 62%),
    radial-gradient(760px 620px at 44% 112%, rgba(23,123,87,.08), transparent 64%)}
.bg-fx::before{content:"";position:absolute;inset:-12%;
  background:
    linear-gradient(118deg,transparent 0 19%,rgba(184,137,63,.12) 19.15%,transparent 19.5%),
    linear-gradient(152deg,transparent 0 61%,rgba(23,123,87,.10) 61.15%,transparent 61.5%),
    linear-gradient(32deg,transparent 0 78%,rgba(6,182,212,.08) 78.15%,transparent 78.5%);
  opacity:.72}
.bg-fx::after{content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(23,123,87,.045) 1px,transparent 1px),
    linear-gradient(90deg,rgba(23,123,87,.045) 1px,transparent 1px);
  background-size:92px 92px;
  -webkit-mask-image:radial-gradient(circle at 50% 18%,#000 0%,transparent 68%);
  mask-image:radial-gradient(circle at 50% 18%,#000 0%,transparent 68%);
  opacity:.55}

/* ---------- Layout ---------- */
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px}
.section{padding:100px 0}
.section-sm{padding:64px 0}
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-size:12.5px;font-weight:800;letter-spacing:.16em;text-transform:uppercase;
  color:var(--green);margin-bottom:20px
}
.eyebrow::before{content:"";width:30px;height:3px;background:var(--green);border-radius:2px}
h1,h2,h3{font-family:var(--display);font-weight:800;line-height:1.1;letter-spacing:-.02em;color:var(--text)}
.h-xl{font-size:clamp(34px,5.2vw,60px)}
.h-lg{font-size:clamp(28px,3.6vw,44px)}
.h-md{font-size:clamp(22px,2.5vw,30px)}
.lead{font-size:clamp(16px,1.35vw,19px);color:var(--text-soft);max-width:62ch}
.text-grad{color:var(--green)}
.center{text-align:center}
.section-head{max-width:760px;margin:0 auto 60px}
.section-head.center{text-align:center}
.section-head.center .lead{margin:0 auto}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  padding:14px 28px;border-radius:8px;font-weight:700;font-size:15px;
  transition:transform .2s, box-shadow .25s, background .25s, border-color .25s, color .25s;white-space:nowrap
}
.btn-primary{background:var(--green);color:#fff;box-shadow:0 10px 24px -12px rgba(23,123,87,.6)}
.btn-primary:hover{background:var(--green-dark);transform:translateY(-2px);box-shadow:0 16px 30px -14px rgba(23,123,87,.7)}
.btn-ghost{border:1.5px solid var(--border-strong);color:var(--text);background:#fff}
.btn-ghost:hover{border-color:var(--green);color:var(--green)}
.btn-lg{padding:17px 34px;font-size:16px}
.btn-block{width:100%}

/* ---------- Header ---------- */
.header{position:sticky;top:0;z-index:100;transition:background .3s,border-color .3s,box-shadow .3s;border-bottom:1px solid var(--border);background:rgba(255,255,255,.92);backdrop-filter:blur(12px)}
.header.scrolled{box-shadow:0 6px 24px -18px rgba(13,60,40,.4)}
.header>.container{max-width:1400px}
.nav{display:flex;align-items:center;gap:20px;height:74px}
.logo{display:flex;align-items:center;gap:11px;font-family:var(--display);font-weight:800;font-size:20px;letter-spacing:-.02em;flex:none;color:var(--text)}
.logo>span{white-space:nowrap;line-height:1.1}
.logo .mark{
  width:40px;height:40px;border-radius:9px;background:var(--green);
  display:grid;place-items:center;color:#fff;font-size:13.5px;font-weight:800;letter-spacing:-.3px
}
.logo small{display:block;font-family:var(--font);font-size:10px;font-weight:700;letter-spacing:.18em;color:var(--text-mute);text-transform:uppercase}
.nav-links{display:flex;align-items:center;gap:2px;margin-left:auto}
.nav-links a{padding:9px 11px;border-radius:7px;font-weight:600;font-size:14px;color:var(--text-soft);white-space:nowrap}
.nav-links a:hover{color:var(--green)}
.nav-links a.active{color:var(--green);box-shadow:inset 0 -2px 0 var(--green);border-radius:0}
.nav-actions{display:flex;align-items:center;gap:14px}
.lang-switch{display:flex;gap:2px;background:var(--bg-2);border:1px solid var(--border);border-radius:999px;padding:3px}
.lang-switch button{padding:6px 11px;border-radius:999px;font-size:12.5px;font-weight:700;color:var(--text-mute);letter-spacing:.03em}
.lang-switch button.active{background:var(--green);color:#fff}
.nav-phone{display:flex;align-items:center;gap:8px;font-weight:700;font-size:14.5px;color:var(--text);white-space:nowrap;flex:none}
.nav-phone svg{width:20px;height:20px;flex:none;color:var(--green)}
.nav-phone:hover{color:var(--green)}
.burger{display:none;width:44px;height:44px;border-radius:9px;border:1px solid var(--border);place-items:center}
.burger span{position:relative;width:20px;height:2px;background:var(--text);display:block;transition:.3s}
.burger span::before,.burger span::after{content:"";position:absolute;left:0;width:20px;height:2px;background:var(--text);transition:.3s}
.burger span::before{top:-6px}.burger span::after{top:6px}
.burger.open span{background:transparent}
.burger.open span::before{top:0;transform:rotate(45deg)}
.burger.open span::after{top:0;transform:rotate(-45deg)}

/* ---------- Hero (dark, eye-catching) ---------- */
.hero{position:relative;padding:22px 0 72px;overflow:hidden;
  background:linear-gradient(148deg,#115f48 0%,#1b8f65 52%,#0e4c3a 100%);color:#fff}
.hero::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(650px 460px at 86% 8%, rgba(36,184,126,.44), transparent 60%),
    radial-gradient(520px 420px at 16% 20%, rgba(184,137,63,.20), transparent 64%),
    radial-gradient(560px 520px at 6% 92%, rgba(13,110,80,.50), transparent 62%)}
.hero::after{content:"";position:absolute;inset:0;pointer-events:none;opacity:.5;
  background-image:
    radial-gradient(rgba(255,255,255,.06) 1px,transparent 1px),
    linear-gradient(118deg,transparent 0 24%,rgba(255,255,255,.10) 24.15%,transparent 24.45%);
  background-size:26px 26px,auto}
.hero .container{position:relative;z-index:1}
.hero-grid{display:grid;grid-template-columns:1.12fr .88fr;gap:56px;align-items:center}
.hero h1{color:#fff}
.hero .lead{color:#c8ded3}
.hero-badge{
  display:inline-flex;align-items:center;gap:9px;padding:8px 16px;border-radius:999px;
  background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.22);
  font-size:13px;font-weight:700;color:#eafff5;margin-bottom:26px;backdrop-filter:blur(4px)}
.hero-badge .dot{width:8px;height:8px;border-radius:50%;background:var(--green-bright);box-shadow:0 0 0 4px rgba(36,184,126,.25)}
.hero .btn-primary{background:var(--green-bright);color:#04201c}
.hero .btn-primary:hover{background:#2cc488;transform:translateY(-2px)}
.hero .btn-ghost{border-color:rgba(255,255,255,.32);color:#fff;background:transparent}
.hero .btn-ghost:hover{border-color:#fff;color:#fff;background:rgba(255,255,255,.08)}
.hero h1{margin-bottom:24px}
.hero .lead{margin-bottom:34px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:36px}
.hero-trust{display:flex;gap:24px;flex-wrap:wrap;color:#bcd4c9;font-size:13.5px;font-weight:600}
.hero-trust span{display:flex;align-items:center;gap:8px;position:relative;padding-left:18px}
.hero-trust span::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:7px;height:7px;border-radius:50%;background:var(--green-bright)}
.hero-visual{position:relative}
.hero-card{
  background:var(--dark);
  border-radius:var(--radius-lg);padding:34px;
  box-shadow:var(--shadow);position:relative;overflow:hidden;color:#fff
}
/* glass treatment only inside the dark hero */
.hero .hero-card{
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.18);backdrop-filter:blur(8px);
  box-shadow:0 30px 70px -30px rgba(0,0,0,.5)
}
.hero-card::before{content:"";position:absolute;width:240px;height:240px;border-radius:50%;background:radial-gradient(circle,rgba(31,158,106,.5),transparent 70%);top:-90px;right:-70px}
.hero-card-inner{position:relative}
.hero-card h3{font-family:var(--font);font-size:13px;color:#9fc6b5;font-weight:700;letter-spacing:.14em;text-transform:uppercase;margin-bottom:22px}
.hero-stat-row{display:flex;align-items:baseline;gap:14px;padding:16px 0;border-bottom:1px solid rgba(255,255,255,.12)}
.hero-stat-row:last-child{border-bottom:none}
.hero-stat-row .num{font-family:var(--display);font-size:30px;font-weight:800;color:#fff;flex:none;white-space:nowrap}
.hero-stat-row .lbl{font-size:13.5px;color:#bcd4c9;line-height:1.4}

/* ---------- Stats band ---------- */
.stats{display:grid;grid-template-columns:repeat(5,1fr);gap:0;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;background:#fff;box-shadow:0 34px 70px -38px rgba(11,51,39,.45)}
.stats-lift{margin-top:-66px;position:relative;z-index:3;padding-top:0}
.stat{padding:30px 22px;text-align:center;border-right:1px solid var(--border);transition:background .25s}
.stat:last-child{border-right:none}
.stat:hover{background:var(--bg-2)}
.stat .num{font-family:var(--display);font-size:clamp(28px,3vw,38px);font-weight:800;color:var(--green)}
.stat .lbl{font-size:12.5px;color:var(--text-soft);margin-top:8px;line-height:1.4}

/* ---------- Cards / services ---------- */
.cards{display:grid;gap:22px}
.cards-3{grid-template-columns:repeat(3,1fr)}
.cards-2{grid-template-columns:repeat(2,1fr)}
.card{
  background:rgba(255,255,255,.93);border:1px solid rgba(196,216,206,.85);border-radius:var(--radius);
  padding:32px;transition:transform .25s,border-color .25s,box-shadow .25s;position:relative;overflow:hidden
}
.card::before{content:"";position:absolute;top:0;left:0;width:100%;height:3px;background:var(--green);transform:scaleX(0);transform-origin:left;transition:transform .3s;z-index:2}
.card::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(145deg,rgba(255,255,255,.55),transparent 34%,rgba(184,137,63,.055) 100%);
  opacity:.78;z-index:0}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--border)}
.card:hover::before{transform:scaleX(1)}
.card>*{position:relative;z-index:1}
.card-icon{
  width:54px;height:54px;border-radius:12px;background:var(--grad-soft);
  display:grid;place-items:center;margin-bottom:20px;color:var(--green)
}
.card-icon svg{width:26px;height:26px}
.card h3{font-family:var(--font);font-size:18.5px;font-weight:800;margin-bottom:10px;line-height:1.3}
.card p{font-size:14.5px;color:var(--text-soft)}
.card-link{display:inline-flex;align-items:center;gap:7px;margin-top:18px;font-weight:700;font-size:14px;color:var(--green)}
.card-link svg{transition:transform .2s}
.card:hover .card-link svg{transform:translateX(4px)}

/* ---------- Steps ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.step{background:rgba(255,255,255,.94);border:1px solid rgba(196,216,206,.85);border-radius:var(--radius);padding:30px;position:relative;overflow:hidden;transition:transform .25s,box-shadow .25s,border-color .25s}
.step::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(220px 120px at 88% 0%,rgba(31,158,106,.09),transparent 70%),
    linear-gradient(145deg,rgba(255,255,255,.35),transparent 42%);
  opacity:.9;z-index:0}
.step-visual{display:flex;align-items:center;margin-bottom:20px}
.step .n{font-family:var(--display);font-size:15px;font-weight:800;width:42px;height:42px;border-radius:10px;background:var(--green);color:#fff;display:grid;place-items:center;margin:0 -8px 0 0;position:relative;z-index:1;box-shadow:0 10px 22px -12px rgba(23,123,87,.65)}
.step-icon{width:68px;height:52px;border-radius:14px;background:var(--grad-soft);color:var(--green);display:grid;place-items:center;padding-left:8px;position:relative;overflow:hidden}
.step-icon::before{content:"";position:absolute;inset:auto -16px -20px auto;width:50px;height:50px;border-radius:50%;background:currentColor;opacity:.08}
.step-icon svg{width:28px;height:28px;position:relative;z-index:1}
.step:nth-child(6n+2) .step-icon{background:#e6f6f8;color:#0e7490}
.step:nth-child(6n+3) .step-icon{background:#eef0ff;color:#4338ca}
.step:nth-child(6n+4) .step-icon{background:#fff4df;color:#b45309}
.step:nth-child(6n+5) .step-icon{background:#e9f4ee;color:#0f766e}
.step:nth-child(6n+6) .step-icon{background:#eaf0ed;color:var(--green-dark)}
.step h3{font-family:var(--font);font-size:17px;font-weight:800;margin-bottom:8px}
.step p{font-size:14px;color:var(--text-soft)}
.step>*{position:relative;z-index:1}
.step:hover{transform:translateY(-4px);box-shadow:var(--shadow-sm);border-color:rgba(23,123,87,.28)}

/* ---------- About / feature split ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.feature-list{display:grid;gap:18px;margin-top:30px}
.feature-item{display:flex;gap:16px;align-items:flex-start}
.feature-item .ic{flex:none;width:44px;height:44px;border-radius:11px;background:var(--grad-soft);display:grid;place-items:center;color:var(--green)}
.feature-item h4{font-size:16px;font-weight:800;margin-bottom:4px}
.feature-item p{font-size:14px;color:var(--text-soft)}

/* ---------- Testimonials ---------- */
.testimonials{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.quote{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:32px;position:relative}
.quote .mark{font-family:var(--display);font-size:54px;line-height:.6;color:var(--green);opacity:.5;margin-bottom:12px}
.quote p{font-size:15px;color:var(--text);margin-bottom:22px}
.quote .author{display:flex;align-items:center;gap:13px}
.quote .avatar{width:46px;height:46px;border-radius:50%;background:var(--green);display:grid;place-items:center;color:#fff;font-weight:800;font-size:17px}
.quote .author b{display:block;font-size:14.5px}
.quote .author span{font-size:12.5px;color:var(--text-mute)}

/* ---------- Logos / partners ---------- */
.logos{display:grid;grid-template-columns:repeat(6,1fr);gap:16px}
.logo-chip{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);height:92px;display:grid;place-items:center;padding:14px;text-align:center;font-weight:700;font-size:14px;color:var(--text-soft);transition:.25s}
.logo-chip:hover{border-color:var(--green);color:var(--green)}

/* ---------- CTA band ---------- */
.cta-band{position:relative;border-radius:var(--radius-lg);overflow:hidden;padding:64px;background:linear-gradient(135deg,#f8fbf9 0%,#e7f2ec 100%);border:1px solid var(--border)}
.cta-band::before{content:"";position:absolute;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle,rgba(31,158,106,.18),transparent 70%);top:-160px;right:-110px}
.cta-band-inner{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:40px;flex-wrap:wrap}
.cta-band h2{margin-bottom:12px;max-width:18ch;color:var(--text)}
.cta-band p{color:var(--text-soft);max-width:46ch}
.cta-band .btn-primary{background:var(--green);color:#fff}
.cta-band .btn-primary:hover{background:var(--green-dark)}

/* ---------- Forms ---------- */
.form-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:38px;box-shadow:var(--shadow-sm)}
.field{margin-bottom:18px}
.field label{display:block;font-size:13.5px;font-weight:700;color:var(--text-soft);margin-bottom:8px}
.field input,.field textarea,.field select{
  width:100%;padding:13px 16px;background:#fff;border:1px solid var(--border-strong);
  border-radius:var(--radius-sm);color:var(--text);font-size:15px;transition:border-color .2s,box-shadow .2s
}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(23,123,87,.12)}
.field textarea{resize:vertical;min-height:120px}
.form-note{font-size:12.5px;color:var(--text-mute);margin-top:6px}

/* ---------- Page hero (inner pages) ---------- */
.page-hero{padding:64px 0 20px;position:relative;overflow:hidden}
.page-hero::before{content:"";position:absolute;inset:-40px 0 auto;height:260px;pointer-events:none;
  background:
    radial-gradient(620px 220px at 78% 0%,rgba(31,158,106,.12),transparent 70%),
    radial-gradient(520px 220px at 18% 28%,rgba(184,137,63,.09),transparent 68%),
    linear-gradient(118deg,transparent 0 58%,rgba(23,123,87,.07) 58.15%,transparent 58.45%)}
.page-hero .container{position:relative;z-index:1}
.breadcrumbs{display:flex;gap:8px;align-items:center;font-size:13px;color:var(--text-mute);margin-bottom:20px}
.breadcrumbs a:hover{color:var(--green)}

/* ---------- Article / blog ---------- */
.post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.post{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:transform .25s,border-color .25s,box-shadow .25s;display:flex;flex-direction:column}
.post:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--border)}
.post-thumb{height:170px;background:var(--dark);display:grid;place-items:center;font-family:var(--display);font-size:40px;color:rgba(255,255,255,.18);position:relative;overflow:hidden}
.post-thumb .tag{position:absolute;top:14px;left:14px;padding:5px 12px;border-radius:999px;font-size:11.5px;font-weight:700;background:#fff;color:var(--green);border:1px solid var(--border)}
.post-body{padding:24px;display:flex;flex-direction:column;flex:1}
.post-meta{font-size:12.5px;color:var(--text-mute);margin-bottom:10px;display:flex;gap:12px}
.post h3{font-family:var(--font);font-size:18px;font-weight:800;line-height:1.32;margin-bottom:10px}
.post p{font-size:14px;color:var(--text-soft);margin-bottom:18px;flex:1}
.filter-bar{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:36px}
.chip{padding:9px 18px;border-radius:999px;border:1px solid var(--border-strong);font-size:14px;font-weight:600;color:var(--text-soft);transition:.2s;background:#fff}
.chip:hover{border-color:var(--green);color:var(--green)}
.chip.active{background:var(--green);color:#fff;border-color:var(--green)}

/* Article body */
.article{max-width:760px;margin:0 auto}
.article-head{margin-bottom:36px}
.article-head .post-meta{font-size:14px;margin-bottom:18px}
.article-body{font-size:17px;color:var(--text-soft);line-height:1.8}
.article-body h2{font-family:var(--display);font-size:26px;color:var(--text);margin:38px 0 16px}
.article-body h3{font-size:21px;color:var(--text);margin:30px 0 12px}
.article-body p{margin-bottom:20px}
.article-body ul{list-style:disc;padding-left:24px;margin-bottom:20px}
.article-body li{margin-bottom:8px}
.article-body blockquote{border-left:3px solid var(--green);padding:8px 22px;margin:24px 0;background:var(--bg-2);border-radius:0 10px 10px 0;color:var(--text)}
.article-body a{color:var(--green);text-decoration:underline}

/* ---------- Materials / downloads ---------- */
.material{display:flex;align-items:center;gap:20px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:22px 26px;transition:.25s}
.material:hover{border-color:var(--green);box-shadow:var(--shadow-sm);transform:translateX(4px)}
.material .ftype{flex:none;width:54px;height:54px;border-radius:11px;background:var(--grad-soft);display:grid;place-items:center;font-weight:800;font-size:13px;color:var(--green)}
.material .info{flex:1}
.material .info h3{font-family:var(--font);font-size:16.5px;font-weight:800;margin-bottom:4px}
.material .info p{font-size:13.5px;color:var(--text-soft)}
.material .meta{font-size:12px;color:var(--text-mute);margin-top:4px}
.materials-list{display:grid;gap:16px}

/* ---------- News / NPA ---------- */
.news-item{display:grid;grid-template-columns:130px 1fr;gap:24px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:28px;transition:.25s}
.news-item:hover{border-color:var(--green);box-shadow:var(--shadow-sm)}
.news-date{font-family:var(--display);font-weight:800}
.news-date .d{font-size:34px;color:var(--text)}
.news-date .m{font-size:13px;color:var(--green);text-transform:uppercase;letter-spacing:.06em}
.news-item .tag{display:inline-block;padding:4px 11px;border-radius:999px;font-size:11.5px;font-weight:700;background:var(--grad-soft);color:var(--green);margin-bottom:10px}
.news-item h3{font-family:var(--font);font-size:18px;font-weight:800;margin-bottom:8px}
.news-item p{font-size:14.5px;color:var(--text-soft)}

/* ---------- Contacts ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px}
.contact-info{display:grid;gap:22px}
.contact-row{display:flex;gap:16px;align-items:flex-start}
.contact-row .ic{flex:none;width:48px;height:48px;border-radius:11px;background:var(--grad-soft);display:grid;place-items:center;color:var(--green)}
.contact-row h4{font-size:13px;color:var(--text-mute);font-weight:700;margin-bottom:4px;text-transform:uppercase;letter-spacing:.06em}
.contact-row p,.contact-row a{font-size:16px;font-weight:600}
.contact-row a:hover{color:var(--green)}
.map-wrap{border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);min-height:300px}
.map-wrap iframe{width:100%;height:100%;min-height:340px;border:0}

/* ---------- Team ---------- */
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.team-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:30px;text-align:center;transition:.25s}
.team-card:hover{box-shadow:var(--shadow-sm)}
.team-card .badge{width:64px;height:64px;border-radius:50%;background:var(--grad-soft);display:grid;place-items:center;margin:0 auto 16px;color:var(--green)}
.team-card h3{font-family:var(--font);font-size:16px;font-weight:800;margin-bottom:6px}
.team-card p{font-size:13.5px;color:var(--text-soft)}

/* ---------- Footer (dark green) ---------- */
.footer{background:linear-gradient(155deg,#146b4e 0%,#0f5a42 100%);color:#e4f0ea;padding:66px 0 30px;margin-top:0}
.footer .logo{margin-bottom:18px;color:#fff}
.footer .logo .mark{background:#fff;color:var(--green)}
.footer .logo small{color:#7fa595}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:40px;margin-bottom:44px}
.footer-about{font-size:14px;color:#9fc0b2;max-width:34ch}
.footer h4{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:#7fa595;margin-bottom:18px;font-family:var(--font);font-weight:800}
.footer-links{display:grid;gap:11px}
.footer-links a{font-size:14.5px;color:#cdddd5}
.footer-links a:hover{color:#fff}
.footer-social{display:flex;gap:12px;margin-top:18px}
.footer-social a{width:42px;height:42px;border-radius:10px;border:1px solid rgba(255,255,255,.18);display:grid;place-items:center;color:#cdddd5;transition:.25s}
.footer-social a:hover{border-color:#fff;color:#fff;background:rgba(255,255,255,.06);transform:translateY(-3px)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.14);padding-top:24px;display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;font-size:13px;color:#7fa595}

/* ---------- Modal ---------- */
.modal-overlay{position:fixed;inset:0;background:rgba(11,51,39,.45);backdrop-filter:blur(4px);z-index:200;display:none;align-items:center;justify-content:center;padding:24px}
.modal-overlay.open{display:flex}
.modal{background:#fff;border-radius:var(--radius-lg);padding:38px;max-width:460px;width:100%;position:relative;box-shadow:0 40px 80px -30px rgba(11,51,39,.4)}
.modal h3{font-size:24px;margin-bottom:8px}
.modal p{color:var(--text-soft);font-size:14.5px;margin-bottom:24px}
.modal-close{position:absolute;top:18px;right:18px;width:38px;height:38px;border-radius:9px;border:1px solid var(--border);display:grid;place-items:center;color:var(--text-soft)}
.modal-close:hover{color:var(--text);border-color:var(--green)}

/* ---------- WhatsApp float ---------- */
.wa-float{position:fixed;bottom:24px;right:24px;z-index:90;width:58px;height:58px;border-radius:50%;background:#25d366;display:grid;place-items:center;box-shadow:0 12px 30px -8px rgba(37,211,102,.55);transition:transform .2s}
.wa-float:hover{transform:scale(1.08)}
.wa-float svg{width:30px;height:30px;color:#fff}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ---------- Toast ---------- */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(120px);background:var(--dark);border:1px solid var(--dark-2);color:#fff;padding:14px 24px;border-radius:999px;font-weight:600;font-size:14.5px;z-index:300;transition:transform .35s;box-shadow:var(--shadow)}
.toast.show{transform:translateX(-50%) translateY(0)}

/* ---------- Utility ---------- */
.muted{color:var(--text-mute)}
.empty-state{text-align:center;padding:60px 20px;color:var(--text-mute);border:1px dashed var(--border-strong);border-radius:var(--radius);background:var(--bg-2)}
.divider{height:1px;background:var(--border);margin:0}
.tag-pill{display:inline-block;padding:5px 13px;border-radius:999px;font-size:12px;font-weight:700;background:var(--grad-soft);color:var(--green)}

/* ---------- Animated background scene ---------- */
#bgScene{position:fixed;inset:0;z-index:-1;pointer-events:none}
@keyframes heroGlowDrift{0%,100%{transform:translate3d(0,0,0) scale(1)}50%{transform:translate3d(-2.5%,2.2%,0) scale(1.06)}}
.hero::before{animation:heroGlowDrift 16s ease-in-out infinite}

/* ---------- Design polish ---------- */
.scroll-progress{position:fixed;top:0;left:0;height:3px;width:0;background:var(--grad);z-index:300;transition:width .12s linear;box-shadow:0 0 12px rgba(31,158,106,.5)}

/* decorative glow behind hero visual */
.hero-visual{position:relative}
.hero-visual::before{content:"";position:absolute;inset:-40px -30px -40px 30px;background:radial-gradient(440px 340px at 72% 28%,rgba(31,158,106,.12),transparent 70%);z-index:-1;pointer-events:none}

/* subtle dot texture on dark blocks */
.hero-card{background-image:radial-gradient(rgba(255,255,255,.06) 1px,transparent 1px);background-size:22px 22px}
.cta-band{background-image:radial-gradient(rgba(23,123,87,.07) 1px,transparent 1px),linear-gradient(135deg,#f8fbf9 0%,#e7f2ec 100%);background-size:22px 22px,auto}
.footer{background-image:radial-gradient(rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(155deg,#146b4e 0%,#0f5a42 100%);background-size:24px 24px,auto}

/* floating accent badge on hero */
.hero-float{position:absolute;left:-20px;bottom:-26px;display:flex;align-items:center;gap:13px;background:#fff;border:1px solid var(--border);border-radius:14px;padding:14px 20px 14px 16px;box-shadow:var(--shadow);max-width:260px;z-index:2}
.hero-float .ic{width:42px;height:42px;border-radius:10px;background:var(--green);color:#fff;display:grid;place-items:center;flex:none}
.hero-float .ic svg{width:22px;height:22px}
.hero-float b{display:block;font-size:13.5px;line-height:1.25;color:var(--text)}
.hero-float span{font-size:12px;color:var(--text-mute)}

/* card icon fills on hover */
.card-icon{transition:background .28s,color .28s,transform .28s}
.card:hover .card-icon{transform:scale(1.08) rotate(-3deg)}
.step .n,.step-icon{transition:transform .25s}
.step:hover .n{transform:translateY(-3px)}
.step:hover .step-icon{transform:translateY(-3px)}

/* partner marquee */
.marquee{overflow:hidden;position:relative;-webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
.marquee-track{display:flex;gap:16px;width:max-content;animation:gxp-marquee 40s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee .logo-chip{flex:none;width:190px}
@keyframes gxp-marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.marquee-track{animation:none}.reveal{transition:none}.hero::before{animation:none}}

/* ---------- Responsive ---------- */
@media (max-width:1240px){
  .nav-phone{display:none}
  .nav-links a{font-size:13.5px;padding:9px 9px}
}
@media (max-width:1040px){
  .stats{grid-template-columns:repeat(3,1fr);border:none;gap:14px;background:transparent}
  .stat{border:1px solid var(--border);border-radius:var(--radius)}
  .cards-3,.steps,.testimonials,.post-grid{grid-template-columns:repeat(2,1fr)}
  .logos{grid-template-columns:repeat(4,1fr)}
  .team-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:860px){
  .section{padding:72px 0}
  .hero-grid,.split,.contact-grid{grid-template-columns:1fr}
  .hero-visual{order:-1}
  .nav-links,.nav-phone{display:none}
  .nav-links.mobile-open{display:flex;position:fixed;top:74px;left:0;right:0;bottom:0;flex-direction:column;background:#fff;padding:24px;gap:6px;border-top:1px solid var(--border);z-index:99}
  .nav-links.mobile-open a{font-size:18px;padding:14px}
  .burger{display:grid}
  .cta-band{padding:40px 28px}
  .hero-float{display:none}
}
@media (max-width:560px){
  .container{padding:0 18px}
  .stats,.cards-3,.cards-2,.steps,.testimonials,.post-grid,.logos,.team-grid,.footer-grid{grid-template-columns:1fr}
  .news-item{grid-template-columns:1fr;gap:14px}
  .section{padding:56px 0}
  .cta-band-inner{flex-direction:column;align-items:flex-start}
  .h-xl{font-size:clamp(32px,9vw,44px)}
}

/* ============================================================
   Premium polish v2 — motion, depth & accessibility
   ============================================================ */

/* keyboard focus visibility */
a:focus-visible,button:focus-visible,input:focus-visible,
textarea:focus-visible,select:focus-visible{
  outline:2px solid var(--green);outline-offset:3px;border-radius:6px}
.hero a:focus-visible,.hero button:focus-visible{outline-color:#eafff5}

/* hero card breathes gently */
.hero-visual{animation:heroFloatY 8s ease-in-out infinite;will-change:transform}
@keyframes heroFloatY{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}

/* primary button light sweep on hover */
.btn-primary{position:relative;overflow:hidden;isolation:isolate}
.btn-primary::after{content:"";position:absolute;inset:0 auto 0 -130%;width:55%;
  background:linear-gradient(110deg,transparent,rgba(255,255,255,.4),transparent);
  transform:skewX(-18deg);transition:left .65s cubic-bezier(.2,.7,.2,1);z-index:-1}
.btn-primary:hover::after{left:150%}

/* arrow nudges on primary CTAs that carry one */
.btn svg{transition:transform .2s}
.btn:hover svg{transform:translateX(3px)}

/* nav links: animated underline + cleaner active state */
.nav-links a{position:relative}
.nav-links a::after{content:"";position:absolute;left:11px;right:11px;bottom:5px;height:2px;
  background:var(--green);border-radius:2px;transform:scaleX(0);transform-origin:left;
  transition:transform .26s cubic-bezier(.2,.7,.2,1)}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1)}
.nav-links a.active{box-shadow:none}

/* reveal: optional scale variant + slightly springier base */
.reveal{transition:opacity .8s cubic-bezier(.16,.84,.28,1),transform .8s cubic-bezier(.16,.84,.28,1)}
.reveal.r-scale{transform:translateY(26px) scale(.97)}
.reveal.r-scale.in{transform:none}

/* cards: deeper, warmer lift */
.card:hover,.post:hover{box-shadow:0 28px 56px -30px rgba(11,51,39,.42)}

/* eyebrow dash animates subtly when its section reveals */
.section-head.center .eyebrow{justify-content:center}

@media (prefers-reduced-motion:reduce){
  .hero-visual{animation:none}
  .btn-primary::after{display:none}
}

/* ---------- Brand logo mark (rotating ornament) ---------- */
.logo .logo-mark{width:48px;height:48px;flex:none;display:block;color:var(--green)}
.logo .logo-mark .logo-svg{width:100%;height:100%;display:block}
.logo-ring{transform-box:view-box;transform-origin:50px 50px;animation:gxpSpin 16s linear infinite}
@keyframes gxpSpin{to{transform:rotate(360deg)}}
.footer .logo .logo-mark{color:#fff}
@media (prefers-reduced-motion:reduce){.logo-ring{animation:none}}

/* ---------- Centered hero (single column) ---------- */
.hero-grid.hero-centered{grid-template-columns:1fr;max-width:880px;margin:0 auto;text-align:center}
.hero-centered .hero-badge{margin-left:auto;margin-right:auto}
.hero-centered .lead{margin-left:auto;margin-right:auto}
.hero-centered .hero-cta{justify-content:center}
.hero-centered .hero-trust{justify-content:center}

/* ---------- Slogan badge on two lines (left) ---------- */
.hero .hero-badge{max-width:320px;white-space:normal;align-items:flex-start}
.hero .hero-badge .dot{margin-top:6px;flex:none}
.hero .hero-badge>span:last-child{line-height:1.35;text-align:left}

/* ---------- Big animated hero logo ---------- */
.hero-logo{display:flex;justify-content:center;align-items:center}
.hero-logo-svg{width:min(400px,78%);height:auto;
  filter:drop-shadow(0 24px 60px rgba(0,0,0,.4))}
.ring-outer{transform-box:view-box;transform-origin:100px 100px;animation:gxpSpinCW 26s linear infinite}
.ring-inner{transform-box:view-box;transform-origin:100px 100px;animation:gxpSpinCCW 18s linear infinite}
@keyframes gxpSpinCW{to{transform:rotate(360deg)}}
@keyframes gxpSpinCCW{to{transform:rotate(-360deg)}}
@media (prefers-reduced-motion:reduce){.ring-outer,.ring-inner{animation:none}}
@media (max-width:860px){
  .hero-logo{order:-1;margin-bottom:6px}
  .hero-logo-svg{width:230px}
  .hero-logo-img{width:200px}
}
/* real uploaded logo image */
.hero-logo-img{width:min(360px,76%);height:auto;display:block;
  filter:drop-shadow(0 22px 55px rgba(0,0,0,.4))}
.hero-logo.logo-missing{display:none}

/* ---------- Stacked hero: logo on top, centered text ---------- */
.hero-grid.hero-stack{grid-template-columns:1fr;max-width:840px;margin:0 auto;text-align:center;gap:0}
.hero-stack .hero-logo{margin:0 auto 12px;justify-content:center}
.hero-stack .hero-logo-svg,.hero-stack .hero-logo-img{width:160px}
.hero-stack .hero-badge{margin-left:auto;margin-right:auto}
.hero-stack .lead{margin-left:auto;margin-right:auto}
.hero-stack .hero-cta{justify-content:center}
.hero-stack .hero-trust{justify-content:center}
@media (max-width:860px){
  .hero-stack .hero-logo-svg,.hero-stack .hero-logo-img{width:128px}
}
/* slogan kicker pinned to the top-left of the hero */
.hero-kicker{margin:0 0 6px 0;align-self:flex-start}

/* ---------- Colorful designer service icons ---------- */
.card-icon{color:#fff;box-shadow:0 10px 22px -12px rgba(13,60,40,.5)}
.card-icon svg{filter:drop-shadow(0 1px 1px rgba(0,0,0,.12))}
.cards .card:nth-child(8n+1) .card-icon{background:linear-gradient(135deg,#10b981,#047857);box-shadow:0 12px 24px -12px rgba(16,185,129,.6)}
.cards .card:nth-child(8n+2) .card-icon{background:linear-gradient(135deg,#06b6d4,#0e7490);box-shadow:0 12px 24px -12px rgba(6,182,212,.6)}
.cards .card:nth-child(8n+3) .card-icon{background:linear-gradient(135deg,#6366f1,#4338ca);box-shadow:0 12px 24px -12px rgba(99,102,241,.6)}
.cards .card:nth-child(8n+4) .card-icon{background:linear-gradient(135deg,#f59e0b,#ea580c);box-shadow:0 12px 24px -12px rgba(245,158,11,.6)}
.cards .card:nth-child(8n+5) .card-icon{background:linear-gradient(135deg,#f43f5e,#be123c);box-shadow:0 12px 24px -12px rgba(244,63,94,.6)}
.cards .card:nth-child(8n+6) .card-icon{background:linear-gradient(135deg,#3b82f6,#1d4ed8);box-shadow:0 12px 24px -12px rgba(59,130,246,.6)}
.cards .card:nth-child(8n+7) .card-icon{background:linear-gradient(135deg,#8b5cf6,#6d28d9);box-shadow:0 12px 24px -12px rgba(139,92,246,.6)}
.cards .card:nth-child(8n+8) .card-icon{background:linear-gradient(135deg,#14b8a6,#0f766e);box-shadow:0 12px 24px -12px rgba(20,184,166,.6)}

/* hero brand lockup (text instead of logo) */
.hero-brand{display:flex;flex-direction:column;align-items:center;gap:10px;margin-bottom:26px}
.hero-brand-name{font-family:var(--display);font-weight:800;letter-spacing:-.02em;line-height:1.04;
  color:#fff;font-size:clamp(30px,4.4vw,52px)}
.hero-brand-name .g{color:var(--green-bright)}
.hero-brand-sub{font-weight:600;color:#c8ded3;line-height:1.4;max-width:34ch;
  font-size:clamp(15px,1.5vw,19px)}

/* ---------- Case studies ---------- */
.case-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:30px;
  transition:transform .25s,box-shadow .25s,border-color .25s}
.case-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.case-card .tag-pill{margin-bottom:14px}
.case-card h3{font-family:var(--font);font-size:19px;font-weight:800;margin-bottom:10px;line-height:1.3}
.case-card p{font-size:14.5px;color:var(--text-soft);margin-bottom:16px}
.case-result{border-left:3px solid var(--green);background:var(--grad-soft);
  padding:12px 16px;border-radius:0 10px 10px 0;font-size:14px;color:var(--text)}
.case-result b{color:var(--green-dark)}

/* ---------- FAQ accordion ---------- */
.faq-list{display:grid;gap:12px;max-width:820px;margin:0 auto}
.faq-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.faq-item summary{list-style:none;cursor:pointer;padding:20px 24px;font-weight:700;font-size:16.5px;
  color:var(--text);display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";font-size:26px;font-weight:500;color:var(--green);transition:transform .25s;line-height:1;flex:none}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item summary:hover{color:var(--green)}
.faq-a{padding:0 24px 22px;font-size:15px;color:var(--text-soft);line-height:1.7}

/* ============================================================
   LMS / Обучение
   ============================================================ */
.btn-sm{padding:9px 16px;font-size:13.5px}
.lms-authbar{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:28px}
#lmsAuth{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.lms-userline{font-size:14px;font-weight:700;color:var(--text-soft)}
.lms-verify-link{font-size:14px;font-weight:700;color:var(--green)}
.lms-verify-link:hover{text-decoration:underline}

/* course cards */
.course-card{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:transform .25s,box-shadow .25s,border-color .25s}
.course-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.course-top{height:120px;display:flex;align-items:center;justify-content:space-between;padding:20px 22px;color:#fff}
.course-top.free{background:linear-gradient(135deg,#10b981,#047857)}
.course-top.paid{background:linear-gradient(135deg,#0b3327,#177b57)}
.course-top svg{width:40px;height:40px;opacity:.9}
.course-price{font-weight:800;font-size:16px;background:rgba(255,255,255,.18);padding:6px 12px;border-radius:999px;white-space:nowrap}
.course-body{padding:22px 24px 26px;display:flex;flex-direction:column;flex:1}
.course-body .tag-pill{margin-bottom:12px}
.course-body h3{font-family:var(--font);font-size:18px;font-weight:800;line-height:1.3;margin-bottom:8px}
.course-body p{font-size:14px;color:var(--text-soft);flex:1;margin-bottom:16px}

/* course page */
.course-head{margin-bottom:26px}
.course-head .tag-pill{margin-bottom:14px}
.course-cta{background:var(--grad-soft);border:1px solid var(--border);border-radius:var(--radius);padding:24px;margin-bottom:30px;text-align:center}
.course-cta .form-note{margin-top:10px}
.lesson-list{display:grid;gap:14px;margin-bottom:30px}
.lesson{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.lesson.locked{opacity:.7}
.lesson-h{display:flex;align-items:center;gap:14px;padding:18px 22px}
.lesson-n{flex:none;width:34px;height:34px;border-radius:9px;background:var(--green);color:#fff;display:grid;place-items:center;font-weight:800;font-size:14px}
.lesson-h .grow{flex:1}
.lesson-h b{font-size:16px;font-weight:700}
.lesson-tag{font-size:11px;font-weight:700;color:var(--green);background:var(--grad-soft);padding:2px 8px;border-radius:999px;margin-left:6px}
.lesson .lock{font-size:18px}
.lesson-body{padding:0 22px 22px}
.video-wrap{position:relative;padding-top:56.25%;border-radius:10px;overflow:hidden;margin-bottom:16px;background:#000}
.video-wrap iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.lesson-content{font-size:15px;color:var(--text-soft);line-height:1.7}
.lesson-content h2{font-size:20px;color:var(--text);margin:18px 0 10px}
.lesson-content ul{list-style:disc;padding-left:22px;margin:10px 0}
.lesson-content li{margin-bottom:6px}

/* quiz */
.quiz{background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius-lg);padding:30px;margin-top:10px}
.quiz h2{margin-bottom:20px}
.quiz-q{margin-bottom:22px}
.quiz-qt{font-weight:700;font-size:16px;margin-bottom:12px}
.quiz-opt{display:flex;align-items:center;gap:10px;padding:11px 14px;border:1px solid var(--border);border-radius:10px;margin-bottom:8px;cursor:pointer;font-size:14.5px;transition:border-color .2s,background .2s}
.quiz-opt:hover{border-color:var(--green)}
.quiz-opt input{accent-color:var(--green);width:18px;height:18px}
.quiz-pass{margin-top:20px;background:var(--grad-soft);border:1px solid var(--green);border-radius:var(--radius);padding:22px;text-align:center}
.quiz-pass b{display:block;font-size:18px;color:var(--green-dark);margin-bottom:6px}
.quiz-pass .btn{margin-top:14px}
.quiz-fail{margin-top:20px;background:#fdecec;border:1px solid #f3b4b4;border-radius:var(--radius);padding:18px;color:#9a2a2a;font-weight:600}

/* certificate verification */
.verify-ok{background:var(--grad-soft);border:1px solid var(--green);border-radius:var(--radius);padding:24px;text-align:center}
.verify-ok b{display:block;font-size:18px;color:var(--green-dark);margin-bottom:10px}
.verify-ok .vline{font-size:20px;font-weight:800;color:var(--text)}
.verify-ok .vmeta{margin-top:8px;font-size:13px;color:var(--text-mute)}
.verify-bad{background:#fdecec;border:1px solid #f3b4b4;border-radius:var(--radius);padding:22px;text-align:center;color:#9a2a2a;font-weight:700}

/* ---------- Premium light background refresh ---------- */
.section[style*="var(--bg-2)"]{
  background:
    radial-gradient(760px 320px at 82% 0%,rgba(31,158,106,.10),transparent 72%),
    radial-gradient(560px 280px at 12% 18%,rgba(184,137,63,.08),transparent 70%),
    linear-gradient(180deg,#edf7f2 0%,#f6fbf8 100%) !important
}

.stats,.quote,.logo-chip,.material,.news-item,.team-card,.case-card,
.faq-item,.course-card,.lesson,.quiz,.course-cta,.verify-ok,.form-card{
  background:rgba(255,255,255,.93);
  border-color:rgba(196,216,206,.85);
  box-shadow:0 18px 56px -44px rgba(13,60,40,.30)
}

.cta-band{
  border-color:rgba(196,216,206,.95);
  box-shadow:0 30px 70px -46px rgba(13,60,40,.36);
  background-image:
    radial-gradient(rgba(23,123,87,.07) 1px,transparent 1px),
    radial-gradient(420px 260px at 88% 0%,rgba(31,158,106,.18),transparent 72%),
    radial-gradient(360px 220px at 12% 100%,rgba(184,137,63,.12),transparent 72%),
    linear-gradient(135deg,#ffffff 0%,#e9f5ee 100%);
  background-size:22px 22px,auto,auto,auto
}
.cta-band::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(118deg,transparent 0 66%,rgba(255,255,255,.42) 66.15%,transparent 66.6%)}

.footer{
  background-image:
    radial-gradient(rgba(255,255,255,.04) 1px,transparent 1px),
    radial-gradient(620px 340px at 88% 0%,rgba(31,158,106,.20),transparent 70%),
    linear-gradient(155deg,#125f48 0%,#0e4c3a 100%);
  background-size:24px 24px,auto,auto
}
