/* ========== CSS RESET & BASE ========== */
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: 'Outfit', 'Segoe UI', system-ui, sans-serif;
  background: var(--bg);
  color: var(--text);
  -webkit-font-smoothing: antialiased;
  line-height: 1.5;
}
img,svg { display:block; max-width:100%; }
a { color: var(--accent); text-decoration:none; }
a:hover, a:focus-visible { text-decoration:underline; }
button { font-family: inherit; cursor: pointer; }
body, button, input, select, textarea { font-size: 16px; }

/* ========== THEME TOKENS ========== */
:root {
  /* Brand palette: warm neon orange + soft amber halo */
  --accent: #ff9b24;
  --accent-alt: #ffc869;
  --accent-hot: #ff7a00;
  --bg: #080808;
  --bg-alt: #111111;
  --bg-soft: #181818;
  --text: #f6f6f6;
  --text-dim: #afafaf;
  --radius: 14px;
  --gradient: linear-gradient(100deg,#ff9b24,#ffbd4d 55%,#ffe5a3);
  --shadow: 0 8px 30px -8px rgba(0,0,0,.65),0 0 0 1px rgba(255,180,70,.06);
  --focus: 0 0 0 3px rgba(255,155,36,.55);
  --glow-text: 0 0 6px rgba(255,155,36,.85),0 0 16px rgba(255,155,36,.55),0 0 36px rgba(255,155,36,.4);
  --glow-strong: 0 0 10px rgba(255,155,36,.9),0 0 28px rgba(255,155,36,.6),0 0 60px rgba(255,155,36,.4);
}
[data-theme="light"] {
  --bg: #fafafa;
  --bg-alt: #ffffff;
  --bg-soft: #f2f2f2;
  --text: #1d1d1d;
  --text-dim: #575757;
  --shadow: 0 4px 18px -6px rgba(0,0,0,.18),0 0 0 1px rgba(0,0,0,.05);
  --gradient: linear-gradient(100deg,#ff9b24,#ffb948 60%,#ffd988);
}

/* Scrollbar (WebKit) */
body::-webkit-scrollbar { width: 10px; }
body::-webkit-scrollbar-track { background: var(--bg-alt); }
body::-webkit-scrollbar-thumb { background: linear-gradient(var(--accent),var(--accent-alt)); border-radius: 20px; }

/* ========== ACCESSIBILITY ========== */
.skip-link { position:absolute; left:-999px; top:auto; width:1px; height:1px; overflow:hidden; }
.skip-link:focus { position:fixed; left:1rem; top:1rem; width:auto; height:auto; padding:.75rem 1rem; background:var(--bg-soft); color:var(--text); border-radius:var(--radius); z-index:1000; }

/* ========== HEADER & NAV ========== */
.site-header { position:fixed; top:0; left:0; right:0; backdrop-filter: blur(16px); background:rgba(8,8,8,.78); border-bottom:1px solid rgba(255,175,60,.08); z-index:100; }
[data-theme="light"] .site-header { background:rgba(255,255,255,.9); border-color:rgba(0,0,0,.06); }
.nav-inner { display:flex; align-items:center; justify-content:space-between; gap:1rem; padding:.85rem clamp(1rem,3vw,2.5rem); }
.logo { font-size: clamp(1.3rem,2.2vw,2.2rem); font-weight:700; letter-spacing:.5px; color:#ffbf66; text-shadow: var(--glow-text); font-family: 'Outfit', 'Segoe UI', sans-serif; }
.logo span { color:#fff; filter:drop-shadow(0 0 4px rgba(255,255,255,.25)); }
.logo span { color:inherit; }
.primary-nav ul { list-style:none; display:flex; gap:1.2rem; margin:0; padding:0; align-items:center; }
.primary-nav a { font-weight:500; position:relative; padding:.35rem .2rem; }
.primary-nav a::after { content:""; position:absolute; left:0; bottom:0; width:0; height:2px; background:var(--gradient); transition:.35s; border-radius:2px; }
.primary-nav a:hover::after, .primary-nav a:focus-visible::after, .primary-nav a.active::after { width:100%; }
.nav-toggle { display:none; background:var(--bg-soft); color:var(--text); border:1px solid rgba(255,255,255,.12); padding:.6rem .9rem; border-radius:10px; font-size:1.1rem; }
.theme-toggle { background:none; border:none; font-size:1.2rem; line-height:1; }

/* ========== HERO ========== */
.hero { position:relative; min-height:100dvh; display:flex; align-items:center; justify-content:center; text-align:center; padding:7rem 1.2rem 4rem; overflow:hidden; }
.hero-bg { position:absolute; inset:0; background:
    radial-gradient(circle at 30% 38%,rgba(255,140,20,.35),transparent 62%),
    radial-gradient(circle at 72% 62%,rgba(255,200,100,.35),transparent 65%),
    linear-gradient(135deg,#050505,#121212 55%,#1a1a1a);
  animation: heroPulse 16s linear infinite alternate; }
.hero::after { content:""; position:absolute; inset:0; background: repeating-linear-gradient(60deg,rgba(255,255,255,.05)0 2px,transparent 2px 10px); mix-blend-mode: overlay; opacity:.15; pointer-events:none; }
@keyframes heroPulse { 0% { filter:hue-rotate(0); } 100% { filter:hue-rotate(30deg); } }
.hero-content { position:relative; max-width: 940px; }
.hero h1 { margin:0 0 1rem; font-size: clamp(2.5rem,5.4vw,4.6rem); line-height:1.05; font-weight:700; }
.gradient-text { color:#ffbf66; text-shadow: var(--glow-strong); background:none; -webkit-background-clip:unset; background-clip:unset; }
.lead { font-size: clamp(1.05rem,1.35vw,1.3rem); max-width:680px; margin:0 auto 2rem; color:var(--text-dim); }
.hero-cta { display:flex; gap:1.1rem; flex-wrap:wrap; justify-content:center; }
.trust-badges { margin:2.4rem auto 0; display:flex; gap:1.5rem; justify-content:center; flex-wrap:wrap; }
.trust-badges div { background:#141414; padding:.9rem 1.1rem; border-radius:var(--radius); box-shadow:0 0 0 1px rgba(255,160,50,.15),0 0 18px -4px rgba(255,155,36,.25); min-width:120px; position:relative; }
.trust-badges div::before { content:""; position:absolute; inset:0; border-radius:inherit; background:radial-gradient(circle at 50% 30%,rgba(255,160,50,.15),transparent 70%); mix-blend-mode:screen; pointer-events:none; }
.trust-badges strong { display:block; font-size:1.2rem; color:#ffc673; text-shadow: var(--glow-text); }
.scroll-down { position:absolute; bottom:1.2rem; left:50%; transform:translateX(-50%); font-size:1.7rem; opacity:.7; }

/* Typewriter */
.typewriter { display:inline-block; min-width:9ch; color:#ffe5b0; text-shadow: 0 0 6px rgba(255,150,40,.8),0 0 18px rgba(255,150,40,.45); position:relative; }
.typewriter::after { content:""; position:absolute; top:0; bottom:0; right:-4px; width:3px; background:var(--accent); animation: cursor .85s steps(1) infinite; }
@keyframes cursor { 50% { opacity:0; } }

/* ========== SECTIONS ========== */
.section { padding: clamp(3.5rem,8vw,6rem) 1.1rem; position:relative; }
.container { max-width: 1180px; margin:0 auto; }
.section h2 { font-size: clamp(1.9rem,3.2vw,3rem); margin:0 0 1.3rem; line-height:1.15; }
.section p { max-width: 820px; }

.pill-list { list-style:none; padding:0; margin:2rem 0 0; display:flex; flex-wrap:wrap; gap:.65rem; }
.pill-list li { background: var(--bg-soft); padding:.55rem .95rem; border-radius: 999px; font-size:.8rem; letter-spacing:.5px; text-transform:uppercase; color:var(--text-dim); }

/* Roles */
.roles { background: linear-gradient(165deg,#0c0c0c,#161616 55%,#121212); }
.role-cards { display:grid; gap:1.6rem; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); }
.card { background: linear-gradient(150deg,#141414,#101010); padding:1.15rem 1.2rem 1.25rem; border-radius: var(--radius); box-shadow:0 0 0 1px rgba(255,170,60,.08),0 8px 22px -8px rgba(0,0,0,.65); position:relative; overflow:hidden; display:flex; flex-direction:column; gap:.75rem; transition:.4s; }
.card::before { content:""; position:absolute; inset:0; opacity:0; background:radial-gradient(circle at 60% 40%,rgba(255,155,36,.18),transparent 70%); transition:.45s; }
.card:hover::before, .card[aria-expanded="true"]::before { opacity:1; }
.card:hover, .card:focus-within { transform:translateY(-4px); box-shadow:0 10px 34px -6px rgba(0,0,0,.55),0 0 0 1px rgba(255,255,255,.05); }
.card h3 { margin:.2rem 0 .15rem; font-size:1.2rem; }
.card .summary { margin:0 0 .2rem; color:var(--text-dim); }
.card .details { margin-top:auto; padding-top:.6rem; border-top:1px solid rgba(255,255,255,.07); display:none; animation: fadeSlide .4s both; }
.card[aria-expanded="true"] .details { display:block; }
.mini-apply { display:inline-block; margin-top:.65rem; font-weight:600; color:#ffba55; text-shadow:0 0 4px rgba(255,150,40,.6); }
@keyframes fadeSlide { from { opacity:0; transform:translateY(6px); } to { opacity:1; transform:translateY(0); } }

/* Stats */
.stats { background: radial-gradient(circle at 70% 30%,rgba(255,150,40,.18),transparent 60%), var(--bg); }
.stat-grid { display:grid; gap:1.4rem; grid-template-columns:repeat(auto-fit,minmax(160px,1fr)); margin-top:1.5rem; }
.stat { background: #141414; padding:1.3rem 1.1rem; border-radius: var(--radius); text-align:center; box-shadow:0 0 0 1px rgba(255,155,36,.08),0 6px 16px -6px rgba(0,0,0,.7); }
.stat .number { font-size:2rem; font-weight:700; display:block; color:#ffbe61; text-shadow: var(--glow-text); }
.stat .label { font-size:.8rem; text-transform:uppercase; letter-spacing:1px; color:var(--text-dim); }

/* Carousel */
.testimonials { background: linear-gradient(180deg,#0a0a0a,#141414); }
.carousel { position:relative; overflow:hidden; max-width:780px; margin:1rem auto 0; }
.carousel-track { display:flex; transition: transform .6s cubic-bezier(.65,.05,.36,1); }
.slide { min-width:100%; padding:1rem 1.3rem 2.2rem; opacity:.35; filter:blur(2px); transition:.6s; }
.slide.active { opacity:1; filter:none; }
.slide blockquote { font-size:1.15rem; margin:0 0 1rem; line-height:1.5; position:relative; }
.slide blockquote::before { content:"“"; font-size:3.5rem; position:absolute; left:-.4rem; top:-1.2rem; opacity:.2; }
.carousel-btn { position:absolute; top:50%; transform:translateY(-50%); background:var(--bg-soft); border:none; width:46px; height:46px; border-radius:50%; font-size:1.5rem; color:var(--text); display:grid; place-items:center; box-shadow:var(--shadow); }
.carousel-btn:hover { background:var(--accent); }
.carousel-btn.prev { left:-12px; }
.carousel-btn.next { right:-12px; }
@media (max-width:680px){ .carousel-btn.prev { left:6px;} .carousel-btn.next { right:6px;} }

/* Timeline */
.timeline { list-style:none; margin:2.2rem 0 0; padding:0; display:grid; gap:1.2rem; counter-reset: step; }
.timeline li { background: #141414; padding:1rem 1.1rem 1.1rem 3.3rem; border-radius: var(--radius); position:relative; font-weight:500; box-shadow:0 0 0 1px rgba(255,170,60,.08),0 8px 18px -10px rgba(0,0,0,.65); }
.timeline li span { position:absolute; left:1rem; top:50%; transform:translateY(-50%); width:36px; height:36px; background:#ff9b24; border-radius:50%; display:grid; place-items:center; font-weight:600; box-shadow:var(--glow-text); color:#141414; }

/* Accordion */
.accordion .item { border-bottom:1px solid rgba(255,255,255,.08); }
.question { background:none; border:none; color:inherit; width:100%; text-align:left; padding:1rem 0; font-size:1.05rem; font-weight:600; position:relative; }
.question::after { content:"+"; position:absolute; right:0; top:50%; transform:translateY(-50%); transition:.3s; }
.question[aria-expanded="true"]::after { content:"–"; }
.answer { padding:0 0 1rem; color:var(--text-dim); }

/* Form */
form { display:flex; flex-direction:column; gap:1.2rem; }
.form-row { display:flex; gap:1.2rem; flex-wrap:wrap; }
.form-row label { flex:1 1 250px; }
label { display:flex; flex-direction:column; gap:.4rem; font-size:.9rem; font-weight:600; color:var(--text-dim); }
input, select, textarea { background: var(--bg-alt); color:var(--text); border:1px solid rgba(255,255,255,.09); padding:.85rem 1rem; border-radius:10px; font:inherit; resize:vertical; min-height:54px; box-shadow:inset 0 0 0 1px rgba(255,255,255,.02); }
input:focus-visible, select:focus-visible, textarea:focus-visible, .cta-button:focus-visible, .card:focus-visible, .nav-toggle:focus-visible, .theme-toggle:focus-visible { outline:none; box-shadow: var(--focus); }
textarea { min-height:140px; }
.form-footer { display:flex; flex-direction:column; gap:.75rem; }
.form-status { min-height:1.1rem; font-size:.85rem; }

/* Buttons */
.cta-button { --btn-bg: var(--gradient); --btn-text:#fff; display:inline-block; border:none; background:var(--btn-bg); color:var(--btn-text); padding:.9rem 1.4rem; border-radius: 14px; font-weight:600; letter-spacing:.5px; position:relative; overflow:hidden; transition:.4s; text-align:center; }
.cta-button.primary { box-shadow:0 6px 18px -4px rgba(255,155,36,.55); }
.cta-button.ghost { --btn-bg:var(--bg-alt); --btn-text:var(--text); box-shadow:0 2px 6px -2px rgba(0,0,0,.4); }
.cta-button:hover { filter:brightness(1.1); transform:translateY(-2px); }
.cta-button:active { transform:translateY(0); }

/* Contact */
.contact-list { list-style:none; padding:0; margin:1.4rem 0 0; display:flex; gap:1.4rem; flex-wrap:wrap; }
.contact-list a { background: var(--bg-alt); padding:.7rem 1rem; border-radius:10px; box-shadow: var(--shadow); }
.contact-list a:hover { background: var(--accent); color:#fff; }

/* Footer */
.footer { background: #09090c; padding:3.5rem 1.1rem 2rem; position:relative; margin-top:4rem; }
[data-theme="light"] .footer { background:#111827; color:#fff; }
.footer-grid { display:grid; gap:2.2rem; grid-template-columns: repeat(auto-fit,minmax(200px,1fr)); align-items:start; }
.f-brand p { color:var(--text-dim); margin:.6rem 0 0; }
.f-nav ul { list-style:none; padding:0; margin:0; display:grid; gap:.5rem; }
.f-nav a { font-weight:500; }
.f-meta { font-size:.8rem; color:var(--text-dim); display:flex; flex-direction:column; gap:.35rem; }
.back-to-top { position:absolute; right:1rem; bottom:1rem; background:#141414; border:none; width:46px; height:46px; border-radius:50%; color:#ffc470; font-size:1.2rem; box-shadow:0 0 0 1px rgba(255,170,60,.12),0 0 18px -6px rgba(255,155,36,.4); }
.back-to-top:hover { background:var(--accent); }

/* Back to top visibility */
.back-to-top.hidden { opacity:0; pointer-events:none; transform: translateY(20px); transition:.4s; }
.back-to-top:not(.hidden) { transition:.4s; }

/* Animations on scroll */
[data-animate] { opacity:0; transform: translateY(40px); transition: .9s cubic-bezier(.16,.84,.42,1); }
[data-animate].in { opacity:1; transform:none; }

/* Responsive nav */
@media (max-width: 920px){
  .nav-toggle { display:inline-block; }
  .primary-nav { position:absolute; top:100%; right:1rem; background:var(--bg-alt); padding:1rem 1.2rem; border-radius:16px; box-shadow: var(--shadow); opacity:0; transform: translateY(-10px); pointer-events:none; transition:.4s; }
  .primary-nav.open { opacity:1; transform: translateY(0); pointer-events:auto; }
  .primary-nav ul { flex-direction:column; align-items:stretch; }
  .primary-nav a, .primary-nav button { padding:.6rem 0; }
}

/* Smaller devices adjustments */
@media (max-width:600px){
  .hero h1 { font-size: clamp(2.3rem,11vw,3rem); }
  .trust-badges div { min-width:100px; }
  .carousel-btn { display:none; }
  .slide { padding: .5rem .5rem 1.8rem; }
}

/* Utility */
.hidden { display:none !important; }

/* Light theme fine-tune */
[data-theme="light"] .card, [data-theme="light"] .stat, [data-theme="light"] .trust-badges div, [data-theme="light"] .timeline li, [data-theme="light"] .contact-list a { background:#ffffff; box-shadow:0 0 0 1px rgba(255,170,60,.15),0 4px 14px -6px rgba(0,0,0,.15); }
[data-theme="light"] .hero-bg { background:radial-gradient(circle at 30% 40%,rgba(255,155,36,.25),transparent 60%),radial-gradient(circle at 70% 60%,rgba(255,210,120,.25),transparent 65%),linear-gradient(130deg,#fff7f0,#ffffff); }

/* Neon stroke utility for SVG paths */
.neon-stroke { stroke:#ffae42; filter: drop-shadow(0 0 4px rgba(255,170,70,.7)) drop-shadow(0 0 12px rgba(255,170,70,.5)); }

