/* =========================================================
   French Ici Tutoring — shared stylesheet
   Aesthetic: refined academic (Oxford common-room) meets
   French atelier. Deep navy, warm ivory, French red, gold.
   Rounded everything. Elegant serif display type.
   ========================================================= */

:root{
  --paper:#FBF7EF;
  --paper-2:#F3EADA;
  --card:#FFFFFF;
  --ink:#16222F;
  --muted:#586676;
  --bleu:#0E2C4E;
  --bleu-2:#16467E;
  --bleu-soft:#E8EFF7;
  --rouge:#B3121B;
  --rouge-2:#8B0E15;
  --rouge-soft:#FBEAEA;
  --or:#B0892B;
  --or-2:#977322;
  --or-soft:#F0E6C8;
  --line:rgba(14,44,78,.13);
  --line-strong:rgba(14,44,78,.22);

  --r-xs:9px;
  --r-sm:13px;
  --r:18px;
  --r-lg:26px;
  --r-xl:34px;
  --r-pill:999px;

  --shadow-sm:0 2px 8px rgba(14,44,78,.06);
  --shadow:0 14px 38px -18px rgba(14,44,78,.30);
  --shadow-lg:0 30px 70px -30px rgba(14,44,78,.40);

  --display:"Cormorant Garamond",Georgia,serif;
  --body:"Lora",Georgia,serif;
  --ui:"Hanken Grotesk",-apple-system,BlinkMacSystemFont,sans-serif;

  --wrap:1140px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--body);
  color:var(--ink);
  background:var(--paper);
  font-size:18px;
  line-height:1.72;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  background-image:
    radial-gradient(1100px 520px at 88% -8%, rgba(22,70,126,.07), transparent 60%),
    radial-gradient(900px 520px at -8% 4%, rgba(176,137,43,.07), transparent 55%);
  background-attachment:fixed;
}
img{max-width:100%;display:block}
a{color:var(--bleu-2);text-decoration:none}
a:hover{color:var(--rouge)}

h1,h2,h3,h4{font-family:var(--display);font-weight:600;line-height:1.08;color:var(--bleu);letter-spacing:.2px;margin:0 0 .4em}
h1{font-size:clamp(2.6rem,6vw,4.4rem);font-weight:700}
h2{font-size:clamp(2rem,4vw,2.9rem)}
h3{font-size:clamp(1.4rem,2.4vw,1.85rem)}
h4{font-size:1.2rem}
p{margin:0 0 1.1rem}

.wrap{max-width:var(--wrap);margin:0 auto;padding:0 26px}
.narrow{max-width:780px;margin-inline:auto}
section{position:relative}

.eyebrow{
  font-family:var(--ui);
  text-transform:uppercase;
  letter-spacing:.26em;
  font-size:.72rem;
  font-weight:700;
  color:var(--rouge);
  display:inline-flex;align-items:center;gap:.6em;
  margin:0 0 1rem;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--or);display:inline-block;border-radius:2px}
.eyebrow.center{justify-content:center}
.eyebrow.center::after{content:"";width:26px;height:2px;background:var(--or);display:inline-block;border-radius:2px}

