/* =========================================================
   ARTIWEB ACADEMY — Design System
   Bleu marine #0A1128 / Bleu inter #0F2557 / Rouge #E63946
   Or accent #FFD166 / Blanc #FFFFFF / Gris clair #F7F8FA
   Display: Space Grotesk — Corps: Inter — Mono: JetBrains Mono
   ========================================================= */

:root{
  --navy-950:#070D1F;
  --navy-900:#0A1128;
  --navy-800:#0F2557;
  --navy-700:#163571;
  --red-600:#E63946;
  --red-700:#C42836;
  --gold-400:#FFD166;
  --white:#FFFFFF;
  --grey-50:#F7F8FA;
  --grey-100:#EDEFF4;
  --grey-300:#C7CCDA;
  --grey-500:#7C84A0;
  --grey-700:#4A5170;
  --ink:#0A1128;

  --font-display:'Space Grotesk', sans-serif;
  --font-body:'Inter', sans-serif;
  --font-mono:'JetBrains Mono', monospace;

  --radius-s:8px;
  --radius-m:14px;
  --radius-l:22px;
  --shadow-card:0 10px 30px -12px rgba(10,17,40,.18);
  --shadow-red:0 14px 32px -10px rgba(230,57,70,.45);
  --container:1180px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto;}
  *{animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important;}
}

body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--white);
  -webkit-font-smoothing:antialiased;
  line-height:1.55;
}

h1,h2,h3,h4{
  font-family:var(--font-display);
  margin:0 0 .5em;
  line-height:1.1;
  letter-spacing:-.01em;
  color:var(--navy-900);
}
h1{font-size:clamp(2.4rem,4.2vw,3.6rem); font-weight:600;}
h2{font-size:clamp(1.8rem,3vw,2.5rem); font-weight:600;}
h3{font-size:1.3rem; font-weight:600;}
p{margin:0 0 1em; color:var(--grey-700);}
a{color:inherit; text-decoration:none;}
img{max-width:100%; display:block;}
ul{margin:0; padding:0;}
button{font-family:inherit; cursor:pointer;}

:focus-visible{
  outline:3px solid var(--gold-400);
  outline-offset:2px;
  border-radius:4px;
}

.container{
  max-width:var(--container);
  margin:0 auto;
  padding:0 24px;
}

.eyebrow{
  font-family:var(--font-mono);
  font-size:.74rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--red-600);
  display:flex;
  align-items:center;
  gap:8px;
  margin-bottom:14px;
  font-weight:600;
}
.eyebrow::before{
  content:"";
  width:7px;height:7px;border-radius:50%;
  background:var(--red-600);
  box-shadow:0 0 0 4px rgba(230,57,70,.18);
}

.section{padding:88px 0;}
.section--tight{padding:56px 0;}
.section--navy{background:var(--navy-900); color:var(--white);}
.section--navy h2, .section--navy h3{color:var(--white);}
.section--navy p{color:var(--grey-300);}
.section--grey{background:var(--grey-50);}

.section-head{
  max-width:680px;
  margin-bottom:48px;
}
.section-head.center{margin-left:auto; margin-right:auto; text-align:center;}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-family:var(--font-body);
  font-weight:600;
  font-size:.95rem;
  padding:14px 26px;
  border-radius:999px;
  border:none;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease;
  white-space:nowrap;
}
.btn:hover{transform:translateY(-2px);}
.btn-primary{
  background:var(--red-600);
  color:var(--white);
  box-shadow:var(--shadow-red);
}
.btn-primary:hover{background:var(--red-700);}
.btn-ghost{
  background:transparent;
  color:var(--white);
  border:1.5px solid rgba(255,255,255,.35);
}
.btn-ghost:hover{border-color:var(--white); background:rgba(255,255,255,.08);}
.btn-dark-ghost{
  background:transparent;
  color:var(--navy-900);
  border:1.5px solid var(--grey-300);
}
.btn-dark-ghost:hover{border-color:var(--navy-900);}
.btn-block{width:100%; justify-content:center;}
.btn-sm{padding:10px 18px; font-size:.85rem;}

