:root {
    --gold:        #F5C400;
    --gold-dark:   #D4A900;
    --gold-light:  rgba(245,196,0,0.12);
    --gold-line:   rgba(245,196,0,0.28);
    --petrol:      #004060;
    --petrol-mid:  #005070;
    --petrol-line: rgba(0,64,96,0.16);
    --ink:         #001828;
    --text:        #1A2B38;
    --text-mid:    #3D5468;
    --text-muted:  #576875; /* WCAG-Fix: war #6B8498 (3.63:1), jetzt 5.36:1 ✓ */
    --bg:          #F4F7FA;
    --border:      rgba(0,0,0,0.07);
    --border-mid:  rgba(0,0,0,0.11);
    --shadow-sm:   0 2px 8px rgba(0,0,0,0.06);
    --shadow-md:   0 8px 32px rgba(0,0,0,0.09);
    --shadow-lg:   0 24px 64px rgba(0,0,0,0.14);
  }
  *,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
  html{scroll-behavior:smooth;}
  body{font-family:'Nunito',sans-serif;background:var(--bg);color:var(--text);line-height:1.6;overflow-x:hidden;}
  img{max-width:100%;height:auto;display:block;}
  a{text-decoration:underline;color:inherit;}
  nav a, .btn-primary, .btn-ghost, .nav-cta, .mod-tab, .target-tag,
  .feat-card, .footer-nav a, .footer-bottom a, .logo-wrap,
  .role-card, .screenshot-inner, .lightbox-close{text-decoration:none;}
  ul{list-style:none;}
  .container{max-width:1120px;margin:0 auto;padding:0 40px;}

  /* ── NAV ── */
  nav {
    position:fixed;top:0;left:0;right:0;z-index:100;
    padding:0 48px;height:68px;
    display:flex;align-items:center;justify-content:space-between;
    background:rgba(244,247,250,0.96);
    backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
    border-bottom:1px solid var(--border);
    transition:box-shadow 0.3s;
  }
  nav.scrolled{box-shadow:var(--shadow-sm);}
  .nav-logo img{height:36px;width:auto;display:block;}
  .nav-links{display:flex;gap:32px;align-items:center;list-style:none;}
  .nav-links a{font-size:15px;font-weight:500;color:var(--text-mid);transition:color 0.2s;}
  .nav-links a:hover{color:var(--petrol);}
  .nav-cta-short{display:none;}
  .nav-cta-long{display:inline;}
  .nav-cta{background:var(--gold)!important;color:var(--ink)!important;padding:10px 22px;border-radius:8px;font-weight:700!important;
    border:2px solid #9A7800!important; /* WCAG-Fix: UI-Kontrast ✓ */
    box-shadow:0 2px 12px rgba(245,196,0,0.35);transition:all 0.2s!important;}
  .nav-cta:hover{background:var(--gold-dark)!important;border-color:#7A6000!important;transform:translateY(-1px);}

  /* P2-Fix 2: Hamburger-Button Mobile */
  .nav-toggle{display:none;background:none;border:none;color:var(--petrol);font-size:24px;cursor:pointer;
    padding:8px;border-radius:6px;min-height:44px;min-width:44px;align-items:center;justify-content:center;}

  /* ── BUTTONS ── */
  .btn-primary{background:var(--gold);color:var(--ink);padding:14px 30px;border-radius:10px;font-size:15px;font-weight:700;
    display:inline-flex;align-items:center;gap:8px;box-shadow:0 4px 16px rgba(245,196,0,0.35);
    transition:all 0.2s;border:2px solid #9A7800;cursor:pointer;font-family:'Nunito',sans-serif;} /* WCAG-Fix: border für UI-Kontrast 3.2:1 ✓ */
  .btn-primary:hover{background:var(--gold-dark);border-color:#7A6000;transform:translateY(-2px);box-shadow:0 8px 28px rgba(245,196,0,0.45);}
  .btn-ghost{background:white;color:var(--text-mid);padding:14px 26px;border-radius:10px;font-size:15px;font-weight:500;
    border:1px solid var(--border-mid);box-shadow:var(--shadow-sm);display:inline-flex;align-items:center;gap:8px;transition:all 0.2s;}
  .btn-ghost:hover{color:var(--petrol);border-color:var(--petrol-line);}

  /* ── TYPE ── */
  .section-label{font-size:12px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;color:var(--petrol);
    margin-bottom:14px;display:flex;align-items:center;gap:8px;}
  .section-label::before{content:'';width:16px;height:2px;background:var(--gold);border-radius:2px;}
  .section-title{font-family:'Poppins',sans-serif;font-weight:700;font-size:clamp(32px,4vw,48px);line-height:1.15;
    letter-spacing:-0.025em;color:var(--petrol);margin-bottom:16px;text-align:center;}
  .section-sub{font-size:17px;color:var(--text-mid);font-weight:400;line-height:1.75;max-width:560px;text-align:center;margin-left:auto;margin-right:auto;}

  /* ── HERO ── */
  .hero{position:relative;padding:138px 40px 100px;min-height:100vh;display:flex;align-items:center;overflow:hidden;}
  .hero::before{content:'';position:absolute;top:-200px;right:-100px;width:700px;height:700px;
    background:radial-gradient(circle,rgba(0,64,96,0.07) 0%,transparent 65%);pointer-events:none;}
  .hero::after{content:'';position:absolute;bottom:-200px;left:-100px;width:500px;height:500px;
    background:radial-gradient(circle,rgba(245,196,0,0.06) 0%,transparent 65%);pointer-events:none;}
  .hero-inner{max-width:1120px;margin:0 auto;width:100%;display:grid;grid-template-columns:1fr 1fr;
    gap:72px;align-items:center;position:relative;z-index:2;}
  .hero-badge{display:inline-flex;align-items:center;gap:8px;background:transparent;border:none;
    padding:0 0 28px 0;font-size:12px;font-weight:600;color:var(--petrol);
    letter-spacing:0.05em;text-transform:uppercase;animation:fadeUp 0.7s ease both;}
  .badge-dot{width:6px;height:6px;border-radius:50%;background:var(--petrol);animation:pulse 2s infinite;}
  @keyframes pulse{0%,100%{opacity:1;transform:scale(1);}50%{opacity:.4;transform:scale(.7);}}
  .hero h1{font-family:'Poppins',sans-serif;font-weight:700;font-size:clamp(42px,5vw,64px);line-height:1.08;
    letter-spacing:-0.03em;color:var(--petrol);margin-bottom:22px;animation:fadeUp 0.7s 0.1s ease both;}
  .hero h1 em{font-style:italic;color:var(--gold-dark);}
  .hero-sub{font-size:17px;color:var(--text-mid);max-width:460px;margin-bottom:40px;line-height:1.75;animation:fadeUp 0.7s 0.2s ease both;}
  .hero-actions{display:flex;gap:12px;flex-wrap:wrap;animation:fadeUp 0.7s 0.3s ease both;}
  .hero-visual{animation:fadeUp 0.7s 0.15s ease both;}
  .hero-screenshot-wrap{border-radius:16px;overflow:hidden;box-shadow:var(--shadow-lg);border:3px solid var(--petrol);}
  .hero-screenshot-wrap img{width:100%;height:auto;display:block;}

  /* ── STATS ── */
  .stats-bar{background:white;border-top:1px solid var(--border);border-bottom:1px solid var(--border);}
  .stats-inner{max-width:1120px;margin:0 auto;display:flex;padding:0 40px;}
  .stat-item{flex:1;padding:36px 28px;border-right:1px solid var(--border);text-align:center;}
  .stat-item:last-child{border-right:none;}
  .stat-num{font-family:'Poppins',sans-serif;font-weight:700;font-size:38px;color:var(--petrol);line-height:1;margin-bottom:6px;letter-spacing:-0.02em;}
  .stat-num.has-accent .accent{color:var(--gold-dark);}
  .stat-label{font-size:14px;color:var(--text-muted);font-weight:500;}

  /* ── FEATURES ── */
  .features-section{padding:60px 0;background:white;}
  .features-intro{display:flex;flex-direction:column;align-items:center;text-align:center;margin-bottom:60px;}
  .features-intro .section-label{justify-content:center;}
  .features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
  .feat-card{background:var(--bg);border:1px solid var(--border);border-radius:18px;padding:32px 28px;
    transition:all 0.3s;position:relative;overflow:hidden;}
  .feat-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;
    background:linear-gradient(90deg,var(--gold),var(--gold-dark));transform:scaleX(0);transform-origin:left;transition:transform 0.3s;}
  .feat-card:hover{background:white;border-color:var(--gold-line);box-shadow:var(--shadow-md);transform:translateY(-4px);}
  .feat-card:hover::after{transform:scaleX(1);}
  .feat-icon{width:64px;height:64px;border-radius:16px;background:var(--gold-light);border:1px solid var(--gold-line);
    display:flex;align-items:center;justify-content:center;font-size:30px;margin-bottom:22px;}
  .feat-card h3{font-family:'Poppins',sans-serif;font-size:18px;font-weight:700;color:var(--petrol);margin-bottom:10px;}
  .feat-card p{font-size:15px;color:var(--text-muted);line-height:1.65;}

  /* ── SCREENSHOTS ── */
  .screenshots-section{padding:60px 0;background:var(--bg);}
  .screenshots-intro{text-align:center;margin-bottom:64px;}
  .screenshots-intro .section-label{justify-content:center;}
  .screenshots-intro .section-title,.screenshots-intro .section-sub{margin-left:auto;margin-right:auto;}
  .screenshot-tabs{display:flex;gap:10px;justify-content:center;margin-bottom:48px;flex-wrap:wrap;}
  .tab-btn{padding:10px 22px;border-radius:100px;font-size:15px;font-weight:600;border:1px solid var(--border-mid);
    background:white;color:var(--text-mid);cursor:pointer;transition:all 0.2s;font-family:'Nunito',sans-serif;}
  .tab-btn:hover{border-color:var(--gold-line);color:var(--petrol);}
  .tab-btn.active{background:var(--petrol);color:white;border-color:var(--petrol);box-shadow:0 4px 16px rgba(0,64,96,0.25);}
  .screenshot-stage{position:relative;max-width:1000px;margin:0 auto;}
  .screenshot-panel{display:none;}
  .screenshot-panel.active{display:block;animation:fadeIn 0.35s ease;}
  @keyframes fadeIn{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:translateY(0);}}
  .screenshot-frame{background:var(--petrol);border-radius:24px;padding:20px;box-shadow:var(--shadow-lg);position:relative;}
  .screenshot-label-chip{position:absolute;top:-14px;right:24px;background:var(--gold);color:var(--ink);
    padding:7px 20px;border-radius:100px;font-size: 14px;font-weight:700;box-shadow:0 4px 12px rgba(245,196,0,0.35);}
  .screenshot-inner{border-radius:12px;overflow:hidden;}
  .screenshot-inner img{width:100%;height:auto;display:block;border-radius:12px;cursor:zoom-in;transition:opacity 0.2s;}
  .screenshot-inner img:hover{opacity:0.88;}
  /* Lightbox */
  .lightbox-overlay{display:none;position:fixed;inset:0;background:rgba(0,10,20,0.92);z-index:9999;align-items:center;justify-content:center;padding:24px;}
  .lightbox-overlay.active{display:flex;animation:fadeIn 0.2s ease;}
  .lightbox-content{max-width:90vw;max-height:90vh;position:relative;}
  .lightbox-content img{max-width:90vw;max-height:85vh;border-radius:12px;box-shadow:0 24px 80px rgba(0,0,0,0.6);object-fit:contain;display:block;}
  .lightbox-close{position:fixed;top:20px;right:28px;background:none;border:none;color:white;font-size:40px;cursor:pointer;line-height:1;opacity:0.7;transition:opacity 0.2s;}
  .lightbox-close:hover{opacity:1;}

  /* ── PROBLEM ── */
  .problem-section{padding:60px 0;background:white;}
  .problem-section > .container > .section-label,
  .problem-section > .container > .section-title{text-align:center;justify-content:center;}
  .problem-grid{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start;margin-top:60px;}
  .problem-list{display:flex;flex-direction:column;gap:14px;}
  .problem-item{display:flex;gap:16px;align-items:flex-start;padding:20px 22px;background:var(--bg);
    border:1px solid var(--border);border-radius:14px;transition:all 0.25s;}
  .problem-item:hover{border-color:var(--border-mid);box-shadow:var(--shadow-sm);}
  .problem-icon{width:40px;height:40px;border-radius:10px;background:#FEF2F2;border:1px solid rgba(239,68,68,0.15);
    display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;}
  .problem-item h3,.problem-heading{font-family:'Poppins',sans-serif;font-size:18px;font-weight:700;color:var(--petrol);margin-bottom:3px;}
  .problem-item p{font-size:14px;color:var(--text-muted);line-height:1.5;}
  .solution-stack{display:flex;flex-direction:column;gap:20px;position:sticky;top:88px;}
  .solution-main{background:var(--petrol);border-radius:20px;padding:40px;}
  .solution-main h3{font-family:'Poppins',sans-serif;font-weight:700;font-size:28px;line-height:1.25;margin-bottom:14px;color:white;}
  .solution-main > p{font-size:15px;color:rgba(255,255,255,0.82);line-height:1.7;font-weight:400;}
  .sol-list{display:flex;flex-direction:column;gap:11px;margin-top:24px;}
  .sol-item{display:flex;align-items:center;gap:10px;font-size:15px;color:rgba(255,255,255,0.88);}
  .sol-check{width:20px;height:20px;border-radius:50%;background:white;border:1px solid rgba(255,255,255,0.4);
    display:flex;align-items:center;justify-content:center;color:var(--petrol);font-size:12px;flex-shrink:0;}
  .solution-quote{background:var(--gold);border-radius:16px;padding:28px 32px;}
  .solution-quote p{font-family:'Poppins',sans-serif;font-weight:700;font-size:22px;color:var(--ink);font-style:normal;line-height:1.4;}

  /* ── ROLES ── */
  .roles-section{padding:60px 0;background:var(--bg);}
  .roles-section > .container > .section-label,
  .roles-section > .container > .section-title{text-align:center;justify-content:center;}
  .roles-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:60px;}
  .role-card{border:1px solid var(--border);border-radius:20px;padding:36px 32px;background:white;
    transition:all 0.3s;position:relative;overflow:hidden;}
  .role-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;
    background:linear-gradient(90deg,var(--gold),var(--gold-dark));transform:scaleX(0);transform-origin:left;transition:transform 0.3s;}
  .role-card:hover{box-shadow:var(--shadow-md);border-color:var(--gold-line);transform:translateY(-3px);}
  .role-card:hover::before{transform:scaleX(1);}
  .role-title{font-family:'Poppins',sans-serif;font-weight:700;font-size:24px;color:var(--petrol);margin-bottom:8px;}
  .role-intro{font-size:14px;color:var(--text-muted);margin-bottom:24px;line-height:1.6;}
  .role-points{display:flex;flex-direction:column;gap:10px;}
  .role-points li{font-size:14px;color:var(--text-mid);display:flex;align-items:flex-start;gap:8px;line-height:1.5;}
  .role-points li::before{content:'→';color:var(--gold-dark);flex-shrink:0;font-size:12px;margin-top:2px;font-weight:700;}

  /* ── TARGETS ── */
  .targets-section{padding:36px 0;background:var(--bg);border-top:1px solid var(--border);border-bottom:1px solid var(--border);}
  .targets-inner{display:flex;align-items:center;gap:32px;flex-wrap:wrap;}
  .targets-label{font-size:12px;font-weight:700;color:var(--text-muted);white-space:nowrap;text-transform:uppercase;letter-spacing:0.08em;}
  .targets-tags{display:flex;gap:8px;flex-wrap:wrap;}
  .target-tag{padding:7px 16px;background:white;border:1px solid var(--border);border-radius:6px;
    font-size:13px;font-weight:500;color:var(--text-mid);cursor:default;}

  /* ── CTA ── */
  .cta-section{padding:60px 0;background:var(--petrol);text-align:center;position:relative;overflow:hidden;}
  .cta-section::before{content:'';position:absolute;top:-250px;left:50%;transform:translateX(-50%);
    width:700px;height:550px;background:radial-gradient(ellipse at center,rgba(245,196,0,0.1) 0%,transparent 65%);pointer-events:none;}
  .cta-inner{position:relative;z-index:2;max-width:560px;margin:0 auto;}
  .cta-section .section-label{color:var(--gold);justify-content:center;}
  .cta-section .section-label::before{background:var(--gold);}
  .cta-section h2{font-family:'Nunito',sans-serif;font-weight:800;font-size:clamp(36px,5vw,56px);letter-spacing:-0.03em;
    line-height:1.1;margin-bottom:16px;color:white;}
  .cta-section h2 em{font-style:italic;color:var(--gold);}
  .cta-desc{font-size:16px;color:rgba(255,255,255,0.8);margin-bottom:24px;font-weight:300;line-height:1.6;}
  .cta-box{background:rgba(255,255,255,0.07);border:1px solid rgba(255,255,255,0.12);border-radius:16px;padding:24px;}
  .cta-input-row{display:flex;gap:10px;margin-bottom:10px;}
  .cta-field{flex:1;}
  /* P2-Fix 3: Labels sichtbar statt display:none */
  .cta-label{display:block;font-size:11px;font-weight:700;color:rgba(255,255,255,0.75);margin-bottom:5px;letter-spacing:0.04em;text-transform:uppercase;}
  .cta-req{color:var(--gold);}
  .cta-required-note{font-size:12px;color:rgba(255,255,255,0.7);margin-bottom:10px;text-align:left;}
  .cta-textarea{resize:vertical;min-height:100px;line-height:1.6;}
  .cta-input{width:100%;padding:14px 18px;background:rgba(255,255,255,0.18);border:1px solid rgba(255,255,255,0.4);
    border-radius:10px;font-size:15px;color:white;font-family:'Nunito',sans-serif;outline:none;transition:border-color 0.2s,background 0.2s;}
  .cta-input::placeholder{color:rgba(255,255,255,0.55);}
  .cta-input:focus{border-color:rgba(245,196,0,0.85);background:rgba(255,255,255,0.24);}
  .cta-input.cta-input-error{border-color:rgba(239,68,68,0.65);}
  .cta-error{font-size:12px;color:#FCA5A5;display:none;margin-top:4px;}
  .cta-error.show{display:block;}
  .cta-check-row{display:flex;align-items:flex-start;gap:10px;margin:14px 0 4px;font-size:13px;color:rgba(255,255,255,0.75);line-height:1.55;}
  /* P2-Fix 4: Checkbox größer für bessere Klickfläche */
  .cta-check-row input[type=checkbox]{width:20px;height:20px;min-width:20px;margin-top:1px;flex-shrink:0;accent-color:var(--gold);cursor:pointer;}
  .cta-check-row a{color:rgba(255,255,255,0.9);text-decoration:underline;}
  .cta-note{font-size:12px;color:rgba(255,255,255,0.45);text-align:center;margin-top:14px;}

  .contact-person-card{display:flex;align-items:center;gap:12px;background:rgba(255,255,255,0.08);
    border:1px solid rgba(255,255,255,0.15);border-radius:12px;padding:12px 16px;margin-bottom:16px;text-align:left;}
  .contact-avatar{width:52px;height:52px;border-radius:50%;object-fit:cover;object-position:top;
    border:2px solid var(--gold);flex-shrink:0;}
  .contact-person-name{font-size:15px;font-weight:700;color:white;margin:0 0 2px;}
  .contact-person-role{font-size:12px;color:rgba(255,255,255,0.75);margin:0;}

  .btn-bookings{display:inline-flex;align-items:center;justify-content:center;gap:10px;width:100%;
    padding:14px 24px;background:var(--gold);color:var(--ink);border-radius:10px;
    font-size:15px;font-weight:700;text-decoration:none;transition:background 0.2s,transform 0.15s;}
  .btn-bookings:hover{background:var(--gold-dark);transform:translateY(-1px);}
  .bookings-note{font-size:12px;color:rgba(255,255,255,0.7);text-align:center;margin:8px 0 0;}

  .cta-toggle{width:100%;display:flex;align-items:center;justify-content:space-between;
    background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.15);border-radius:12px;
    padding:14px 18px;color:rgba(255,255,255,0.9);font-size:14px;font-weight:700;cursor:pointer;
    margin-top:20px;text-decoration:none;transition:background 0.2s,color 0.2s;}
  .cta-toggle:hover{background:rgba(255,255,255,0.13);color:white;}
  .cta-toggle[aria-expanded='true']{border-bottom-left-radius:0;border-bottom-right-radius:0;border-bottom-color:transparent;color:white;}
  .cta-toggle-icon{transition:transform 0.25s;flex-shrink:0;}
  .cta-toggle[aria-expanded='true'] .cta-toggle-icon{transform:rotate(180deg);}
  .cta-form-wrap{border-top-left-radius:0;border-top-right-radius:0;border-top:none;
    animation:fadeUp 0.25s ease both;}
  .cta-form-wrap[hidden]{display:none;}
  .cta-divider{display:flex;align-items:center;gap:12px;margin:20px 0 16px;color:rgba(255,255,255,0.6);font-size:13px;}
  .cta-divider::before,.cta-divider::after{content:'';flex:1;height:1px;background:rgba(255,255,255,0.15);}

  /* Success state */
  .cta-success{display:none;text-align:center;padding:32px 0;}
  .cta-success.show{display:block;animation:fadeUp 0.5s ease both;}
  .cta-success-icon{width:68px;height:68px;background:rgba(245,196,0,0.15);border:2px solid var(--gold);
    border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:28px;
    margin:0 auto 16px;animation:popIn 0.5s cubic-bezier(0.34,1.56,0.64,1) both;}
  @keyframes popIn{from{transform:scale(0);opacity:0;}to{transform:scale(1);opacity:1;}}
  .cta-success h3{font-size:22px;font-weight:800;color:white;margin-bottom:8px;}
  .cta-success p{font-size:15px;color:rgba(255,255,255,0.55);line-height:1.6;}

  /* ── FOOTER ── */
  footer{background:var(--ink);border-top:1px solid rgba(255,255,255,0.07);padding:24px 48px;
    display:flex;align-items:center;justify-content:center;gap:28px;flex-wrap:wrap;text-align:center;}
  .footer-logo img{height:28px;width:auto;display:block;}
  .footer-links{display:flex;gap:24px;}
  .footer-links a{font-size:14px;color:rgba(255,255,255,0.75);transition:color 0.2s;}
  .footer-links a:hover{color:white;}
  .footer-copy{font-size:13px;color:rgba(255,255,255,0.5);}

  /* ── ANIMATIONS ── */
  @keyframes fadeUp{from{opacity:0;transform:translateY(24px);}to{opacity:1;transform:translateY(0);}}
  .reveal{opacity:0;transform:translateY(28px);transition:opacity 0.65s ease,transform 0.65s ease;}
  .reveal.visible{opacity:1;transform:translateY(0);}

  /* ── RESPONSIVE ── */
  @media (max-width:900px){
    nav{padding:0 20px;}
    .nav-toggle{display:flex;} /* P2: Hamburger sichtbar auf Mobile */
    .nav-links{display:none;flex-direction:column;position:absolute;top:68px;left:0;right:0;
      background:rgba(244,247,250,0.98);border-bottom:1px solid var(--border);
      padding:16px 20px;gap:0;}
    .nav-links.nav-open{display:flex;}
    .nav-links li{border-bottom:1px solid var(--border);}
    .nav-links li:last-child{border-bottom:none;}
    .nav-links a{display:block;padding:14px 0;font-size:16px;}
    .nav-cta{display:block;text-align:center;margin:8px 0 4px;}
    .nav-cta-short{display:inline;}
    .nav-cta-long{display:none;}
    .container,.hero{padding-left:20px;padding-right:20px;}
    .hero-inner,.features-intro,.problem-grid{grid-template-columns:1fr;gap:40px;}
    .features-grid,.roles-grid{grid-template-columns:1fr 1fr;}
    .stats-inner{flex-wrap:wrap;}
    .stat-item{border-right:none;border-bottom:1px solid var(--border);}
    footer{padding:28px 20px;}
    .solution-stack{position:relative;top:auto;}
  }
  @media (max-width:600px){
    .features-grid,.roles-grid{grid-template-columns:1fr;}
    .cta-input-row{flex-direction:column;}
  }

  /* ── MODULES ── */
  .modules-section{padding:60px 0;background:white;}
  .modules-intro{text-align:center;}
  .modules-intro .section-label{justify-content:center;}
  .modules-intro .section-title{margin:0 auto 16px;}

  .mod-tabs{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin-bottom:40px;}
  .mod-tab{padding:10px 20px;border-radius:100px;font-size:14px;font-weight:600;
    border:1px solid var(--border-mid);background:var(--bg);color:var(--text-mid);
    cursor:pointer;transition:all 0.2s;font-family:'Nunito',sans-serif;}
  .mod-tab:hover{border-color:var(--petrol-line);color:var(--petrol);}
  .mod-tab.active{background:var(--petrol);color:white;border-color:var(--petrol);
    box-shadow:0 4px 16px rgba(0,64,96,0.22);}

  .mod-stage{max-width:860px;margin:0 auto;}
  .mod-panel{display:none;}
  .mod-panel.active{display:block;animation:fadeIn 0.3s ease;}

  .mod-header{display:flex;gap:20px;align-items:flex-start;margin-bottom:28px;}
  .mod-icon{width:56px;height:56px;border-radius:16px;background:var(--gold-light);
    border:1px solid var(--gold-line);display:flex;align-items:center;justify-content:center;
    font-size:26px;flex-shrink:0;}
  .mod-title{font-family:'Poppins',sans-serif;font-size:28px;color:var(--petrol);
    margin-bottom:8px;line-height:1.2;}
  .mod-desc{font-size:16px;color:var(--text-mid);line-height:1.7;}

  .mod-chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px;}
  .mod-chip{padding:6px 14px;border-radius:6px;font-size:13px;font-weight:500;
    background:transparent;border:1px solid var(--border);color:var(--text-muted);
    cursor:default;letter-spacing:0;}
  .active-chip{background:var(--petrol)!important;color:white!important;border-color:var(--petrol)!important;}

  .mod-highlight{display:flex;gap:12px;align-items:flex-start;padding:18px 22px;
    background:var(--gold-light);border:1px solid var(--gold-line);border-radius:14px;
    font-size: 15px;color:#5A4200;line-height:1.6;}
  .mod-hl-icon{font-size:18px;flex-shrink:0;margin-top:1px;}


  /* ── COUNT-UP ANIMATION ── */
  .count-up {
    display: inline-block;
    transition: opacity 0.3s;
  }
  .stat-item {
    transition: transform 0.4s ease, opacity 0.4s ease;
  }
  .stat-item.stat-visible {
    animation: statPop 0.6s cubic-bezier(0.34, 1.56, 0.64, 1) both;
  }
  @keyframes statPop {
    0%   { opacity: 0; transform: translateY(20px) scale(0.85); }
    60%  { opacity: 1; transform: translateY(-4px) scale(1.04); }
    100% { opacity: 1; transform: translateY(0) scale(1); }
  }


  /* ── PREFERS-REDUCED-MOTION ── */
  @media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
      animation-duration: 0.01ms !important;
      animation-iteration-count: 1 !important;
      transition-duration: 0.01ms !important;
      scroll-behavior: auto !important;
    }
    .reveal { opacity: 1; transform: none; }
    .hero-badge, .hero h1, .hero-sub, .hero-actions, .hero-visual { animation: none; opacity: 1; }
    .stat-item.stat-visible { animation: none; opacity: 1; transform: none; }
  }


  /* ── SKIP TO CONTENT ── */
  .skip-link {
    position: absolute; top: -100px; left: 16px; z-index: 9999;
    background: var(--petrol); color: white;
    padding: 12px 20px; border-radius: 0 0 8px 8px;
    font-size: 14px; font-weight: 700;
    transition: top 0.2s;
    text-decoration: none;
  }
  .skip-link:focus {
    top: 0;
    outline: 3px solid var(--gold);
    outline-offset: 2px;
  }

  /* ── FOCUS STYLES ── */
  :focus-visible {
    outline: 3px solid var(--gold);
    outline-offset: 3px;
    border-radius: 4px;
  }
  .tab-btn:focus-visible,
  .mod-tab:focus-visible,
  .btn-primary:focus-visible,
  .btn-ghost:focus-visible {
    outline: 3px solid var(--gold);
    outline-offset: 3px;
  }
  .nav-cta:focus-visible {
    outline: 3px solid var(--petrol) !important;
    outline-offset: 3px;
  }