  :root{
    --bg:#FFFFFF;
    --bg-soft:#FAFAFA;
    --ink:#1B1B1F;
    --ink-muted:#6B7079;
    --ink-faint:#A3A8B2;
    --line:#EAEAEC;

    /* === Brand colors, sampled directly from the TTC logo === */
    --magenta:#DB349F;
    --magenta-deep:#AC1A71;
    --magenta-soft:#FCE4F3;

    --indigo:#7A54A1;
    --indigo-navy:#233175;
    --indigo-soft:#ECE7F7;

    --blue:#4AC3D3;
    --blue-deep:#1B7A9E;
    --blue-soft:#E2F6F9;

    --green:#8BBB3F;
    --green-deep:#3F7D1F;
    --green-soft:#EFF6E1;

    --gold:#F8BD16;
    --gold-deep:#B86A14;
    --gold-soft:#FEF1D6;

    --radius-lg:28px;
    --radius-md:18px;
    --radius-sm:12px;

    --display:'Fraunces', serif;
    --body:'Plus Jakarta Sans', sans-serif;
  }
  *{box-sizing:border-box; margin:0; padding:0;}
  html{scroll-behavior:smooth;}
  body{
    background:var(--bg);
    color:var(--ink);
    font-family:var(--body);
    line-height:1.65;
    -webkit-font-smoothing:antialiased;
    overflow-x:hidden;
  }
  img{max-width:100%; display:block;}
  a{color:inherit; text-decoration:none;}
  ul{list-style:none;}
  button{font-family:inherit;}

  .wrap{max-width:1180px; margin:0 auto; padding:0 32px;}
  section{position:relative;}

  .eyebrow{
    display:inline-flex; align-items:center; gap:7px;
    font-family:var(--body); font-weight:700; font-size:12.5px;
    letter-spacing:0.05em; text-transform:uppercase;
    padding:8px 16px; border-radius:999px;
    background:var(--magenta-soft); color:var(--magenta-deep);
  }
  .eyebrow--indigo{background:var(--indigo-soft); color:var(--indigo-navy);}
  .eyebrow--gold{background:var(--gold-soft); color:var(--gold-deep);}
  .eyebrow--green{background:var(--green-soft); color:var(--green-deep);}
  .eyebrow--blue{background:var(--blue-soft); color:var(--blue-deep);}
  .eyebrow::before{content:''; width:6px; height:6px; border-radius:50%; background:currentColor;}

  h1,h2,h3,h4{font-family:var(--display); font-weight:600; letter-spacing:-0.01em; color:var(--ink);}
  h1{font-size:clamp(36px,5.6vw,62px); line-height:1.08; font-weight:600;}
  h2{font-size:clamp(28px,3.8vw,42px); line-height:1.16;}
  h3{font-size:20px; line-height:1.32; font-weight:600;}
  p{color:var(--ink-muted);}
  .lead{font-size:18.5px; color:var(--ink-muted); max-width:560px;}
  em{font-style:italic; font-family:var(--display);}
  .hl-magenta{color:var(--magenta);}
  .hl-indigo{color:var(--indigo);}

  /* ===== NAV ===== */
  header{
    position:sticky; top:0; z-index:50;
    background:rgba(255,255,255,0.9);
    backdrop-filter:blur(14px);
    border-bottom:1px solid var(--line);
  }
  nav{display:flex; align-items:center; justify-content:space-between; padding:16px 0;}
  .logo{font-family:var(--display); font-weight:600; font-size:17px; display:flex; align-items:center; gap:12px;}
  .logo-img{height:42px; width:auto;}
  .nav-links{display:flex; align-items:center; gap:34px;}
  .nav-links a{font-size:15px; font-weight:500; color:var(--ink-muted); transition:color .2s;}
  .nav-links a:hover{color:var(--ink);}
  .nav-cta{
    font-family:var(--body); font-size:14.5px; font-weight:700;
    padding:12px 24px; border-radius:999px;
    background:var(--magenta); color:#fff;
    box-shadow:0 8px 20px rgba(219,52,159,0.28);
    transition:transform .2s, box-shadow .2s;
  }
  .nav-cta:hover{transform:translateY(-2px); box-shadow:0 12px 26px rgba(219,52,159,0.38);}
  .nav-toggle{display:none; background:none; border:none; color:var(--ink); font-size:24px; cursor:pointer;}

  @media(max-width:880px){
    .nav-links{
      position:fixed; top:73px; right:0; left:0;
      background:#fff; flex-direction:column;
      padding:12px 0; gap:2px;
      border-bottom:1px solid var(--line);
      transform:translateY(-130%); transition:transform .3s ease;
      align-items:stretch; overflow-y:auto;
      max-height:85vh; width:100%; box-sizing:border-box;
      list-style:none;
    }
    .nav-links.open{transform:translateY(0);}
    .nav-toggle{display:block;}
  }

  /* ===== BUTTONS ===== */
  .btn-primary{
    font-family:var(--body); font-size:15.5px; font-weight:700;
    display:inline-flex; align-items:center; gap:9px;
    padding:16px 30px; border-radius:999px;
    background:var(--magenta); color:#fff; border:none;
    box-shadow:0 10px 26px rgba(219,52,159,0.28);
    transition:transform .2s, box-shadow .2s;
    cursor:pointer;
  }
  .btn-primary:hover{transform:translateY(-2px); box-shadow:0 14px 32px rgba(219,52,159,0.4);}
  .btn-ghost{
    font-family:var(--body); font-size:15.5px; font-weight:700;
    display:inline-flex; align-items:center; gap:8px;
    padding:15px 28px; border-radius:999px;
    background:#fff; color:var(--ink);
    border:1.5px solid var(--line);
    transition:border-color .2s, transform .2s;
    cursor:pointer;
  }
  .btn-ghost:hover{border-color:var(--ink); transform:translateY(-2px);}

  .btn-indigo{
    font-family:var(--body); font-size:15.5px; font-weight:700;
    display:inline-flex; align-items:center; gap:9px;
    padding:16px 30px; border-radius:999px;
    background:var(--indigo); color:#fff; border:none;
    box-shadow:0 10px 26px rgba(122,84,161,0.3);
    transition:transform .2s, box-shadow .2s;
    cursor:pointer;
  }
  .btn-indigo:hover{transform:translateY(-2px); box-shadow:0 14px 32px rgba(122,84,161,0.42);}

  .btn-blue{
    font-family:var(--body); font-size:15.5px; font-weight:700;
    display:inline-flex; align-items:center; gap:9px;
    padding:16px 30px; border-radius:999px;
    background:var(--blue-deep); color:#fff; border:none;
    box-shadow:0 10px 26px rgba(27,122,158,0.3);
    transition:transform .2s, box-shadow .2s;
    cursor:pointer;
  }
  .btn-blue:hover{transform:translateY(-2px); box-shadow:0 14px 32px rgba(27,122,158,0.42);}

  /* ===== HERO ===== */
  .hero{padding:80px 0 60px; overflow:hidden;}
  .hero-grid{display:grid; grid-template-columns:1.1fr 0.9fr; gap:60px; align-items:center;}
  .hero-checks{margin:30px 0 28px; display:flex; flex-direction:column; gap:14px;}
  .check-item{display:flex; gap:12px; align-items:flex-start; font-size:16px; color:var(--ink); font-weight:500;}
  .check-icon{
    flex-shrink:0; width:24px; height:24px; border-radius:50%; margin-top:1px;
    background:var(--green-soft);
    display:flex; align-items:center; justify-content:center;
  }
  .hero-ctas{display:flex; gap:16px; flex-wrap:wrap; margin-bottom:22px;}

  .period-badge{
    display:inline-flex; align-items:center; gap:10px;
    padding:13px 22px; border-radius:999px;
    background:linear-gradient(120deg, var(--gold-soft), var(--magenta-soft));
    font-size:14.5px; font-weight:700; color:var(--ink);
  }
  .period-badge svg{flex-shrink:0;}
  .period-badge strong{color:var(--magenta-deep);}

  .hero-visual{position:relative; display:flex; align-items:center; justify-content:center; min-height:560px;}
  .blob{
    position:absolute; border-radius:50%; filter:blur(2px);
    z-index:0;
  }
  .blob-1{width:340px; height:340px; background:radial-gradient(circle at 35% 30%, var(--magenta-soft), transparent 70%); top:-20px; left:-10px;}
  .blob-2{width:280px; height:280px; background:radial-gradient(circle at 60% 60%, var(--blue-soft), transparent 70%); bottom:-30px; right:0;}

  .photo-wrap{position:relative; z-index:2; width:340px; margin-bottom:85px;}
  .photo-accent{
    position:absolute; inset:0; z-index:0;
    transform:translate(16px,16px);
    background:linear-gradient(135deg, var(--magenta), var(--blue-deep));
    border-radius:28px;
  }
  .photo-card{
    position:relative; z-index:1; width:100%; aspect-ratio:4/5;
    border-radius:28px; overflow:hidden;
    box-shadow:0 30px 60px rgba(20,20,30,0.18);
  }
  .photo-card img{width:100%; height:100%; object-fit:cover; object-position:center 14%;}

  .emblem{
    position:absolute; z-index:3; bottom:-46px; left:-54px;
    width:252px; height:252px; border-radius:50%;
    background:#fff;
    border:1.5px solid var(--line);
    display:flex; flex-direction:column; align-items:center; justify-content:center; gap:6px;
    box-shadow:0 28px 55px rgba(20,20,30,0.2);
  }
  .emblem::before{
    content:''; position:absolute; inset:-11px; border-radius:50%;
    border:1.5px dashed var(--gold);
    opacity:0.55;
  }
  .emblem .cor{font-family:var(--body); font-size:12px; font-weight:700; letter-spacing:0.05em; color:var(--gold-deep); text-transform:uppercase; margin-top:2px;}
  .emblem .title{font-family:var(--display); font-size:30px; font-weight:600; color:var(--ink); text-align:center; line-height:1.12; max-width:178px;}
  .emblem .sub{font-family:var(--body); font-size:11px; color:var(--ink-faint); text-transform:uppercase; letter-spacing:0.08em; font-weight:600; margin-top:3px;}
  .emblem-seal{
    position:absolute; bottom:8px; right:6px; z-index:3;
    width:46px; height:46px; border-radius:50%;
    background:linear-gradient(135deg, var(--magenta), var(--indigo));
    display:flex; align-items:center; justify-content:center;
    box-shadow:0 10px 22px rgba(122,84,161,0.35);
    border:3px solid #fff;
  }
  .float-dot{position:absolute; border-radius:50%; z-index:1;}
  .float-dot.d1{width:18px; height:18px; background:var(--gold); top:20px; right:40px;}
  .float-dot.d2{width:12px; height:12px; background:var(--magenta); bottom:50px; left:10px;}
  .float-dot.d3{width:24px; height:24px; border:3px solid var(--blue); background:none; top:60%; right:-10px;}

  /* ===== SECTION GENERIC ===== */
  .section{padding:100px 0;}
  .section-soft{background:var(--bg-soft);}
  .section-head{max-width:680px; margin-bottom:54px;}
  .section-head h2{margin-top:16px;}
  .section-head p{margin-top:16px; font-size:17px;}
  .center{text-align:center; margin-left:auto; margin-right:auto;}

  /* ===== PAIN POINTS ===== */
  .pain-list{display:grid; grid-template-columns:1fr 1fr; gap:16px; margin:40px 0 44px;}
  .pain-item{
    display:flex; gap:14px; align-items:flex-start; padding:22px 24px; border-radius:var(--radius-md);
    background:#fff; border:1px solid var(--line);
    font-size:15.5px; color:var(--ink); font-weight:500;
  }
  .pain-icon{
    flex-shrink:0; width:36px; height:36px; border-radius:11px;
    display:flex; align-items:center; justify-content:center;
  }
  .pain-close{max-width:680px; font-size:17px; color:var(--ink); margin-bottom:12px;}
  .pain-close strong{color:var(--magenta);}

  /* ===== BENEFITS ===== */
  .benefits-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:22px;}
  .benefit-card{
    background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg);
    padding:32px 28px; transition:transform .25s, box-shadow .25s;
  }
  .benefit-card:hover{transform:translateY(-5px); box-shadow:0 22px 44px rgba(20,20,30,0.08);}
  .benefit-icon{
    width:50px; height:50px; border-radius:16px; margin-bottom:20px;
    background:var(--magenta-soft);
    display:flex; align-items:center; justify-content:center;
  }
  .benefit-card:nth-child(2) .benefit-icon{background:var(--indigo-soft);}
  .benefit-card:nth-child(3) .benefit-icon{background:var(--gold-soft);}
  .benefit-card:nth-child(4) .benefit-icon{background:var(--blue-soft);}
  .benefit-card:nth-child(5) .benefit-icon{background:var(--green-soft);}
  .benefit-card h3{margin-bottom:11px;}
  .benefit-card p{font-size:15px;}
  .competency-toggle{
    margin-top:16px; font-family:var(--body); font-size:13.5px; font-weight:700; color:var(--indigo);
    background:none; border:none; cursor:pointer; display:inline-flex; align-items:center; gap:6px;
  }
  .competency-list{
    display:none; margin-top:16px; padding-top:16px; border-top:1px solid var(--line);
    list-style:disc; padding-left:18px; font-size:13.5px; color:var(--ink-muted); gap:7px;
  }
  .competency-list.open{display:flex; flex-direction:column;}

  /* ===== BONUSES ===== */
  .bonus-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:22px; margin-bottom:40px;}
  .bonus-card{
    background:#fff; border:2px solid var(--line); border-radius:var(--radius-lg);
    padding:26px 22px; display:flex; flex-direction:column; gap:14px;
    position:relative; transition:transform .25s, box-shadow .25s;
  }
  .bonus-card:hover{transform:translateY(-5px);}
  .bonus-card--magenta{border-color:var(--magenta); box-shadow:0 18px 40px rgba(219,52,159,0.14);}
  .bonus-card--indigo{border-color:var(--indigo); box-shadow:0 18px 40px rgba(122,84,161,0.14);}
  .bonus-card--blue{border-color:var(--blue-deep); box-shadow:0 18px 40px rgba(27,122,158,0.14);}
  .bonus-ribbon{
    position:absolute; top:18px; right:18px;
    background:var(--magenta); color:#fff; font-size:11px; font-weight:800;
    padding:5px 12px; border-radius:999px; letter-spacing:0.04em;
  }
  .bonus-num{font-family:var(--display); font-size:15px; font-style:italic; color:var(--gold-deep);}
  .bonus-card h3{font-size:17px;}
  .bonus-card p{font-size:14px;}
  .bonus-price{font-size:14px; color:var(--ink-faint); text-decoration:line-through; font-weight:600;}
  .bonus-total{
    text-align:center; padding:40px; border-radius:var(--radius-lg);
    background:linear-gradient(120deg, var(--magenta-soft), var(--indigo-soft));
  }
  .bonus-total .val{font-family:var(--display); font-size:38px; color:var(--ink); font-weight:700; margin:8px 0;}

  /* ===== PRICING ===== */
  .price-banner{text-align:center; margin-bottom:50px;}
  .price-banner .old{color:var(--ink-faint); text-decoration:line-through; font-size:19px; font-weight:600;}
  .price-banner .new{font-family:var(--display); font-size:54px; color:var(--magenta); font-weight:700; margin:8px 0;}
  .urgency{
    display:inline-flex; align-items:center; gap:8px; margin-top:12px;
    font-size:13.5px; font-weight:700; color:var(--gold-deep);
    background:var(--gold-soft);
    padding:9px 18px; border-radius:999px;
  }

  .pricing-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:22px;}
  .price-card{
    background:#fff; border:1.5px solid var(--line); border-radius:var(--radius-lg);
    padding:34px 28px; display:flex; flex-direction:column; gap:20px;
    transition:transform .25s, box-shadow .25s;
  }
  .price-card.featured{border-color:var(--indigo); background:linear-gradient(180deg, var(--indigo-soft) 0%, #fff 30%);}
  .price-card:hover{transform:translateY(-5px); box-shadow:0 22px 44px rgba(20,20,30,0.08);}
  .price-card .tag{font-size:12.5px; font-weight:700; color:var(--ink-faint); text-transform:uppercase; letter-spacing:0.06em;}
  .price-card .amount{font-family:var(--display); font-size:36px; font-weight:700; color:var(--ink);}
  .price-card .rate-line{display:flex; justify-content:space-between; font-size:14px; color:var(--ink-muted); padding:9px 0; border-top:1px solid var(--line); font-weight:500;}
  .price-card .desc{font-size:14px; color:var(--ink-muted); flex-grow:1;}
  .price-card .btn-primary, .price-card .btn-ghost, .price-card .btn-indigo, .price-card .btn-blue{justify-content:center; width:100%; margin-top:auto; border:none;}

  /* ===== SCHEDULE ===== */
  .pain-list.sched{grid-template-columns:repeat(2,1fr);}
  .pain-list.sched .pain-icon{background:var(--gold-soft); color:var(--gold-deep); font-family:var(--display); font-weight:700; font-size:13px;}

  /* ===== TESTIMONIALS ===== */
  .testi-grid{display:flex; flex-direction:column; gap:24px; max-width:780px; margin:0 auto;}
  .testi-card{
    background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg);
    overflow:hidden; box-shadow:0 18px 40px rgba(20,20,30,0.06);
    display:flex; align-items:center; gap:0;
  }
  .testi-card video{width:100%; display:block; aspect-ratio:16/9; object-fit:contain; background:#0c0c10;}
  .testi-name{padding:18px 22px; font-family:var(--display); font-weight:600; font-size:16px; border-top:1px solid var(--line);}

  /* ===== PROOF OF ACCREDITATION ===== */
  .proof-grid{display:grid; grid-template-columns:1fr 1fr; gap:24px; max-width:780px; margin:0 auto;}
  .proof-card{
    background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg);
    overflow:hidden; box-shadow:0 18px 40px rgba(20,20,30,0.06);
    transition:transform .25s, box-shadow .25s;
  }
  .proof-card:hover{transform:translateY(-5px); box-shadow:0 24px 48px rgba(20,20,30,0.1);}
  .proof-card img{width:100%; display:block;}
  .proof-card--diploma img{aspect-ratio:1/1.04; object-fit:contain; object-position:center; background:#eef0f1; padding:10px;}
  .proof-card--autorizatie img{aspect-ratio:4/5; object-fit:cover; object-position:top center; background:#f2f2f2;}
  .proof-caption{padding:18px 20px;}
  .proof-caption h3{font-size:16px; margin-bottom:4px;}
  .proof-caption p{font-size:13.5px;}

  /* ===== ABOUT ===== */
  .about-grid{display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:start;}
  .stat-row{display:flex; gap:38px; margin-top:30px;}
  .stat .num{font-family:var(--display); font-size:32px; color:var(--magenta); font-weight:700;}
  .stat .lbl{font-size:12px; color:var(--ink-faint); text-transform:uppercase; letter-spacing:0.05em; font-weight:700; margin-top:4px;}
  .coordinator-card{
    background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg);
    padding:24px; box-shadow:0 18px 40px rgba(20,20,30,0.05);
  }
  .coordinator-photo{width:100%; aspect-ratio:4/5; border-radius:18px; overflow:hidden; margin-bottom:22px; background:#111;}
  .coordinator-photo img{width:100%; height:100%; object-fit:cover; object-position:center 18%;}
  .coordinator-head{margin-bottom:16px;}
  .coordinator-head h3{margin-bottom:8px;}
  .coordinator-card p{font-size:14.5px; margin-bottom:13px; padding:0 6px;}
  .coordinator-card p:last-child{margin-bottom:0;}

  /* ===== PROCESS ===== */
  .process-card{
    background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg);
    padding:12px 32px; max-width:760px; margin:0 auto;
  }
  .process-step{
    display:flex; align-items:flex-start; gap:20px;
    padding:24px 0;
    border-bottom:1px solid var(--line);
  }
  .process-step:last-child{border-bottom:none;}
  .process-num{
    flex-shrink:0; width:46px; height:46px; border-radius:50%;
    display:flex; align-items:center; justify-content:center;
    font-family:var(--display); font-weight:700; font-size:17px; color:#fff;
  }
  .process-step:nth-child(1) .process-num{background:var(--magenta);}
  .process-step:nth-child(2) .process-num{background:var(--indigo);}
  .process-step:nth-child(3) .process-num{background:var(--blue-deep);}
  .process-step:nth-child(4) .process-num{background:var(--green-deep);}
  .process-text{padding-top:4px;}
  .process-text h3{font-size:17px; margin-bottom:5px;}
  .process-text p{font-size:14.5px;}

  /* ===== FAQ ===== */
  .faq-list{display:flex; flex-direction:column; gap:14px;}
  .faq-item{background:#fff; border:1px solid var(--line); border-radius:var(--radius-md); overflow:hidden;}
  .faq-q{
    width:100%; text-align:left; padding:24px 26px; background:none; border:none; cursor:pointer;
    display:flex; justify-content:space-between; align-items:center; gap:16px;
    font-family:var(--display); font-size:16.5px; color:var(--ink); font-weight:600;
  }
  .faq-q .plus{font-family:var(--body); color:var(--magenta); font-size:20px; font-weight:700; transition:transform .25s; flex-shrink:0;}
  .faq-item.open .plus{transform:rotate(45deg);}
  .faq-a{max-height:0; overflow:hidden; transition:max-height .3s ease;}
  .faq-a p{padding:0 26px 24px; font-size:15px;}

  /* ===== FINAL CTA ===== */
  .final-cta{
    text-align:center; padding:120px 0; position:relative; overflow:hidden;
    background:linear-gradient(135deg, var(--magenta-soft) 0%, var(--blue-soft) 100%);
  }
  .final-cta h2{max-width:680px; margin:0 auto 18px;}
  .final-cta p{max-width:480px; margin:0 auto 36px; font-size:17px;}

  /* ===== FOOTER ===== */
  footer{background:var(--ink); color:#fff; padding:64px 0 32px;}
  .footer-grid{display:grid; grid-template-columns:1.3fr 0.8fr 1fr 1fr; gap:36px; margin-bottom:44px;}
  .footer-grid h4{font-size:12.5px; color:#8B8F99; text-transform:uppercase; letter-spacing:0.06em; margin-bottom:18px; font-weight:700;}
  .footer-grid p, .footer-grid a{font-size:14.5px; color:#C9CCD3; display:flex; align-items:center; gap:7px; margin-bottom:11px;}
  .footer-grid a:hover{color:#fff;}
  .footer-grid .logo{color:#fff; margin-bottom:16px;}
  .footer-logo-img{height:38px; width:auto; filter:brightness(1.1);}
  .footer-bottom{display:flex; justify-content:space-between; align-items:center; padding-top:26px; border-top:1px solid rgba(255,255,255,0.12); font-size:13px; color:#8B8F99; flex-wrap:wrap; gap:10px;}

  .reveal{opacity:0; transform:translateY(22px); transition:opacity .65s cubic-bezier(.22,.61,.36,1), transform .65s cubic-bezier(.22,.61,.36,1);}
  .reveal.in{opacity:1; transform:translateY(0);}

  @keyframes heroFade{
    from{opacity:0; transform:translateY(16px);}
    to{opacity:1; transform:translateY(0);}
  }
  .hero-anim > *{opacity:0; animation:heroFade .75s cubic-bezier(.22,.61,.36,1) forwards;}
  .hero-anim > *:nth-child(1){animation-delay:.05s;}
  .hero-anim > *:nth-child(2){animation-delay:.16s;}
  .hero-anim > *:nth-child(3){animation-delay:.27s;}
  .hero-anim > *:nth-child(4){animation-delay:.38s;}
  .hero-anim > *:nth-child(5){animation-delay:.49s;}
  .hero-anim > *:nth-child(6){animation-delay:.6s;}
  .hero-visual{opacity:0; animation:heroFade .9s cubic-bezier(.22,.61,.36,1) .35s forwards;}

  @media (prefers-reduced-motion: reduce){
    .hero-anim > *, .hero-visual{animation:none; opacity:1; transform:none;}
  }

  /* ===== MODAL ===== */
  .modal-overlay{
    position:fixed; inset:0; z-index:200; display:none;
    align-items:center; justify-content:center; padding:24px;
    background:rgba(20,20,25,0.55); backdrop-filter:blur(3px);
  }
  .modal-overlay.open{display:flex;}
  .modal-card{
    background:#fff; border-radius:24px; max-width:540px; width:100%;
    max-height:88vh; overflow-y:auto; padding:36px; position:relative;
  }
  .modal-close{
    position:absolute; top:18px; right:18px; width:34px; height:34px; border-radius:50%;
    background:var(--bg-soft); border:none; font-size:18px; cursor:pointer;
    display:flex; align-items:center; justify-content:center; color:var(--ink-muted);
  }
  .modal-card h3{font-size:22px; margin-bottom:6px; padding-right:30px;}
  .modal-sub{font-size:13.5px; color:var(--ink-faint); margin-bottom:26px;}
  .form-row{margin-bottom:16px;}
  .form-row label{display:block; font-size:13px; font-weight:700; margin-bottom:6px; color:var(--ink);}
  .form-row input[type=text], .form-row input[type=email], .form-row input[type=tel]{
    width:100%; padding:13px 14px; border:1.5px solid var(--line); border-radius:10px;
    font-family:var(--body); font-size:14.5px; color:var(--ink);
  }
  .form-row input:focus{outline:none; border-color:var(--magenta);}
  .doc-section-title{font-size:12.5px; font-weight:700; text-transform:uppercase; letter-spacing:0.06em; color:var(--ink-faint); margin:24px 0 14px;}
  .doc-row{border:1.5px dashed var(--line); border-radius:14px; padding:14px 16px; margin-bottom:12px;}
  .doc-row .doc-label{font-weight:700; font-size:14px; margin-bottom:3px; color:var(--ink);}
  .doc-row .doc-hint{font-size:12px; color:var(--ink-faint); margin-bottom:9px;}
  .doc-row input[type=file]{font-size:12.5px; width:100%;}
  .modal-thanks{display:none; text-align:center; padding:20px 0;}
  .modal-thanks.show{display:block;}
  .modal-thanks .icon{width:56px; height:56px; border-radius:50%; background:var(--green-soft); display:flex; align-items:center; justify-content:center; margin:0 auto 18px;}

  @media(max-width:900px){
    .hero-grid{grid-template-columns:1fr; gap:46px;}
    .hero-visual{order:-1; min-height:auto;}
    .photo-wrap{width:230px; margin-bottom:55px;}
    .photo-accent{transform:translate(10px,10px);}
    .emblem{width:170px; height:170px; bottom:-32px; left:-36px;}
    .emblem .title{font-size:20px; max-width:124px;}
    .emblem .cor{font-size:10px;}
    .emblem .sub{font-size:9.5px;}
    .emblem-seal{width:36px; height:36px;}
    .pain-list, .benefits-grid, .bonus-grid, .pricing-grid, .about-grid, .footer-grid, .proof-grid{grid-template-columns:1fr;}
    .footer-grid{grid-template-columns:1fr 1fr;}
    .footer-grid > div:first-child{grid-column:1/-1;}
    .stat-row{gap:26px;}
    .section{padding:64px 0;}
    .process-card{padding:8px 22px;}
  }

/* ===================================================== */
/* SHARED MULTI-PAGE COMPONENTS (nav dropdown, courses,   */
/* trust stats, WhatsApp banner)                          */
/* ===================================================== */

/* Nav dropdown ("Cursuri") */
.nav-dropdown{position:relative;}
.nav-dropdown-toggle{
  display:inline-flex; align-items:center; gap:5px; cursor:pointer;
  background:none; border:none; font:inherit; color:var(--ink-muted);
  font-size:15px; font-weight:500; padding:0;
}
.nav-dropdown-toggle:hover{color:var(--ink);}
.nav-dropdown-toggle svg{transition:transform .2s;}
.nav-dropdown.open .nav-dropdown-toggle svg{transform:rotate(180deg);}
.nav-dropdown-menu{
  position:absolute; top:calc(100% + 16px); left:50%;
  transform:translateX(-50%) translateY(6px);
  background:#fff; border:1px solid var(--line); border-radius:18px;
  box-shadow:0 26px 50px rgba(20,20,30,0.14);
  padding:10px; min-width:300px;
  opacity:0; visibility:hidden; pointer-events:none;
  transition:opacity .2s ease, transform .2s ease, visibility .2s;
  z-index:60;
}
.nav-dropdown:hover .nav-dropdown-menu,
.nav-dropdown.open .nav-dropdown-menu{
  opacity:1; visibility:visible; pointer-events:auto; transform:translateX(-50%) translateY(0);
}
.nav-dropdown-menu a{
  display:flex; flex-direction:column; gap:2px;
  padding:11px 14px; border-radius:12px; font-size:14px; color:var(--ink);
}
.nav-dropdown-menu a:hover{background:var(--bg-soft);}
.nav-dropdown-menu a span{font-size:12px; color:var(--ink-faint); font-weight:500;}
@media(max-width:880px){
  /* Each li takes full width, content right-aligned */
  .nav-links > li{
    width:100%; box-sizing:border-box;
    padding:0 16px; display:flex; flex-direction:column; align-items:flex-end;
  }

  /* Plain nav links — right aligned */
  .nav-links > li > a:not(.nav-cta){
    display:block; padding:13px 14px; border-radius:10px;
    font-size:15.5px; font-weight:500; color:var(--ink-muted);
    width:100%; box-sizing:border-box; text-align:right;
  }
  .nav-links > li > a.nav-cta{
    display:block; text-align:center; margin:8px 0 4px;
    width:100%; box-sizing:border-box;
  }

  /* Dropdown container — full width, items right */
  .nav-dropdown{width:100%; box-sizing:border-box;}
  .nav-dropdown-toggle{
    width:100%; text-align:right; padding:13px 14px; border-radius:10px;
    font-size:15.5px; font-weight:500; color:var(--ink-muted);
    background:none; border:none; cursor:pointer;
    display:flex; justify-content:space-between; align-items:center;
    flex-direction:row-reverse;
    box-sizing:border-box; font-family:var(--body);
  }
  .nav-dropdown-toggle svg{flex-shrink:0;}

  /* Dropdown panel — right anchored */
  .nav-dropdown-menu{
    position:static !important; transform:none !important;
    box-shadow:none; border:none; border-radius:0;
    opacity:1; visibility:visible; pointer-events:auto;
    display:none; flex-direction:column; gap:4px;
    padding:4px 0 8px; min-width:0;
    background:transparent;
    width:100%; box-sizing:border-box;
    align-items:flex-end;
  }
  .nav-dropdown.open .nav-dropdown-menu{display:flex;}

  /* Dropdown items — right-anchored, text right */
  .nav-dropdown-menu a{
    display:flex; flex-direction:column; gap:3px; align-items:flex-end;
    padding:11px 14px; border-radius:10px;
    background:rgba(219,52,159,0.07);
    font-size:14.5px; font-weight:600; color:var(--ink);
    white-space:normal; word-break:break-word; text-align:right;
    box-sizing:border-box; width:100%;
    text-decoration:none;
  }
  .nav-dropdown-menu a:hover{background:rgba(219,52,159,0.14);}
  .nav-dropdown-menu a span{
    font-size:11.5px; color:var(--magenta); font-weight:700; text-align:right;
  }
}

/* Course catalog cards */
.course-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:22px;}
.course-card{
  background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg);
  padding:30px 26px; display:flex; flex-direction:column; gap:13px;
  transition:transform .25s, box-shadow .25s;
  border-top:4px solid transparent;
}
.course-card:hover{transform:translateY(-5px); box-shadow:0 22px 44px rgba(20,20,30,0.08);}
/* Per-card color theming via nth-child */
.course-card:nth-child(1){background:linear-gradient(160deg, var(--magenta-soft) 0%, #fff 50%); border-top-color:var(--magenta);}
.course-card:nth-child(2){background:linear-gradient(160deg, var(--indigo-soft) 0%, #fff 50%); border-top-color:var(--indigo);}
.course-card:nth-child(3){background:linear-gradient(160deg, var(--gold-soft) 0%, #fff 50%); border-top-color:var(--gold);}
.course-card:nth-child(4){background:linear-gradient(160deg, var(--blue-soft) 0%, #fff 50%); border-top-color:var(--blue);}
.course-card:nth-child(5){background:linear-gradient(160deg, var(--green-soft) 0%, #fff 50%); border-top-color:var(--green);}
.course-card:nth-child(6){background:linear-gradient(160deg, var(--magenta-soft) 0%, var(--indigo-soft) 100%); border-top-color:var(--indigo);}
.course-card:hover{transform:translateY(-5px); box-shadow:0 22px 44px rgba(20,20,30,0.08);}
.course-icon{width:50px; height:50px; border-radius:16px; display:flex; align-items:center; justify-content:center; margin-bottom:4px;}
.course-card h3{font-size:19px; line-height:1.25;}
.course-card p{font-size:14.5px; flex-grow:1;}
.course-start{
  display:flex; align-items:center; gap:7px;
  font-size:12.5px; font-weight:700; color:var(--ink-faint);
  padding-top:10px; border-top:1px solid var(--line);
}
.course-link{
  display:inline-flex; align-items:center; gap:6px;
  font-size:14.5px; font-weight:700; color:var(--magenta);
  margin-top:2px;
}
.course-link svg{transition:transform .2s;}
.course-card:hover .course-link svg{transform:translateX(3px);}
.course-card--soon{opacity:0.55;}

/* Trust / stats trio */
.trust-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:22px;}
.trust-card{text-align:center; padding:36px 26px; border-radius:var(--radius-lg); border:1px solid var(--line); background:#fff;}
.trust-card .trust-icon{width:54px; height:54px; border-radius:16px; margin:0 auto 16px; display:flex; align-items:center; justify-content:center;}
.trust-card h3{font-size:17px; margin-bottom:6px;}
.trust-card p{font-size:14px;}

/* WhatsApp CTA banner */
.whatsapp-banner{
  border-radius:var(--radius-lg);
  background:linear-gradient(120deg, var(--green-soft), var(--blue-soft));
  padding:44px; display:flex; align-items:center; justify-content:space-between; gap:28px; flex-wrap:wrap;
}
.whatsapp-banner-text h3{font-size:21px; margin-bottom:6px;}
.whatsapp-banner-text p{font-size:15px; color:var(--ink);}
.btn-whatsapp{
  font-family:var(--body); font-size:15.5px; font-weight:700;
  display:inline-flex; align-items:center; gap:10px;
  padding:16px 28px; border-radius:999px;
  background:var(--green-deep); color:#fff; border:none;
  box-shadow:0 10px 26px rgba(63,125,31,0.28);
  transition:transform .2s, box-shadow .2s; flex-shrink:0;
}
.btn-whatsapp:hover{transform:translateY(-2px); box-shadow:0 14px 32px rgba(63,125,31,0.4);}

/* Footer nav (page links, present on every page) */
.footer-nav-links a{font-weight:600; color:#fff;}
.footer-nav-links a:hover{color:var(--magenta);}

@media(max-width:900px){
  .course-grid, .trust-grid{grid-template-columns:1fr;}
  .whatsapp-banner{padding:30px; flex-direction:column; align-items:flex-start; text-align:left;}
  .btn-whatsapp{width:100%; justify-content:center;}
}

/* ===================================================== */
/* CONTACT PAGE COMPONENTS                                 */
/* ===================================================== */
.form-row textarea{
  width:100%; padding:13px 14px; border:1.5px solid var(--line); border-radius:10px;
  font-family:var(--body); font-size:14.5px; color:var(--ink); resize:vertical; min-height:140px;
}
.form-row textarea:focus{outline:none; border-color:var(--magenta);}

.checkbox-row{display:flex; align-items:flex-start; gap:10px; margin:4px 0 22px;}
.checkbox-row input[type=checkbox]{margin-top:3px; width:16px; height:16px; accent-color:var(--magenta); flex-shrink:0;}
.checkbox-row label{font-size:13px; color:var(--ink-muted); line-height:1.55;}
.checkbox-row a{color:var(--ink); text-decoration:underline; text-underline-offset:2px;}

.contact-grid{display:grid; grid-template-columns:1.1fr 0.9fr; gap:32px; align-items:start;}
.contact-form-card{background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg); padding:36px; box-shadow:0 18px 40px rgba(20,20,30,0.05);}
.contact-info-card{background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg); padding:32px; display:flex; flex-direction:column; gap:20px; box-shadow:0 18px 40px rgba(20,20,30,0.05);}
.contact-info-row{display:flex; gap:14px; align-items:flex-start;}
.contact-info-icon{width:42px; height:42px; border-radius:13px; display:flex; align-items:center; justify-content:center; flex-shrink:0;}
.contact-info-row h4{font-size:14.5px; font-weight:700; margin-bottom:3px; color:var(--ink);}
.contact-info-row p, .contact-info-row a{font-size:14px; color:var(--ink-muted); display:block;}
.contact-info-row a:hover{color:var(--magenta);}
.map-frame{border-radius:var(--radius-md); overflow:hidden; border:1px solid var(--line); margin-top:4px;}
.map-frame iframe{width:100%; height:220px; border:0; display:block;}

.form-thanks{display:none; text-align:center; padding:40px 10px;}
.form-thanks.show{display:block;}
.form-thanks .icon{width:60px; height:60px; border-radius:50%; background:var(--green-soft); display:flex; align-items:center; justify-content:center; margin:0 auto 20px;}

@media(max-width:900px){
  .contact-grid{grid-template-columns:1fr;}
}

/* ===================================================== */
/* ANPC BADGES + FLOATING WHATSAPP                        */
/* ===================================================== */

/* ANPC badges in footer */
.footer-anpc{display:flex; flex-direction:column; gap:7px; justify-content:center;}
.anpc-badge{
  display:flex; align-items:stretch; gap:0;
  background:#fff; border-radius:6px; overflow:hidden;
  text-decoration:none; border:1px solid rgba(255,255,255,0.15);
  box-shadow:0 1px 5px rgba(0,0,0,0.2);
  transition:transform .2s, box-shadow .2s; width:195px;
}
.anpc-badge:hover{transform:translateY(-2px); box-shadow:0 3px 10px rgba(0,0,0,0.3);}
.anpc-badge-icon{
  background:#3A3EC9; color:#fff; padding:6px 8px;
  display:flex; align-items:center; justify-content:center;
  font-weight:900; font-size:10px; letter-spacing:0.03em;
  font-family:var(--body); white-space:nowrap; min-width:44px;
  flex-shrink:0;
}
.anpc-badge-icon.sol-online{background:#1a1a2e; font-size:9px;}
.anpc-badge-body{display:flex; flex-direction:column; padding:0; flex:1;}
.anpc-badge-text{
  font-family:var(--body); font-size:8.5px; font-weight:700;
  color:#1a1a2e; padding:5px 8px 2px; line-height:1.2; text-transform:uppercase; letter-spacing:0.02em;
}
.anpc-badge-btn{
  background:#1a1a2e; color:#fff; font-size:8px; font-weight:800;
  padding:3px 8px 4px; letter-spacing:0.07em; text-transform:uppercase;
  font-family:var(--body); text-align:left;
}

/* Floating WhatsApp button */
.wa-float{
  position:fixed; bottom:28px; right:24px; z-index:999;
  width:58px; height:58px; border-radius:50%;
  background:#25D366;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 6px 22px rgba(37,211,102,0.45), 0 2px 8px rgba(0,0,0,0.2);
  cursor:pointer; text-decoration:none;
  transition:transform .2s, box-shadow .2s;
  animation:waPulse 3s ease-in-out infinite;
}
.wa-float:hover{transform:scale(1.1); box-shadow:0 10px 30px rgba(37,211,102,0.55), 0 4px 12px rgba(0,0,0,0.25);}
@keyframes waPulse{
  0%,100%{box-shadow:0 6px 22px rgba(37,211,102,0.45), 0 2px 8px rgba(0,0,0,0.2);}
  50%{box-shadow:0 6px 22px rgba(37,211,102,0.45), 0 0 0 10px rgba(37,211,102,0.12), 0 2px 8px rgba(0,0,0,0.2);}
}
.wa-float-tooltip{
  position:absolute; right:68px; top:50%; transform:translateY(-50%);
  background:#1a1a2e; color:#fff; font-size:13px; font-weight:600;
  padding:7px 14px; border-radius:8px; white-space:nowrap;
  opacity:0; pointer-events:none; transition:opacity .2s;
  font-family:var(--body);
}
.wa-float-tooltip::after{
  content:''; position:absolute; left:100%; top:50%; transform:translateY(-50%);
  border:6px solid transparent; border-left-color:#1a1a2e;
}
.wa-float:hover .wa-float-tooltip{opacity:1;}

@media(max-width:900px){
  .footer-anpc{
    display:flex; flex-direction:row; flex-wrap:wrap;
    gap:8px; justify-content:flex-start; margin-top:8px;
  }
  .anpc-badge{width:auto; min-width:165px; flex:1;}
  .wa-float{bottom:18px; right:14px; width:52px; height:52px;}
}