/* ---------- Header ---------- */
.site-header{
  position:sticky; top:0; z-index:200;
  background:rgba(10,17,40,.92);
  backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.nav{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 24px;
  max-width:var(--container);
  margin:0 auto;
}
.logo{
  display:flex; align-items:center; gap:10px;
  font-family:var(--font-display);
  font-weight:700;
  font-size:1.2rem;
  color:var(--white);
}
.logo-mark{
  width:36px;height:36px;border-radius:10px;
  background:linear-gradient(135deg, var(--red-600), var(--navy-700));
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-mono);
  font-size:.85rem; font-weight:700; color:var(--white);
}
.logo-mark span{color:var(--gold-400);}

.nav-links{
  display:flex; align-items:center; gap:28px;
  list-style:none;
}
.nav-links a{
  font-size:.92rem; font-weight:500;
  color:var(--grey-300);
  position:relative;
  padding:6px 0;
  transition:color .15s ease;
}
.nav-links a:hover, .nav-links a.active{color:var(--white);}
.nav-links a.active::after{
  content:""; position:absolute; left:0; right:0; bottom:-4px;
  height:2px; background:var(--red-600); border-radius:2px;
}
.has-dropdown{position:relative;}
.dropdown{
  position:absolute; top:calc(100% + 14px); left:-16px;
  background:var(--white);
  border-radius:var(--radius-m);
  box-shadow:0 18px 40px -10px rgba(0,0,0,.35);
  padding:10px;
  min-width:240px;
  display:none;
  flex-direction:column;
}
.has-dropdown:hover .dropdown,
.has-dropdown:focus-within .dropdown{display:flex;}
.dropdown a{
  color:var(--navy-900) !important;
  padding:10px 14px;
  border-radius:var(--radius-s);
  font-size:.9rem;
}
.dropdown a:hover{background:var(--grey-50); color:var(--red-600) !important;}

.nav-cta{display:flex; align-items:center; gap:14px;}
.nav-toggle{
  display:none;
  background:none; border:none; color:var(--white);
  font-size:1.6rem;
}

@media (max-width: 920px){
  .nav-links{
    position:fixed; inset:64px 0 0 0;
    background:var(--navy-900);
    flex-direction:column; align-items:flex-start;
    padding:24px;
    gap:6px;
    transform:translateX(100%);
    transition:transform .25s ease;
    overflow-y:auto;
  }
  .nav-links.open{transform:translateX(0);}
  .nav-links a{width:100%; padding:14px 4px;}
  .dropdown{position:static; display:flex !important; box-shadow:none; background:rgba(255,255,255,.04); margin:4px 0;}
  .dropdown a{color:var(--grey-300) !important;}
  .nav-toggle{display:block;}
  .nav-cta .btn-sm{display:none;}
}

/* ---------- Hero ---------- */
.hero{
  background:radial-gradient(circle at 80% -10%, rgba(230,57,70,.25), transparent 45%), var(--navy-900);
  color:var(--white);
  padding:56px 0 90px;
  overflow:hidden;
  position:relative;
}
.ticker{
  font-family:var(--font-mono);
  font-size:.78rem;
  color:var(--gold-400);
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.1);
  border-radius:999px;
  padding:9px 18px;
  display:inline-flex; align-items:center; gap:10px;
  margin-bottom:32px;
  overflow:hidden;
  white-space:nowrap;
  max-width:100%;
}
.ticker .dot{width:6px;height:6px;border-radius:50%;background:var(--gold-400); flex-shrink:0;}
.ticker-track{
  display:inline-flex;
  gap:28px;
  animation:scrollTicker 18s linear infinite;
}
@keyframes scrollTicker{
  from{transform:translateX(0);}
  to{transform:translateX(-50%);}
}

.hero-grid{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:48px;
  align-items:center;
}
.hero h1{color:var(--white); margin-bottom:20px;}
.hero h1 em{
  font-style:normal; color:var(--gold-400);
}
.hero-sub{font-size:1.08rem; color:var(--grey-300); max-width:520px; margin-bottom:30px;}
.hero-cta{display:flex; gap:14px; flex-wrap:wrap; margin-bottom:34px;}
.hero-trust{
  display:flex; gap:28px; flex-wrap:wrap;
  font-family:var(--font-mono); font-size:.8rem; color:var(--grey-300);
}
.hero-trust b{color:var(--white); font-size:1.3rem; display:block; font-family:var(--font-display);}