.lede{font-size:1.22rem;color:#2b3a49;line-height:1.7}
.muted{color:var(--muted)}

/* ---------- tricolore ribbon ---------- */
.ribbon{height:5px;width:100%;background:linear-gradient(90deg,var(--bleu) 0 33.33%, #fff 33.33% 66.66%, var(--rouge) 66.66% 100%)}

/* ---------- header / nav ---------- */
.site-head{position:sticky;top:0;z-index:60;background:rgba(251,247,239,.86);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;gap:22px;padding:14px 26px;max-width:1260px;margin:0 auto}
.brand{display:flex;align-items:center;gap:12px;margin-right:auto;color:var(--bleu)}
.brand:hover{color:var(--bleu)}
.brand .crest{width:42px;height:42px;flex:0 0 auto}
.brand-name{font-family:var(--display);font-weight:700;font-size:1.5rem;line-height:1;letter-spacing:.3px}
.brand-name small{display:block;font-family:var(--ui);font-weight:600;font-size:.58rem;letter-spacing:.32em;text-transform:uppercase;color:var(--or-2);margin-top:5px}

.nav-links{display:flex;align-items:center;gap:4px;font-family:var(--ui);font-weight:600;font-size:.93rem}
.nav-links a{color:var(--ink);padding:9px 13px;border-radius:var(--r-pill);transition:.18s;position:relative}
.nav-links a:hover{color:var(--bleu);background:var(--bleu-soft)}
.nav-links a.active{color:var(--rouge)}
.nav-links a.active::after{content:"";position:absolute;left:13px;right:13px;bottom:2px;height:2px;background:var(--rouge);border-radius:2px}

.has-drop{position:relative}
.has-drop>button{font:inherit;font-family:var(--ui);font-weight:600;color:var(--ink);background:none;border:0;cursor:pointer;padding:9px 13px;border-radius:var(--r-pill);display:inline-flex;align-items:center;gap:6px}
.has-drop>button:hover{color:var(--bleu);background:var(--bleu-soft)}
.has-drop>button svg{width:11px;height:11px;transition:.2s}
.drop{position:absolute;top:calc(100% + 8px);left:0;min-width:268px;background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow);padding:8px;opacity:0;visibility:hidden;transform:translateY(6px);transition:.18s}
.has-drop:hover .drop,.has-drop:focus-within .drop{opacity:1;visibility:visible;transform:translateY(0)}
.has-drop:hover>button svg{transform:rotate(180deg)}
.drop a{display:block;padding:11px 13px;border-radius:var(--r-sm);color:var(--ink);font-size:.92rem}
.drop a:hover{background:var(--bleu-soft);color:var(--bleu)}
.drop a span{display:block;font-family:var(--body);font-size:.82rem;color:var(--muted);font-weight:400;margin-top:2px}

.nav-cta{font-family:var(--ui);font-weight:700;font-size:.9rem;background:var(--bleu);color:#fff;padding:10px 20px;border-radius:var(--r-pill);transition:.2s;border:1px solid var(--bleu)}
.nav-cta:hover{background:var(--rouge);border-color:var(--rouge);color:#fff;transform:translateY(-1px)}
.nav-toggle{display:none;background:none;border:1px solid var(--line-strong);border-radius:var(--r-sm);width:46px;height:42px;cursor:pointer;align-items:center;justify-content:center}
.nav-toggle span,.nav-toggle span::before,.nav-toggle span::after{content:"";display:block;width:20px;height:2px;background:var(--bleu);border-radius:2px;position:relative;transition:.2s}
.nav-toggle span::before{position:absolute;top:-6px}
.nav-toggle span::after{position:absolute;top:6px}

/* ---------- buttons ---------- */
.btn{font-family:var(--ui);font-weight:700;font-size:.98rem;display:inline-flex;align-items:center;gap:.55em;padding:14px 28px;border-radius:var(--r-pill);border:1px solid transparent;cursor:pointer;transition:.2s;line-height:1}
.btn svg{width:16px;height:16px}
.btn-primary{background:var(--bleu);color:#fff;border-color:var(--bleu)}
.btn-primary:hover{background:var(--rouge);border-color:var(--rouge);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow)}
.btn-rouge{background:var(--rouge);color:#fff;border-color:var(--rouge)}
.btn-rouge:hover{background:var(--rouge-2);border-color:var(--rouge-2);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow)}
.btn-ghost{background:transparent;color:var(--bleu);border-color:var(--line-strong)}
.btn-ghost:hover{border-color:var(--bleu);background:var(--bleu-soft);color:var(--bleu);transform:translateY(-2px)}
.btn-light{background:#fff;color:var(--bleu);border-color:#fff}
.btn-light:hover{background:var(--or-soft);border-color:var(--or-soft);transform:translateY(-2px)}
.btn-row{display:flex;flex-wrap:wrap;gap:14px}

/* ---------- hero ---------- */
.hero{padding:84px 0 70px;position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background:
  radial-gradient(620px 360px at 78% 18%, rgba(22,70,126,.10), transparent 70%),
  radial-gradient(520px 320px at 12% 90%, rgba(179,18,27,.07), transparent 70%);pointer-events:none}
.hero .wrap{position:relative}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:54px;align-items:center}
.hero h1{margin-bottom:.25em}
.hero h1 .accent{font-style:italic;color:var(--rouge)}
.hero .lede{max-width:36ch}
.hero-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r-xl);box-shadow:var(--shadow-lg);padding:34px;position:relative}
.hero-card::before{content:"";position:absolute;inset:10px;border:1px solid var(--or-soft);border-radius:calc(var(--r-xl) - 10px);pointer-events:none}
.hero-card .seal{width:74px;height:74px;margin:0 auto 14px}
.hero-card h3{text-align:center;margin-bottom:.2em}
.hero-card .price-big{text-align:center;font-family:var(--display);font-size:3rem;font-weight:700;color:var(--bleu);line-height:1}
.hero-card .price-big span{font-family:var(--ui);font-size:.9rem;font-weight:600;color:var(--muted);display:block;margin-top:6px;letter-spacing:.04em}
.hero-card ul{list-style:none;padding:0;margin:18px 0 22px;font-family:var(--ui);font-size:.95rem}
.hero-card ul li{display:flex;gap:10px;padding:7px 0;border-bottom:1px dashed var(--line)}
.hero-card ul li:last-child{border-bottom:0}
.hero-card ul li::before{content:"";flex:0 0 auto;width:18px;height:18px;border-radius:50%;background:var(--bleu-soft) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2316467E' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") center/12px no-repeat;margin-top:3px}

/* ---------- trust strip ---------- */
.trust{background:var(--bleu);color:#eaf0f7}
.trust .wrap{display:flex;flex-wrap:wrap;gap:14px 40px;justify-content:center;padding:20px 26px;font-family:var(--ui);font-weight:600;font-size:.92rem;letter-spacing:.02em}
.trust .wrap span{display:inline-flex;align-items:center;gap:10px}
.trust .wrap span::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--or)}

/* ---------- section scaffolding ---------- */
.sec{padding:78px 0}
.sec-alt{background:var(--paper-2)}
.sec-navy{background:var(--bleu);color:#e9eff6}
.sec-navy h1,.sec-navy h2,.sec-navy h3{color:#fff}
.sec-navy .eyebrow{color:var(--or-soft)}
.sec-navy .lede,.sec-navy p{color:#cdd9e8}
.sec-head{max-width:720px;margin:0 auto 48px;text-align:center}
.sec-head.left{margin-left:0;text-align:left}

/* ---------- cards / grids ---------- */
.grid{display:grid;gap:24px}
.g3{grid-template-columns:repeat(3,1fr)}
.g2{grid-template-columns:repeat(2,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}

.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:32px;box-shadow:var(--shadow-sm);transition:.25s;position:relative;overflow:hidden}
.card:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:var(--or-soft)}
.card .ic{width:56px;height:56px;border-radius:var(--r);background:var(--bleu-soft);display:flex;align-items:center;justify-content:center;margin-bottom:18px;color:var(--bleu-2)}
.card .ic svg{width:28px;height:28px}
.card h3{margin-bottom:.35em}
.card p{font-size:.98rem;color:var(--muted);margin-bottom:1rem}
.card .more{font-family:var(--ui);font-weight:700;font-size:.9rem;color:var(--rouge);display:inline-flex;align-items:center;gap:6px}
.card .more svg{width:15px;height:15px;transition:.2s}
.card:hover .more svg{transform:translateX(4px)}

.audience-card{display:flex;flex-direction:column}
.audience-card .tag{font-family:var(--ui);font-size:.72rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--or-2);margin-bottom:10px}

/* feature list */
.feat{list-style:none;padding:0;margin:0;display:grid;gap:14px}
.feat li{display:flex;gap:14px;align-items:flex-start}
.feat li .b{flex:0 0 auto;width:30px;height:30px;border-radius:50%;background:var(--rouge-soft);color:var(--rouge);display:flex;align-items:center;justify-content:center;font-family:var(--ui);font-weight:700;font-size:.85rem;margin-top:3px}
.feat li b{font-family:var(--ui);color:var(--bleu)}

/* steps */
.steps{counter-reset:s;display:grid;gap:22px;grid-template-columns:repeat(4,1fr)}
.step{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:26px}
.step::before{counter-increment:s;content:"0" counter(s);font-family:var(--display);font-weight:700;font-size:2.1rem;color:var(--or);display:block;line-height:1;margin-bottom:10px}
.step h4{font-family:var(--ui);font-size:1.02rem;color:var(--bleu)}
.step p{font-size:.93rem;color:var(--muted);margin:0}

/* ---------- pricing ---------- */
.price-wrap{display:grid;grid-template-columns:repeat(2,1fr);gap:26px;max-width:880px;margin:0 auto}
.price-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r-xl);padding:38px;position:relative;box-shadow:var(--shadow-sm);transition:.25s}
.price-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.price-card.feature{border-color:var(--or);box-shadow:var(--shadow)}
.price-card .ribbon-tag{position:absolute;top:22px;right:-2px;background:var(--rouge);color:#fff;font-family:var(--ui);font-weight:700;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;padding:7px 16px 7px 14px;border-radius:var(--r-pill) 0 0 var(--r-pill)}
.price-card h3{font-family:var(--ui);font-weight:700;font-size:1.15rem;color:var(--bleu);text-transform:uppercase;letter-spacing:.06em}
.price-card .amt{font-family:var(--display);font-weight:700;font-size:3.6rem;color:var(--bleu);line-height:1;margin:6px 0}
.price-card .amt small{font-family:var(--ui);font-size:1rem;font-weight:600;color:var(--muted)}
.price-card .per{font-family:var(--ui);font-size:.92rem;color:var(--muted);margin-bottom:18px}
.price-card .save{display:inline-block;font-family:var(--ui);font-weight:700;font-size:.82rem;color:var(--rouge);background:var(--rouge-soft);padding:5px 12px;border-radius:var(--r-pill);margin-bottom:18px}
.fx{list-style:none;padding:16px 0;margin:0 0 22px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);display:grid;grid-template-columns:repeat(2,1fr);gap:10px 18px;font-family:var(--ui);font-size:.92rem}
.fx li{display:flex;justify-content:space-between;gap:10px}
.fx li b{color:var(--bleu)}
.fx li span{color:var(--muted)}

/* ---------- prose (blog / cefr / about) ---------- */
.prose{font-size:1.06rem;line-height:1.8}
.prose h2{margin-top:1.8em}
.prose h3{margin-top:1.5em;color:var(--bleu-2)}
.prose p{margin-bottom:1.2rem}
.prose ul,.prose ol{margin:0 0 1.3rem;padding-left:1.3rem}
.prose li{margin-bottom:.5rem}
.prose blockquote{margin:1.6rem 0;padding:18px 26px;border-left:4px solid var(--or);background:var(--paper-2);border-radius:0 var(--r) var(--r) 0;font-style:italic;color:#2b3a49}
.prose strong{color:var(--bleu)}
.prose a{border-bottom:1px solid var(--or-soft)}
.prose hr{border:0;height:1px;background:var(--line);margin:2.4rem 0}
.fr{font-style:italic;color:var(--bleu-2)}

/* ---------- CEFR ---------- */
.lvl{display:grid;grid-template-columns:auto 1fr;gap:26px;align-items:start;background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:30px;margin-bottom:22px;box-shadow:var(--shadow-sm);transition:.2s}
.lvl:hover{box-shadow:var(--shadow);border-color:var(--or-soft)}
.lvl .badge{width:96px;height:96px;border-radius:var(--r);display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;font-family:var(--display);font-weight:700}
.lvl .badge b{font-size:2.4rem;line-height:1}
.lvl .badge small{font-family:var(--ui);font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700;margin-top:4px;opacity:.9}
.lvl .badge.a1{background:linear-gradient(150deg,#2f7d4f,#1f5e3a)}
.lvl .badge.a2{background:linear-gradient(150deg,#2c8a8a,#1d6464)}
.lvl .badge.b1{background:linear-gradient(150deg,#16467E,#0E2C4E)}
.lvl .badge.b2{background:linear-gradient(150deg,#5a4ba8,#3c3076)}
.lvl .badge.c1{background:linear-gradient(150deg,#B0892B,#977322)}
.lvl .badge.c2{background:linear-gradient(150deg,#B3121B,#8B0E15)}
.lvl h3{margin-bottom:.2em}
.lvl .nick{font-family:var(--ui);font-weight:600;font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;color:var(--or-2);margin-bottom:.6em}
.lvl p{font-size:.98rem;margin-bottom:.8rem}
.lvl .can{list-style:none;padding:0;margin:0;display:grid;gap:7px}
.lvl .can li{display:flex;gap:10px;font-size:.95rem;color:#33414f}
.lvl .can li::before{content:"";flex:0 0 auto;width:16px;height:16px;border-radius:50%;background:var(--or-soft);margin-top:4px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='11' viewBox='0 0 24 24' fill='none' stroke='%23977322' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");background-position:center;background-repeat:no-repeat}

.table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-sm)}
table.tbl{width:100%;border-collapse:collapse;font-family:var(--ui);font-size:.95rem;background:var(--card);min-width:520px}
table.tbl th,table.tbl td{padding:14px 18px;text-align:left;border-bottom:1px solid var(--line)}
table.tbl thead th{background:var(--bleu);color:#fff;font-weight:600;letter-spacing:.02em}
table.tbl tbody tr:last-child td{border-bottom:0}
table.tbl tbody tr:nth-child(even){background:var(--paper)}
table.tbl td b{color:var(--bleu)}

/* ---------- blog ---------- */
.post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.post{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-sm);transition:.25s}
.post:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:var(--or-soft)}
.post .pic{height:118px;background:var(--bleu);position:relative;overflow:hidden}
.post .pic.v1{background:linear-gradient(135deg,#16467E,#0E2C4E)}
.post .pic.v2{background:linear-gradient(135deg,#B0892B,#977322)}
.post .pic.v3{background:linear-gradient(135deg,#B3121B,#8B0E15)}
.post .pic .mono{position:absolute;right:-10px;bottom:-26px;font-family:var(--display);font-weight:700;font-size:7rem;color:rgba(255,255,255,.14);line-height:1}
.post .pic .cat{position:absolute;left:18px;top:16px;font-family:var(--ui);font-weight:700;font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:#fff;background:rgba(0,0,0,.2);padding:5px 12px;border-radius:var(--r-pill)}
.post .body{padding:24px;display:flex;flex-direction:column;flex:1}
.post .body h3{font-size:1.3rem;margin-bottom:.35em}
.post .body p{font-size:.95rem;color:var(--muted);flex:1}
.post .meta{font-family:var(--ui);font-size:.78rem;color:var(--muted);letter-spacing:.04em;margin-top:12px}

.article-head{padding:64px 0 28px;text-align:center}
.article-head .kicker{font-family:var(--ui);font-weight:700;letter-spacing:.18em;text-transform:uppercase;font-size:.74rem;color:var(--rouge)}
.article-head h1{max-width:18ch;margin:14px auto .3em;font-size:clamp(2.2rem,4.6vw,3.4rem)}
.article-head .byline{font-family:var(--ui);font-size:.88rem;color:var(--muted)}

/* ---------- FAQ ---------- */
.faq{max-width:820px;margin:0 auto;display:grid;gap:14px}
.faq details{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow-sm);overflow:hidden}
.faq summary{cursor:pointer;list-style:none;padding:20px 24px;font-family:var(--ui);font-weight:600;font-size:1.04rem;color:var(--bleu);display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq summary::-webkit-details-marker{display:none}
.faq summary .pm{flex:0 0 auto;width:26px;height:26px;border-radius:50%;background:var(--bleu-soft);position:relative;transition:.2s}
.faq summary .pm::before,.faq summary .pm::after{content:"";position:absolute;background:var(--bleu-2);border-radius:2px;top:50%;left:50%;transform:translate(-50%,-50%)}
.faq summary .pm::before{width:12px;height:2px}
.faq summary .pm::after{width:2px;height:12px;transition:.2s}
.faq details[open] summary .pm::after{transform:translate(-50%,-50%) rotate(90deg);opacity:0}
.faq details[open] summary .pm{background:var(--rouge-soft)}
.faq details[open] summary .pm::before{background:var(--rouge)}
.faq .ans{padding:0 24px 22px;color:var(--muted);font-size:1rem}

/* ---------- callout / CTA band ---------- */
.cta-band{background:linear-gradient(135deg,var(--bleu),#0a2138);color:#fff;border-radius:var(--r-xl);padding:54px;text-align:center;position:relative;overflow:hidden}
.cta-band::before{content:"";position:absolute;inset:0;background:radial-gradient(500px 240px at 80% 0,rgba(176,137,43,.25),transparent 60%)}
.cta-band>*{position:relative}
.cta-band h2{color:#fff}
.cta-band p{color:#cdd9e8;max-width:48ch;margin:0 auto 26px}

.callout{background:var(--bleu-soft);border:1px solid var(--line);border-left:4px solid var(--or);border-radius:var(--r);padding:22px 26px;margin:1.6rem 0}
.callout p:last-child{margin:0}

/* split panel */
.split{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.panel{background:var(--card);border:1px solid var(--line);border-radius:var(--r-xl);padding:38px;box-shadow:var(--shadow-sm);position:relative}
.panel::before{content:"";position:absolute;inset:11px;border:1px solid var(--or-soft);border-radius:calc(var(--r-xl) - 11px);pointer-events:none}

/* contact */
.contact-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r-xl);padding:42px;box-shadow:var(--shadow);text-align:center;max-width:620px;margin:0 auto}
.contact-card .seal{width:78px;height:78px;margin:0 auto 18px}
.mail{font-family:var(--display);font-weight:700;font-size:clamp(1.5rem,3.6vw,2.3rem);color:var(--bleu);word-break:break-word}
.mail:hover{color:var(--rouge)}

/* decorative divider */
.flourish{display:flex;align-items:center;justify-content:center;gap:14px;margin:8px 0 0}
.flourish::before,.flourish::after{content:"";height:1px;width:60px;background:var(--line-strong)}
.flourish .dot{width:7px;height:7px;border-radius:50%;border:1.5px solid var(--or);transform:rotate(45deg)}

.pill-tag{display:inline-flex;align-items:center;gap:8px;font-family:var(--ui);font-weight:600;font-size:.82rem;color:var(--bleu);background:#fff;border:1px solid var(--line);padding:8px 16px;border-radius:var(--r-pill);box-shadow:var(--shadow-sm)}

/* ---------- footer ---------- */
.site-foot{background:var(--bleu);color:#c6d2e2;padding:62px 0 0;margin-top:10px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:34px;padding-bottom:40px}
.site-foot .brand-name{color:#fff}
.site-foot .brand-name small{color:var(--or-soft)}
.site-foot p{font-size:.95rem;color:#aebdd1}
.foot-col h4{font-family:var(--ui);font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;color:var(--or-soft);font-weight:700;margin-bottom:16px}
.foot-col a{display:block;color:#c6d2e2;font-size:.95rem;padding:5px 0}
.foot-col a:hover{color:#fff}
.foot-bar{border-top:1px solid rgba(255,255,255,.12);padding:20px 0;font-family:var(--ui);font-size:.82rem;color:#94a6bd;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}
.foot-bar a{color:#94a6bd}.foot-bar a:hover{color:#fff}

/* ---------- reveal animation ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ---------- responsive ---------- */
@media(max-width:980px){
  .hero-grid{grid-template-columns:1fr;gap:38px}
  .hero-card{max-width:440px}
  .g3,.g4,.post-grid,.steps{grid-template-columns:repeat(2,1fr)}
  .split{grid-template-columns:1fr;gap:30px}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:760px){
  body{font-size:17px}
  .nav-links,.nav-cta{display:none}
  .nav-toggle{display:flex}
  .site-head.open .nav-links{display:flex;flex-direction:column;align-items:stretch;position:absolute;top:100%;left:0;right:0;background:var(--paper);border-bottom:1px solid var(--line);padding:14px 18px;gap:2px;box-shadow:var(--shadow)}
  .site-head.open .nav-links a{padding:13px 14px}
  .site-head.open .has-drop{width:100%}
  .site-head.open .has-drop>button{width:100%;justify-content:space-between}
  .site-head.open .drop{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:0;border-left:2px solid var(--or-soft);border-radius:0;margin:2px 0 6px 8px;padding:0}
  .site-head.open .nav-cta{display:inline-flex;justify-content:center;margin-top:8px}
  .sec{padding:56px 0}
  .price-wrap,.g2,.g3,.g4,.post-grid,.steps{grid-template-columns:1fr}
  .lvl{grid-template-columns:1fr;gap:16px}
  .lvl .badge{width:80px;height:80px}
  .cta-band{padding:38px 26px}
  .panel,.contact-card,.hero-card{padding:28px}
  .foot-grid{grid-template-columns:1fr 1fr}
  .fx{grid-template-columns:1fr}
}
@media(max-width:460px){
  .foot-grid{grid-template-columns:1fr}
  .trust .wrap{flex-direction:column;gap:10px}
}
