/**
 * Homepage — d314.io v5
 * Préfixe hp- | Palette indigo | Plus Jakarta Sans + JetBrains Mono
 */

/* ============================================================
   FIX ELEMENTOR
   ============================================================ */
body.home { padding-top: 0 !important; }
.hp-page, .homepage-container { margin-top: 0 !important; }
.elementor,.elementor-section,.elementor-top-section,
.elementor-location-header ~ *,main,#content {
    margin-top: 0 !important; padding-top: 0 !important;
}

/* ============================================================
   VARIABLES
   ============================================================ */
:root {
    --hp-bg:      var(--bg-primary);
    --hp-bg2:     var(--bg-secondary);
    --hp-surface: var(--surface-card);
    --hp-surf2:   var(--bg-secondary);
    --hp-indigo:  var(--primary-color);
    --hp-indigo2: var(--primary-dark);
    --hp-indigol: var(--primary-hover);
    --hp-indigop: #a5b4fc;
    --hp-cyan:    var(--accent-phys);
    --hp-text:    var(--text-primary);
    --hp-textm:   var(--text-secondary);
    --hp-textd:   var(--text-muted);
    --hp-green:   var(--success-color);
    --hp-border:  var(--border-subtle);
    --hp-borderi: rgba(99,102,241,0.18);
    --hp-font:    var(--font-family-primary);
    --hp-mono:    var(--font-family-mono);
    --hp-tr:      var(--transition-normal);
}

/* ============================================================
   BASE
   ============================================================ */
.hp-page {
    width: 100%; background: var(--hp-bg);
    overflow-x: hidden; font-family: var(--hp-font);
    color: var(--hp-text); -webkit-font-smoothing: antialiased;
}
.hp-grid-bg {
    position: fixed; inset: 0; z-index: 0; pointer-events: none;
    background-image:
        linear-gradient(rgba(99,102,241,.04) 1px,transparent 1px),
        linear-gradient(90deg,rgba(99,102,241,.04) 1px,transparent 1px);
    background-size: 50px 50px;
}
.hp-grad-overlay {
    position: fixed; top:0; left:0; width:100%; height:600px;
    z-index:0; pointer-events:none;
    background: radial-gradient(ellipse at top,rgba(99,102,241,.10),transparent 60%);
}

.hp-inner         { max-width:1100px; margin:0 auto; }
.hp-inner--narrow { max-width:760px;  margin:0 auto; }
.hp-inner--medium { max-width:960px;  margin:0 auto; }

.hp-section-head { margin-bottom:56px; }
.hp-section-head--center { text-align:center; }
.hp-section-head--split {
    display:flex; justify-content:space-between;
    align-items:flex-end; gap:24px;
}
.hp-label {
    display:inline-block; font-family:var(--hp-mono);
    font-size:var(--font-size-xs); font-weight:var(--font-weight-medium); letter-spacing:.18em;
    text-transform:uppercase; color:var(--hp-indigol); margin-bottom:14px;
}
.hp-section-title {
    font-size:clamp(26px,4vw,44px) !important; font-weight:var(--font-weight-extrabold) !important;
    font-family:var(--font-family-primary) !important;
    letter-spacing:-.03em; line-height:1.1;
    color:var(--hp-text); margin-bottom:14px;
}
.hp-section-desc { font-size:var(--text-base); color:var(--hp-textm); line-height:1.6; max-width:500px; }
.hp-section-head--center .hp-section-desc { margin:0 auto; }