.hero-visual{position:relative; height:420px;}
.skill-card{
  position:absolute;
  width:230px;
  background:var(--white);
  color:var(--navy-900);
  border-radius:var(--radius-m);
  padding:18px;
  box-shadow:0 24px 50px -12px rgba(0,0,0,.45);
}
.skill-card .tag{
  font-family:var(--font-mono); font-size:.68rem; text-transform:uppercase;
  color:var(--red-600); letter-spacing:.08em; margin-bottom:8px; display:block;
}
.skill-card h4{font-size:1rem; margin-bottom:6px;}
.skill-card p{font-size:.8rem; margin:0; color:var(--grey-700);}
.skill-card.c1{top:0; left:10%; transform:rotate(-6deg); z-index:3;}
.skill-card.c2{top:120px; left:42%; transform:rotate(4deg); z-index:4; border:2px solid var(--gold-400);}
.skill-card.c3{top:255px; left:6%; transform:rotate(3deg); z-index:2;}
.skill-card.c4{top:230px; left:58%; transform:rotate(-3deg); z-index:1; opacity:.92;}

@media (max-width: 980px){
  .hero-grid{grid-template-columns:1fr;}
  .hero-visual{height:340px; max-width:480px; margin:0 auto;}
  .skill-card{width:190px; padding:14px;}
}

/* ---------- Logos / trust bar ---------- */
.logo-bar{
  display:flex; justify-content:center; flex-wrap:wrap; gap:42px;
  padding:30px 0;
  border-top:1px solid var(--grey-100);
  border-bottom:1px solid var(--grey-100);
  font-family:var(--font-mono); font-size:.8rem; color:var(--grey-500); letter-spacing:.04em;
}

/* ---------- Cards grids ---------- */
.grid{display:grid; gap:26px;}
.grid-3{grid-template-columns:repeat(3,1fr);}
.grid-4{grid-template-columns:repeat(4,1fr);}
.grid-2{grid-template-columns:repeat(2,1fr);}
@media (max-width:980px){
  .grid-3, .grid-4{grid-template-columns:repeat(2,1fr);}
}
@media (max-width:640px){
  .grid-2, .grid-3, .grid-4{grid-template-columns:1fr;}
}

.card{
  background:var(--white);
  border:1px solid var(--grey-100);
  border-radius:var(--radius-l);
  padding:30px;
  box-shadow:var(--shadow-card);
  transition:transform .2s ease, box-shadow .2s ease;
}
.card:hover{transform:translateY(-4px); box-shadow:0 22px 44px -14px rgba(10,17,40,.22);}
.card .icon{
  width:46px;height:46px;border-radius:12px;
  display:flex; align-items:center; justify-content:center;
  background:rgba(230,57,70,.1); color:var(--red-600);
  margin-bottom:18px; font-size:1.3rem;
}
.card .meta{
  font-family:var(--font-mono); font-size:.75rem; color:var(--grey-500);
  display:flex; gap:14px; margin-top:14px; flex-wrap:wrap;
}
.card .price{
  font-family:var(--font-display); font-weight:700; color:var(--navy-900); font-size:1.3rem;
}
.card .price span{font-size:.8rem; color:var(--grey-500); font-weight:400; font-family:var(--font-body);}

/* Program / formation card */
.program-card{
  background:var(--white);
  border-radius:var(--radius-l);
  border:1px solid var(--grey-100);
  overflow:hidden;
  box-shadow:var(--shadow-card);
  display:flex; flex-direction:column;
  transition:transform .2s ease;
}
.program-card:hover{transform:translateY(-5px);}
.program-card .ph{
  height:150px;
  background:linear-gradient(135deg, var(--navy-900), var(--navy-700));
  display:flex; align-items:flex-end; padding:18px;
  position:relative;
}
.program-card .ph .badge{
  position:absolute; top:16px; right:16px;
  background:var(--red-600); color:var(--white);
  font-family:var(--font-mono); font-size:.68rem;
  padding:4px 10px; border-radius:999px; text-transform:uppercase;
}
.program-card .ph span{font-family:var(--font-mono); color:var(--gold-400); font-size:.75rem;}
.program-card .body{padding:24px; flex:1; display:flex; flex-direction:column;}
.program-card ul{margin:14px 0; padding-left:0; list-style:none;}
.program-card li{
  font-size:.88rem; color:var(--grey-700); margin-bottom:8px; padding-left:22px; position:relative;
}
.program-card li::before{
  content:"✓"; position:absolute; left:0; color:var(--red-600); font-weight:700;
}
.program-card .footer{
  display:flex; align-items:center; justify-content:space-between;
  margin-top:auto; padding-top:16px; border-top:1px solid var(--grey-100);
}

/* ---------- Stats strip ---------- */
.stats-strip{
  display:grid; grid-template-columns:repeat(4,1fr); gap:24px;
  text-align:center;
}
.stats-strip .stat b{
  font-family:var(--font-display); font-size:2.4rem; color:var(--white); display:block;
}
.stats-strip .stat span{font-family:var(--font-mono); font-size:.8rem; color:var(--grey-300); text-transform:uppercase; letter-spacing:.04em;}
@media (max-width:768px){.stats-strip{grid-template-columns:repeat(2,1fr);}}

/* ---------- Steps ---------- */
.steps{display:flex; flex-direction:column; gap:0;}
.step{
  display:grid; grid-template-columns:70px 1fr; gap:22px;
  padding:26px 0; border-bottom:1px solid var(--grey-100);
}
.step:last-child{border-bottom:none;}
.step .num{
  font-family:var(--font-mono); font-size:1.6rem; color:var(--red-600); font-weight:700;
}
.step h4{margin-bottom:6px;}

/* ---------- FAQ ---------- */
.faq-item{
  border-bottom:1px solid var(--grey-100);
}
.faq-q{
  width:100%; text-align:left; background:none; border:none;
  padding:22px 0; display:flex; justify-content:space-between; align-items:center;
  font-family:var(--font-display); font-size:1.05rem; font-weight:600; color:var(--navy-900);
}
.faq-q .plus{font-size:1.4rem; color:var(--red-600); transition:transform .2s ease;}
.faq-item.open .plus{transform:rotate(45deg);}
.faq-a{
  max-height:0; overflow:hidden; transition:max-height .25s ease;
  color:var(--grey-700); font-size:.94rem;
}
.faq-item.open .faq-a{padding-bottom:22px;}

/* ---------- Testimonials ---------- */
.testi-card{
  background:var(--white); border-radius:var(--radius-l); padding:28px;
  border:1px solid var(--grey-100); box-shadow:var(--shadow-card);
}
.testi-stars{color:var(--gold-400); font-size:.9rem; margin-bottom:12px;}
.testi-person{display:flex; align-items:center; gap:12px; margin-top:18px;}
.testi-avatar{
  width:44px;height:44px;border-radius:50%;
  background:linear-gradient(135deg,var(--red-600),var(--navy-700));
  display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-family:var(--font-display);
}
.testi-video{
  position:relative; border-radius:var(--radius-l); overflow:hidden; aspect-ratio:16/10;
  background:var(--navy-900); display:flex; align-items:center; justify-content:center;
  cursor:pointer;
}
.testi-video .play{
  width:60px;height:60px;border-radius:50%; background:var(--red-600); color:#fff;
  display:flex; align-items:center; justify-content:center; font-size:1.3rem;
  box-shadow:var(--shadow-red);
}
.testi-video .label{
  position:absolute; bottom:14px; left:14px; color:#fff; font-family:var(--font-mono); font-size:.78rem;
  background:rgba(0,0,0,.45); padding:6px 12px; border-radius:999px;
}

/* ---------- Form ---------- */
.form-card{
  background:var(--white); border-radius:var(--radius-l); padding:34px;
  box-shadow:0 30px 60px -20px rgba(10,17,40,.35);
}
.field{margin-bottom:18px;}
.field label{
  display:block; font-size:.82rem; font-weight:600; color:var(--navy-900); margin-bottom:6px;
}
.field input, .field select, .field textarea{
  width:100%; padding:13px 16px; border-radius:var(--radius-s);
  border:1.5px solid var(--grey-300); font-family:var(--font-body); font-size:.95rem;
  background:var(--white); color:var(--ink);
}
.field input:focus, .field select:focus, .field textarea:focus{
  border-color:var(--red-600); outline:none;
}
.field-row{display:grid; grid-template-columns:1fr 1fr; gap:14px;}
@media (max-width:560px){.field-row{grid-template-columns:1fr;}}

/* ---------- WhatsApp floating button ---------- */
.whatsapp-float{
  position:fixed; bottom:24px; right:24px; z-index:300;
  width:60px;height:60px;border-radius:50%;
  background:#25D366; color:#fff;
  display:flex; align-items:center; justify-content:center;
  font-size:1.7rem;
  box-shadow:0 14px 30px -8px rgba(37,211,102,.6);
  animation:pulse 2.4s infinite;
}
@keyframes pulse{
  0%{box-shadow:0 0 0 0 rgba(37,211,102,.5);}
  70%{box-shadow:0 0 0 14px rgba(37,211,102,0);}
  100%{box-shadow:0 0 0 0 rgba(37,211,102,0);}
}