.hp-gradient-text {
    background:linear-gradient(135deg,#6366f1 0%,#22d3ee 100%);
    -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}

@keyframes hp-fadein    { from{opacity:0;transform:translateY(28px)} to{opacity:1;transform:translateY(0)} }
@keyframes hp-bounce    { 0%,100%{transform:translateX(-50%) translateY(0)} 50%{transform:translateX(-50%) translateY(7px)} }
@keyframes hp-dot-pulse { 0%{box-shadow:0 0 0 0 rgba(99,102,241,.7)} 70%{box-shadow:0 0 0 8px rgba(99,102,241,0)} 100%{box-shadow:0 0 0 0 rgba(99,102,241,0)} }
@keyframes hp-gi        { 0%,100%{opacity:.18;transform:translateX(-50%) scale(1)} 50%{opacity:.28;transform:translateX(-50%) scale(1.08)} }
@keyframes hp-gc        { 0%,100%{opacity:.08} 50%{opacity:.16} }

/* Boutons homepage — surcharge globale .btn pour sizing spécifique */
.hp-page .btn { padding:13px 26px !important; font-size:14.5px !important; border-radius:9px !important; }

/* ============================================================
   1. HERO
   ============================================================ */
.hp-hero {
    position:relative; min-height:100vh; background:var(--hp-bg);
    display:flex; align-items:center; justify-content:center;
    padding:140px 40px 100px; overflow:hidden; z-index:1;
}
.hp-hero-glow { position:absolute; border-radius:50%; pointer-events:none; filter:blur(90px); }
.hp-hero-glow--indigo { width:700px; height:700px; background:radial-gradient(circle,#6366f1,transparent 70%); top:-200px; left:50%; transform:translateX(-50%); opacity:.18; animation:hp-gi 8s ease-in-out infinite; }
.hp-hero-glow--cyan   { width:400px; height:400px; background:radial-gradient(circle,#22d3ee,transparent 70%); top:40%; right:5%; opacity:.08; animation:hp-gc 10s ease-in-out infinite; }
.hp-grain { position:absolute; inset:0; pointer-events:none; z-index:1; opacity:.025; background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); background-size:200px 200px; }

.hp-hero-wrap { position:relative; z-index:10; max-width:820px; width:100%; text-align:center; animation:hp-fadein .9s cubic-bezier(.4,0,.2,1) both; }

.hp-badge { all:unset !important; display:inline-flex !important; align-items:center !important; gap:8px !important; padding:6px 14px 6px 10px !important; background:rgba(99,102,241,.10) !important; border:1px solid rgba(99,102,241,.28) !important; border-radius:20px !important; font-size:12.5px !important; font-family:var(--hp-font) !important; color:var(--hp-indigop) !important; font-weight:var(--font-weight-medium) !important; margin-bottom:36px !important; cursor:default; transition:background var(--hp-tr),border-color var(--hp-tr); animation:hp-fadein .9s .1s both; }
.hp-badge:hover { background:rgba(99,102,241,.16) !important; border-color:rgba(99,102,241,.42) !important; }
.hp-badge-dot { width:7px; height:7px; background:#6366f1; border-radius:50%; flex-shrink:0; animation:hp-dot-pulse 2.4s ease-out infinite; display:inline-block; }

.hp-hero-title { font-family:var(--hp-font) !important; font-size:clamp(38px,7.5vw,76px) !important; font-weight:var(--font-weight-extrabold) !important; line-height:1.08 !important; letter-spacing:-.035em !important; color:var(--hp-text) !important; margin:0 0 16px !important; padding:0 !important; background:none !important; -webkit-text-fill-color:var(--hp-text) !important; animation:hp-fadein .9s .15s both; }
.hp-hero-title .hp-gradient-text { -webkit-text-fill-color:transparent !important; }
.hp-hero-sub  { font-family:var(--hp-mono) !important; font-size:var(--font-size-xs) !important; font-weight:var(--font-weight-medium) !important; letter-spacing:.16em !important; text-transform:uppercase !important; color:#6366f1 !important; margin:0 0 20px !important; animation:hp-fadein .9s .2s both; }
.hp-hero-desc { font-family:var(--hp-font) !important; font-size:clamp(15px,1.8vw,18px) !important; font-weight:var(--font-weight-normal) !important; color:var(--hp-textm) !important; line-height:1.7 !important; max-width:580px; margin:0 auto 40px !important; animation:hp-fadein .9s .25s both; }

.hp-hero-cta { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; margin-bottom:28px; animation:hp-fadein .9s .3s both; }

.hp-trust { display:flex; align-items:center; justify-content:center; gap:10px; flex-wrap:wrap; margin-bottom:48px; animation:hp-fadein .9s .35s both; }
.hp-trust-item { display:flex; align-items:center; gap:6px; font-size:12.5px; font-weight:var(--font-weight-medium); color:var(--hp-textm); }
.hp-trust-sep  { width:3px; height:3px; background:var(--hp-textd); border-radius:50%; opacity:.5; display:inline-block; }

.hp-stats { display:inline-flex; align-items:center; background:rgba(28,28,46,.85); border:1px solid var(--hp-borderi); border-radius:14px; padding:18px 32px; backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px); margin-bottom:36px; animation:hp-fadein .9s .4s both; }
.hp-stat { display:flex; flex-direction:column; align-items:center; gap:4px; padding:0 28px; }
.hp-stat:first-child { padding-left:0; }
.hp-stat:last-child  { padding-right:0; }
.hp-stat-div { width:1px; height:36px; background:var(--hp-borderi); flex-shrink:0; }
.hp-stat-num { font-family:var(--hp-mono) !important; font-size:22px !important; font-weight:var(--font-weight-bold) !important; color:var(--hp-text) !important; letter-spacing:-.02em; line-height:1; }
.hp-stat-lbl { font-family:var(--hp-font) !important; font-size:var(--font-size-xs) !important; font-weight:var(--font-weight-medium) !important; color:var(--hp-textd) !important; text-transform:uppercase; letter-spacing:.08em; }

.hp-formula { font-family:var(--hp-mono) !important; font-size:var(--font-size-xs) !important; color:var(--hp-textd) !important; letter-spacing:.06em; opacity:.45; user-select:none; animation:hp-fadein .9s .45s both; }

.hp-scroll-ind { position:absolute; bottom:36px; left:50%; transform:translateX(-50%); z-index:10; color:var(--hp-textd); opacity:.35; cursor:pointer; transition:opacity var(--hp-tr); animation:hp-bounce 2.2s ease-in-out infinite; }
.hp-scroll-ind:hover { opacity:.9; }

/* ============================================================
   2. VALUE PROP
   ============================================================ */
.hp-value { position:relative; z-index:1; padding:100px 40px; background:var(--hp-bg2); border-top:1px solid var(--hp-border); }
.hp-value-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.hp-vcard { background:var(--hp-surface); border:1px solid var(--hp-border); border-radius:14px; padding:28px; position:relative; overflow:hidden; transition:border-color var(--hp-tr),transform var(--hp-tr); }
.hp-vcard::before { content:''; position:absolute; top:0; left:0; right:0; height:1px; background:linear-gradient(90deg,transparent,rgba(99,102,241,.3),transparent); opacity:0; transition:opacity var(--hp-tr); }
.hp-vcard:hover { border-color:var(--hp-borderi); transform:translateY(-2px); }
.hp-vcard:hover::before { opacity:1; }
.hp-vcard-icon { width:40px; height:40px; border-radius:10px; margin-bottom:18px; display:flex; align-items:center; justify-content:center; }
.hp-vcard-icon--indigo { background:rgba(99,102,241,.12); color:var(--hp-indigol); }
.hp-vcard-icon--cyan   { background:rgba(34,211,238,.12);  color:var(--hp-cyan); }
.hp-vcard-icon--green  { background:rgba(16,185,129,.12);  color:var(--hp-green); }
.hp-vcard-title { font-size:var(--text-base); font-weight:var(--font-weight-bold); color:var(--hp-text); margin-bottom:10px; }
.hp-vcard-desc  { font-size:var(--font-size-md); color:var(--hp-textm); line-height:1.6; }

/* ============================================================
   3. FEATURES
   ============================================================ */
.hp-features { position:relative; z-index:1; padding:100px 40px; background:var(--hp-bg); border-top:1px solid var(--hp-border); }
.hp-feat-tabs { display:flex; gap:8px; justify-content:center; flex-wrap:wrap; margin-bottom:48px; }
.hp-feat-tab { all:unset !important; cursor:pointer !important; font-family:var(--hp-mono) !important; font-size:var(--font-size-sm) !important; font-weight:var(--font-weight-semibold) !important; padding:8px 18px !important; border-radius:8px !important; color:var(--hp-textm) !important; border:1px solid var(--hp-border) !important; transition:all .15s !important; letter-spacing:.02em; box-sizing:border-box !important; }
.hp-feat-tab:hover  { color:var(--hp-text) !important; border-color:var(--hp-borderi) !important; background:rgba(99,102,241,.06) !important; }
.hp-feat-tab.active { color:var(--hp-indigop) !important; background:rgba(99,102,241,.12) !important; border-color:rgba(99,102,241,.28) !important; }

.hp-feat-panel { display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:center; }
.hp-feat-content { display:none; }
.hp-feat-content.active { display:block; }
.hp-feat-title { font-size:26px; font-weight:var(--font-weight-extrabold); letter-spacing:-.025em; color:var(--hp-text); margin-bottom:16px; }
.hp-feat-desc  { font-size:var(--font-size-sm); color:var(--hp-textm); line-height:1.7; margin-bottom:28px; }
.hp-feat-list  { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:12px; }
.hp-feat-list li { display:flex; align-items:center; gap:12px; font-size:var(--font-size-md); color:var(--hp-textm); }
.hp-feat-list li::before { content:''; width:6px; height:6px; border-radius:50%; background:var(--hp-indigo); flex-shrink:0; }

.hp-feat-mock { background:var(--hp-surface); border:1px solid var(--hp-borderi); border-radius:16px; padding:24px; display:flex; flex-direction:column; gap:14px; position:relative; overflow:hidden; }
.hp-feat-mock::after { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:linear-gradient(90deg,#6366f1,#22d3ee); }
.hp-mock-bar  { display:flex; gap:6px; align-items:center; }
.hp-mock-dot  { width:9px; height:9px; border-radius:50%; }
.hp-mock-line { height:8px; border-radius:4px; background:var(--hp-surf2); }
.hp-mock-card { background:var(--hp-surf2); border-radius:10px; padding:16px; border:1px solid var(--hp-border); }
.hp-mock-label { font-family:var(--hp-mono); font-size:10px; color:var(--hp-indigol); margin-bottom:10px; letter-spacing:.08em; text-transform:uppercase; }
.hp-mock-video { height:80px; background:linear-gradient(135deg,rgba(99,102,241,.15),rgba(34,211,238,.08)); border-radius:8px; display:flex; align-items:center; justify-content:center; margin-bottom:12px; }
.hp-mock-text  { height:8px; border-radius:4px; background:rgba(255,255,255,.06); margin-bottom:8px; }
.hp-mock-progress { height:4px; background:rgba(255,255,255,.06); border-radius:2px; margin-top:12px; }
.hp-mock-progress-fill { height:100%; border-radius:2px; background:linear-gradient(90deg,#6366f1,#818cf8); }
.hp-mock-big { font-family:var(--hp-mono); font-size:22px; font-weight:var(--font-weight-extrabold); line-height:1; }
.hp-mock-sub { font-size:var(--font-size-xs); color:var(--hp-textd); margin-top:4px; }
.hp-mock-row { display:flex; gap:10px; }
.hp-mock-row .hp-mock-card { flex:1; }

/* ============================================================
   4. COURS — utilise les parc-card de page-parcours
   ============================================================ */
.hp-courses { position:relative; z-index:1; padding:100px 40px; background:var(--hp-bg2); border-top:1px solid var(--hp-border); }
.hp-courses-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; }

/* Surcharges parc-card dans contexte homepage */
.hp-courses-grid .parc-card { cursor:pointer; font-family:var(--hp-font); }
.hp-courses-grid .parc-card-title { color:#e6e8f6; }
.hp-courses-grid .parc-card-subtitle { color:#8486a4; }
.hp-courses-grid .parc-topics li { color:#8486a4; }
.hp-courses-grid .parc-cstat-lbl { color:#4a4c68; }

/* Classes parc- non définies dans homepage.css — copiées de parcours.css */
.parc-card { background:#1c1c2e; border:1px solid rgba(255,255,255,.055); border-radius:16px; overflow:hidden; position:relative; display:flex; flex-direction:column; transition:transform .18s,border-color .18s,box-shadow .18s; font-family:var(--font-family-primary); font-size:var(--font-size-base); color:#e6e8f6; }
.parc-card:not(.unavail):hover { transform:translateY(-4px); border-color:var(--c,#6366f1); box-shadow:0 12px 40px rgba(0,0,0,.3); }
.parc-card.unavail { opacity:.52; cursor:default; }
.parc-card.unavail:hover { transform:none; border-color:rgba(255,255,255,.055); box-shadow:none; }
.parc-card-bar { height:3px; background:linear-gradient(90deg,var(--c,#6366f1),transparent); flex-shrink:0; }
.parc-card-status { position:absolute; top:16px; right:16px; z-index:3; font-family:var(--font-family-mono); font-size:9.5px; font-weight:var(--font-weight-bold); padding:3px 9px; border-radius:5px; border:1px solid; white-space:nowrap; }
.s-dispo { color:#10b981; background:rgba(16,185,129,.13); border-color:rgba(16,185,129,.35); }
.s-early { color:#f59e0b; background:rgba(245,158,11,.13);  border-color:rgba(245,158,11,.35); }
.s-soon  { color:#8486a4; background:var(--bg-secondary); border-color:rgba(255,255,255,.055); }
.parc-card-overlay { position:absolute; inset:0; z-index:5; border-radius:16px; background:rgba(13,13,25,.6); backdrop-filter:blur(2px); display:flex; align-items:center; justify-content:center; }
.parc-overlay-inner { text-align:center; }
.parc-overlay-tag { font-family:var(--font-family-mono); font-size:var(--font-size-xs); font-weight:var(--font-weight-bold); color:#8486a4; background:var(--bg-secondary); border:1px solid rgba(255,255,255,.055); padding:5px 13px; border-radius:6px; margin-bottom:7px; display:inline-flex; align-items:center; gap:6px; }
.parc-overlay-date { font-size:var(--font-size-xs); color:#4a4c68; }
.parc-card-head { padding:20px 22px 14px; display:flex; align-items:flex-start; gap:13px; }
.parc-card-ico { width:44px; height:44px; border-radius:11px; flex-shrink:0; background:var(--cb,rgba(99,102,241,.13)); border:1px solid var(--cd,rgba(99,102,241,.35)); display:flex; align-items:center; justify-content:center; color:var(--c,#6366f1); }
.parc-card-tag { font-family:var(--font-family-mono); font-size:9.5px; font-weight:var(--font-weight-bold); color:var(--c,#6366f1); text-transform:uppercase; letter-spacing:.7px; margin-bottom:4px; }
.parc-card-title    { font-size:var(--font-size-sm); font-weight:var(--font-weight-extrabold); letter-spacing:-.3px; margin-bottom:3px; color:#e6e8f6; }
.parc-card-subtitle { font-size:var(--font-size-xs); color:#8486a4; font-weight:var(--font-weight-medium); }
.parc-card-body { padding:0 22px 14px; flex:1; }
.parc-topics { list-style:none; padding:0; margin:0 0 13px; display:flex; flex-direction:column; gap:5px; }
.parc-topics li { font-size:var(--font-size-sm); color:#8486a4; display:flex; align-items:center; gap:8px; transition:color .12s,transform .12s; }
.parc-topics li::before { content:''; width:4px; height:4px; border-radius:50%; background:var(--c,#6366f1); flex-shrink:0; }
.parc-card:not(.unavail):hover .parc-topics li { color:#e6e8f6; transform:translateX(3px); }
.parc-module-tags { display:flex; flex-wrap:wrap; gap:6px; margin-bottom:14px; }
.parc-module-tags span { font-family:var(--font-family-mono); font-size:10px; font-weight:var(--font-weight-semibold); color:var(--c,#6366f1); background:var(--cb,rgba(99,102,241,.13)); border:1px solid var(--cd,rgba(99,102,241,.35)); padding:3px 9px; border-radius:5px; }
.parc-card-stats { display:grid; grid-template-columns:repeat(3,1fr); background:var(--bg-secondary); border-radius:9px; overflow:hidden; border:1px solid rgba(255,255,255,.055); }
.parc-cstat { padding:9px 0; text-align:center; border-right:1px solid rgba(255,255,255,.055); }
.parc-cstat:last-child { border-right:none; }
.parc-cstat-val { font-family:var(--font-family-mono); font-size:var(--font-size-md); font-weight:var(--font-weight-extrabold); color:var(--c,#6366f1); letter-spacing:-.5px; }
.parc-cstat-lbl { font-size:9.5px; color:#4a4c68; text-transform:uppercase; letter-spacing:.5px; margin-top:2px; font-weight:var(--font-weight-semibold); }
.parc-card-foot { padding:13px 22px; border-top:1px solid rgba(255,255,255,.055); display:flex; align-items:center; justify-content:space-between; flex-shrink:0; }
.parc-xp { font-family:var(--font-family-mono); font-size:10.5px; font-weight:var(--font-weight-bold); color:#f59e0b; }
.parc-card-btn { all:unset; box-sizing:border-box; font-family:var(--font-family-mono); font-size:var(--font-size-xs); font-weight:var(--font-weight-bold); color:var(--c,#6366f1); background:var(--cb,rgba(99,102,241,.13)); border:1px solid var(--cd,rgba(99,102,241,.35)); padding:5px 13px; border-radius:6px; cursor:pointer; text-decoration:none; display:inline-flex; align-items:center; gap:5px; transition:background .12s,border-color .12s; }
.parc-card-btn:hover { background:rgba(99,102,241,.22); }
.parc-card-btn.disabled { opacity:.35; cursor:default; pointer-events:none; }

/* ============================================================
   5. DASHBOARD PREVIEW
   ============================================================ */
.hp-demo { position:relative; z-index:1; padding:100px 40px; background:var(--hp-bg); border-top:1px solid var(--hp-border); }
.hp-dashboard-preview { background:var(--hp-surface); border:1px solid var(--hp-borderi); border-radius:20px; overflow:hidden; box-shadow:0 40px 100px rgba(0,0,0,.5); }
.hp-dp-topbar { height:44px; background:var(--hp-bg2); border-bottom:1px solid var(--hp-border); display:flex; align-items:center; gap:8px; padding:0 20px; }
.hp-dp-dot   { width:10px; height:10px; border-radius:50%; }
.hp-dp-title { font-family:var(--hp-mono); font-size:var(--font-size-xs); color:var(--hp-textd); margin-left:8px; letter-spacing:.05em; }
.hp-dp-body  { display:grid; grid-template-columns:200px 1fr; min-height:420px; }
.hp-dp-sidebar { background:var(--hp-bg2); border-right:1px solid var(--hp-border); padding:16px 10px; display:flex; flex-direction:column; gap:4px; }
.hp-dp-sitem { display:flex; align-items:center; gap:10px; padding:8px 12px; border-radius:8px; cursor:pointer; font-size:12.5px; font-weight:var(--font-weight-medium); color:var(--hp-textm); transition:all .15s; }
.hp-dp-sitem--active { background:rgba(99,102,241,.12); color:var(--hp-indigop); }
.hp-dp-main    { padding:20px; display:flex; flex-direction:column; gap:18px; }
.hp-dp-welcome { font-size:17px; font-weight:var(--font-weight-extrabold); color:var(--hp-text); letter-spacing:-.02em; }
.hp-dp-welcome span { color:var(--hp-indigol); }
.hp-dp-kpis { display:grid; grid-template-columns:repeat(4,1fr); gap:10px; }
.hp-kpi { background:var(--hp-bg2); border:1px solid var(--hp-border); border-radius:10px; padding:12px 14px; }
.hp-kpi-lbl { font-family:var(--hp-mono); font-size:10px; color:var(--hp-textd); text-transform:uppercase; letter-spacing:.06em; margin-bottom:6px; }
.hp-kpi-val { font-family:var(--hp-mono); font-size:var(--text-medium); font-weight:var(--font-weight-bold); color:var(--hp-text); line-height:1; }
.hp-kpi-sub { font-size:var(--font-size-xs); color:var(--hp-green); margin-top:4px; }
.hp-dp-grid2 { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.hp-dp-card  { background:var(--hp-bg2); border:1px solid var(--hp-border); border-radius:10px; padding:14px; }
.hp-dp-card-title { font-size:var(--font-size-sm); font-weight:var(--font-weight-bold); color:var(--hp-text); margin-bottom:12px; }
.hp-dp-bars { display:flex; flex-direction:column; gap:10px; }
.hp-dp-bar-item { display:flex; flex-direction:column; gap:4px; }
.hp-dp-bar-head { display:flex; justify-content:space-between; font-size:var(--font-size-xs); color:var(--hp-textm); }
.hp-dp-bar-pct  { font-family:var(--hp-mono); color:var(--hp-indigol); font-weight:var(--font-weight-semibold); }
.hp-dp-bar-track { height:4px; background:rgba(255,255,255,.05); border-radius:2px; }
.hp-dp-bar-fill  { height:100%; border-radius:2px; background:linear-gradient(90deg,#6366f1,#818cf8); }
.hp-dp-activity { display:flex; flex-direction:column; gap:10px; }
.hp-dp-act { display:flex; align-items:center; gap:10px; font-size:var(--font-size-sm); }
.hp-dp-act-dot  { width:7px; height:7px; border-radius:50%; flex-shrink:0; }
.hp-dp-act-text { color:var(--hp-textm); flex:1; }
.hp-dp-act-time { font-family:var(--hp-mono); font-size:10px; color:var(--hp-textd); }

/* ============================================================
   6. FAQ
   ============================================================ */
.hp-faq { position:relative; z-index:1; padding:100px 40px; background:var(--hp-bg2); border-top:1px solid var(--hp-border); }
.hp-faq-list { display:flex; flex-direction:column; gap:8px; }
.hp-faq-item { background:var(--hp-surface); border:1px solid var(--hp-border); border-radius:12px; overflow:hidden; transition:border-color var(--hp-tr); }
.hp-faq-item--open { border-color:rgba(99,102,241,.28); }
.hp-faq-q { all:unset !important; cursor:pointer !important; box-sizing:border-box !important; width:100% !important; display:flex !important; justify-content:space-between !important; align-items:center !important; padding:18px 22px !important; font-family:var(--hp-font) !important; font-size:var(--font-size-sm) !important; font-weight:var(--font-weight-semibold) !important; color:var(--hp-text) !important; }
.hp-faq-chevron { color:var(--hp-textd); transition:transform .2s; flex-shrink:0; }
.hp-faq-item--open .hp-faq-chevron { transform:rotate(180deg); color:var(--hp-indigol); }
.hp-faq-a { max-height:0; overflow:hidden; transition:max-height .3s ease; font-size:var(--font-size-md); color:var(--hp-textm); line-height:1.7; }
.hp-faq-item--open .hp-faq-a { max-height:200px; }
.hp-faq-a-inner { padding:0 22px 18px; }

/* ============================================================
   BILLING TOGGLE
   ============================================================ */
.hp-billing-toggle {
    display: flex; align-items: center; justify-content: center;
    gap: 12px; margin-bottom: 40px;
}
.hp-billing-label {
    font-family: var(--hp-mono); font-size: 13px; font-weight: var(--font-weight-semibold);
    color: var(--hp-textm); display: flex; align-items: center; gap: 8px;
    transition: color var(--hp-tr);
}
.hp-billing-label.active { color: var(--hp-text); }
.hp-billing-save {
    font-size: 10px; font-weight: var(--font-weight-bold); padding: 2px 7px;
    border-radius: 10px; background: rgba(16,185,129,.15);
    color: #10b981; border: 1px solid rgba(16,185,129,.25);
    letter-spacing: .04em;
}
.hp-toggle {
    all: unset !important; cursor: pointer !important;
    width: 44px !important; height: 24px !important; border-radius: 12px !important;
    background: rgba(255,255,255,.08) !important;
    border: 1px solid var(--hp-border) !important;
    position: relative !important; display: inline-block !important;
    transition: background .2s, border-color .2s !important;
    box-sizing: border-box !important; flex-shrink: 0 !important;
    vertical-align: middle !important;
}
.hp-toggle.on {
    background: #6366f1 !important;
    border-color: #6366f1 !important;
}
.hp-toggle-thumb {
    position: absolute !important; top: 3px !important; left: 3px !important;
    width: 16px !important; height: 16px !important; border-radius: 50% !important;
    background: #4a4c68 !important; pointer-events: none !important;
    transition: transform .2s cubic-bezier(.4,0,.2,1), background .2s !important;
    display: block !important;
}
.hp-toggle.on .hp-toggle-thumb {
    transform: translateX(20px) !important;
    background: #fff !important;
}

/* ============================================================
   PRICING
   ============================================================ */
.hp-pricing { position:relative; z-index:1; padding:100px 40px; background:var(--hp-bg); border-top:1px solid var(--hp-border); }
.hp-plans-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; padding-top:20px; }
.hp-plan-wrap { position:relative; }
.hp-plan { background:var(--hp-surface); border:1px solid var(--hp-border); border-radius:14px; padding:28px; position:relative; transition:border-color var(--hp-tr),transform var(--hp-tr); display:flex; flex-direction:column; overflow:hidden; }
.hp-plan-wrap .hp-plan { height:100%; }
.hp-plan:hover { transform:translateY(-3px); }
.hp-plan--featured { border-color:rgba(99,102,241,.4); background:linear-gradient(135deg,rgba(99,102,241,.08),rgba(79,70,229,.04)); }
.hp-plan--featured::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:linear-gradient(90deg,#6366f1,#22d3ee); }
.hp-plan-badge  { position:absolute; top:-14px; left:50%; transform:translateX(-50%); z-index:2; font-family:var(--hp-mono); font-size:10px; font-weight:var(--font-weight-bold); padding:4px 12px; border-radius:20px; background:#6366f1; color:#fff; white-space:nowrap; letter-spacing:.06em; text-transform:uppercase; }
.hp-plan-name   { font-family:var(--hp-mono); font-size:var(--font-size-xs); font-weight:var(--font-weight-bold); color:var(--hp-textm); text-transform:uppercase; letter-spacing:.08em; margin-bottom:12px; }
.hp-plan-price  { display:flex; align-items:baseline; gap:4px; margin-bottom:6px; }
.hp-plan-eur    { font-size:var(--font-size-md); font-weight:var(--font-weight-semibold); color:var(--hp-textm); }
.hp-plan-amount { font-family:var(--hp-mono); font-size:36px; font-weight:var(--font-weight-extrabold); color:var(--hp-text); letter-spacing:-.03em; }
.hp-plan-period { font-size:var(--font-size-base); color:var(--hp-textd); }
.hp-plan-desc   { font-size:var(--font-size-base); color:var(--hp-textm); margin-bottom:24px; line-height:1.5; }
.hp-plan-feats  { list-style:none; padding:0; margin:0 0 28px; display:flex; flex-direction:column; gap:10px; flex:1; }
.hp-plan-feats li { display:flex; align-items:center; gap:10px; font-size:var(--font-size-base); color:var(--hp-textm); }
.hp-plan-feats li::before { content:''; display:inline-block; width:13px; height:13px; flex-shrink:0; background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='13' height='13' viewBox='0 0 24 24' fill='none' stroke='%2310b981' stroke-width='2.5'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") no-repeat center; }
.hp-plan-cta { width:100%; justify-content:center !important; font-size:var(--font-size-md) !important; padding:12px 20px !important; }

/* ============================================================
   8. CTA FINALE
   ============================================================ */
.hp-cta-final { position:relative; z-index:1; padding:120px 40px; background:var(--hp-bg2); border-top:1px solid var(--hp-border); overflow:hidden; text-align:center; }
.hp-cta-glow  { position:absolute; width:600px; height:600px; border-radius:50%; background:radial-gradient(circle,rgba(99,102,241,.15),transparent 70%); top:50%; left:50%; transform:translate(-50%,-50%); filter:blur(60px); pointer-events:none; z-index:0; }
.hp-cta-inner { position:relative; z-index:2; }
.hp-cta-title { font-size:clamp(28px,5vw,52px); font-weight:var(--font-weight-extrabold); letter-spacing:-.035em; color:var(--hp-text); margin-bottom:20px; line-height:1.1; }
.hp-cta-title .hp-gradient-text { -webkit-text-fill-color:transparent !important; }
.hp-cta-desc  { font-size:17px; color:var(--hp-textm); line-height:1.6; margin-bottom:40px; max-width:480px; margin-left:auto; margin-right:auto; }
.hp-cta-btns  { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1024px) {
    .hp-value-grid { grid-template-columns:repeat(2,1fr); }
    .hp-courses-grid { grid-template-columns:repeat(2,1fr); }
    .hp-plans-grid { grid-template-columns:repeat(2,1fr); }
    .hp-dp-kpis { grid-template-columns:repeat(2,1fr); }
    .hp-dp-body { grid-template-columns:180px 1fr; }
}
@media (max-width:768px) {
    .hp-hero { padding:110px 24px 80px; min-height:90vh; }
    .hp-value,.hp-features,.hp-courses,.hp-demo,
    .hp-faq,.hp-pricing,.hp-cta-final { padding:72px 24px; }
    .hp-value-grid,.hp-courses-grid,.hp-plans-grid { grid-template-columns:1fr; }
    .hp-feat-panel { grid-template-columns:1fr; }
    .hp-feat-right { display:none; }
    .hp-section-head--split { flex-direction:column; align-items:flex-start; gap:16px; }
    .hp-dp-body { grid-template-columns:1fr; }
    .hp-dp-sidebar { display:none; }
    .hp-dp-kpis { grid-template-columns:repeat(2,1fr); }
    .hp-stats { padding:14px 20px; }
    .hp-stat  { padding:0 16px; }
    .hp-stat-num { font-size:var(--text-medium) !important; }
    .hp-hero-cta { flex-direction:column; align-items:stretch; max-width:300px; margin-left:auto; margin-right:auto; }
    .hp-page .btn { justify-content:center !important; }
}
@media (max-width:480px) {
    .hp-hero { padding:90px 20px 60px; }
    .hp-stats { flex-direction:column; gap:16px; padding:20px; width:100%; max-width:260px; }
    .hp-stat-div { width:80px; height:1px; }
    .hp-stat { padding:0; }
    .hp-formula { font-size:10px !important; word-break:break-all; }
    .hp-dp-grid2,.hp-dp-kpis { grid-template-columns:1fr; }
}