/* ---------- Footer ---------- */
.site-footer{background:var(--navy-950); color:var(--grey-300); padding:64px 0 24px;}
.footer-grid{
  display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:40px;
  padding-bottom:40px; border-bottom:1px solid rgba(255,255,255,.08);
}
.footer-grid h5{
  font-family:var(--font-mono); color:var(--white); font-size:.8rem;
  text-transform:uppercase; letter-spacing:.08em; margin-bottom:16px;
}
.footer-grid ul{list-style:none; display:flex; flex-direction:column; gap:10px;}
.footer-grid a{color:var(--grey-300); font-size:.9rem;}
.footer-grid a:hover{color:var(--white);}
.footer-bottom{
  display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:12px;
  padding-top:24px; font-size:.82rem; color:var(--grey-500);
}
.footer-social{display:flex; gap:14px;}
.footer-social a{
  width:36px;height:36px;border-radius:50%; border:1px solid rgba(255,255,255,.15);
  display:flex; align-items:center; justify-content:center; color:var(--grey-300);
}
@media (max-width:900px){.footer-grid{grid-template-columns:1fr 1fr;}}

/* ---------- Breadcrumb ---------- */
.breadcrumb{
  font-family:var(--font-mono); font-size:.78rem; color:var(--grey-300);
  padding:18px 0; display:flex; gap:8px; align-items:center;
}
.breadcrumb a{color:var(--grey-300);}
.breadcrumb a:hover{color:var(--white);}
.breadcrumb .sep{opacity:.5;}

/* ---------- Page hero (sub pages) ---------- */
.page-hero{
  background:linear-gradient(160deg, var(--navy-900), var(--navy-800));
  color:#fff; padding:24px 0 60px;
}
.page-hero h1{color:#fff; max-width:760px;}
.page-hero p{color:var(--grey-300); max-width:620px; font-size:1.05rem;}

/* ---------- Utility ---------- */
.text-center{text-align:center;}
.mt-0{margin-top:0;}
.tag-pill{
  display:inline-block; font-family:var(--font-mono); font-size:.72rem;
  background:rgba(230,57,70,.1); color:var(--red-600); padding:4px 12px;
  border-radius:999px; margin:0 6px 6px 0; text-transform:uppercase; letter-spacing:.04em;
}
.divider{height:1px; background:var(--grey-100); margin:48px 0;}

.cta-banner{
  background:linear-gradient(135deg, var(--red-600), var(--red-700));
  border-radius:var(--radius-l);
  padding:50px;
  color:#fff;
  display:flex; align-items:center; justify-content:space-between; gap:30px; flex-wrap:wrap;
}
.cta-banner h2{color:#fff; margin-bottom:8px;}
.cta-banner p{color:rgba(255,255,255,.85); margin:0;}
.cta-banner .btn-primary{background:var(--navy-900); box-shadow:none;}
.cta-banner .btn-primary:hover{background:var(--navy-950);}

/* Blog */
.blog-card{
  background:#fff; border:1px solid var(--grey-100); border-radius:var(--radius-l);
  overflow:hidden; box-shadow:var(--shadow-card);
}
.blog-card .ph{height:160px; background:linear-gradient(135deg,var(--navy-800),var(--red-600)); opacity:.9;}
.blog-card .body{padding:22px;}
.blog-card .meta{font-family:var(--font-mono); font-size:.72rem; color:var(--grey-500); margin-bottom:10px; text-transform:uppercase;}
.blog-card h3{font-size:1.08rem;}
.blog-card a.readmore{color:var(--red-600); font-weight:600; font-size:.88rem;}

/* Map embed wrapper */
.map-wrap{border-radius:var(--radius-l); overflow:hidden; box-shadow:var(--shadow-card); height:360px;}
.map-wrap iframe{width:100%; height:100%; border:0;}

/* Skip link */
.skip-link{
  position:absolute; left:-9999px; top:0; background:var(--red-600); color:#fff; padding:10px 16px; z-index:999;
}
.skip-link:focus{left:10px; top:10px;}
