/* ============================================================
   LE FREELANCEUR — Design System v3 · Gradient & Glow
   ============================================================ */

:root {
  --night: #04342C;
  --night-2: #052a23;
  --ink: #03241e;
  --teal: #1D9E75;
  --teal-light: #5DCAA5;
  --mint: #E1F5EE;

  --text: #EAF3EF;
  --text-muted: #9DBDB0;
  --text-dim: #6E948A;
  --on-light: #0A2620;
  --on-light-muted: #3F635A;

  --glass: rgba(255,255,255,0.045);
  --glass-2: rgba(255,255,255,0.07);
  --glass-border: rgba(255,255,255,0.12);
  --glass-border-hover: rgba(93,202,165,0.55);

  --accent: var(--teal);
  --accent-hover: #25b487;
  --glow: 0 0 30px rgba(29,158,117,0.55);
  --glow-soft: 0 0 60px rgba(29,158,117,0.25);

  --r-component: 4px;
  --r-card: 14px;
  --r-pill: 999px;

  --s-1:4px; --s-2:8px; --s-3:12px; --s-4:16px; --s-5:20px; --s-6:24px;
  --s-8:32px; --s-10:40px; --s-12:48px; --s-16:64px; --s-20:80px; --s-24:96px;

  --font-title: Georgia, 'Times New Roman', serif;
  --font-body: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --maxw: 1140px;
}

* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body {
  font-family: var(--font-body);
  color: var(--text);
  background: var(--night);
  font-size: 17px; line-height: 1.65; font-weight: 400;
  -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility;
  position: relative; overflow-x: hidden;
}

/* Animated mesh background fixed behind everything */
.bg-mesh {
  position: fixed; inset: 0; z-index: -2; pointer-events: none;
  background:
    radial-gradient(700px circle at 12% 8%, rgba(29,158,117,0.28), transparent 55%),
    radial-gradient(600px circle at 88% 18%, rgba(93,202,165,0.20), transparent 55%),
    radial-gradient(800px circle at 70% 95%, rgba(29,158,117,0.18), transparent 55%),
    var(--night);
}
.bg-orb {
  position: fixed; z-index: -1; border-radius: 50%; filter: blur(70px);
  opacity: 0.5; pointer-events: none; will-change: transform;
}
.bg-orb.o1 { width:480px; height:480px; background: radial-gradient(circle,#1D9E75,transparent 70%); top:-140px; left:-120px; animation: orb1 18s ease-in-out infinite; }
.bg-orb.o2 { width:520px; height:520px; background: radial-gradient(circle,#5DCAA5,transparent 70%); top:40%; right:-180px; opacity:0.32; animation: orb2 22s ease-in-out infinite; }
@keyframes orb1 { 0%,100%{transform:translate(0,0) scale(1)} 50%{transform:translate(60px,40px) scale(1.15)} }
@keyframes orb2 { 0%,100%{transform:translate(0,0) scale(1)} 50%{transform:translate(-50px,-60px) scale(1.1)} }

img { max-width:100%; display:block; }
a { color:inherit; text-decoration:none; }
ul { list-style:none; }

/* Typography */
h1,h2,h3,h4 { font-family:var(--font-title); font-weight:400; line-height:1.12; letter-spacing:-0.01em; color:#fff; }
h1 { font-size: clamp(2.5rem, 5.4vw, 4rem); }
h2 { font-size: clamp(2rem, 3.6vw, 2.8rem); }
h3 { font-size: 1.3rem; line-height:1.3; }
p { color: var(--text-muted); }
.lead { font-size: clamp(1.05rem,1.6vw,1.25rem); color: var(--text-muted); max-width: 60ch; }
.grad-text { background: linear-gradient(100deg,#5DCAA5,#1D9E75 60%,#5DCAA5); -webkit-background-clip:text; background-clip:text; color:transparent; }

.eyebrow {
  display:inline-flex; align-items:center; gap:var(--s-3);
  font-family:var(--font-body); font-size:0.78rem; font-weight:600;
  letter-spacing:0.14em; text-transform:uppercase; color:var(--teal-light);
  margin-bottom:var(--s-5);
}
.eyebrow::before { content:""; width:28px; height:2px; background:var(--teal-light); display:inline-block; box-shadow:var(--glow); }
.eyebrow.center { justify-content:center; }

/* Layout */
.container { width:100%; max-width:var(--maxw); margin:0 auto; padding:0 var(--s-6); }
section { padding: var(--s-24) 0; position:relative; }
.section-head { max-width:64ch; margin-bottom:var(--s-12); }
.section-head.center { margin-inline:auto; text-align:center; }

/* Light section (mint) for readability contrast */
.sec-light { background: var(--mint); color: var(--on-light); }
.sec-light h1,.sec-light h2,.sec-light h3 { color: var(--night); }
.sec-light p { color: var(--on-light-muted); }
.sec-light .eyebrow { color:#0F6E56; }
.sec-light .eyebrow::before { background:#0F6E56; box-shadow:none; }
.sec-light .grad-text { background:linear-gradient(100deg,#1D9E75,#04342C); -webkit-background-clip:text; background-clip:text; color:transparent; }

/* Buttons */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:var(--s-2);
  font-family:var(--font-body); font-weight:600; font-size:0.95rem;
  padding:14px 28px; border-radius:var(--r-pill); cursor:pointer;
  border:1.5px solid transparent; transition:all .22s ease; white-space:nowrap;
}
.btn svg { width:18px; height:18px; }
.btn-primary { background:var(--accent); color:#fff; box-shadow:var(--glow); }
.btn-primary:hover { background:var(--accent-hover); transform:translateY(-2px); box-shadow:0 0 40px rgba(29,158,117,0.8); }
.btn-glass { background:var(--glass-2); color:var(--text); border-color:var(--glass-border); backdrop-filter:blur(10px); }
.btn-glass:hover { border-color:var(--glass-border-hover); color:#fff; }
.btn-light { background:#fff; color:var(--night); }
.btn-light:hover { background:var(--mint); transform:translateY(-2px); }
.sec-light .btn-glass { background:rgba(4,52,44,0.05); color:var(--night); border-color:rgba(4,52,44,0.18); }
.sec-light .btn-glass:hover { border-color:var(--teal); color:var(--teal); }
.btn-lg { padding:17px 36px; font-size:1rem; }

/* Header */
.site-header { position:sticky; top:0; z-index:100; background:rgba(4,52,44,0.55); backdrop-filter:saturate(160%) blur(16px); border-bottom:1px solid rgba(255,255,255,0.08); }
.nav { display:flex; align-items:center; justify-content:space-between; height:74px; }
.brand { display:flex; align-items:center; gap:var(--s-3); font-family:var(--font-title); font-size:1.15rem; color:#fff; }
.brand .dot { width:9px; height:9px; border-radius:50%; background:var(--teal-light); flex-shrink:0; box-shadow:var(--glow); }
.brand small { display:block; font-family:var(--font-body); font-size:0.66rem; letter-spacing:0.12em; text-transform:uppercase; color:var(--text-muted); font-weight:600; }
.nav-links { display:flex; align-items:center; gap:var(--s-8); }
.nav-links a { font-size:0.94rem; font-weight:500; color:var(--text-muted); transition:color .15s ease; }
.nav-links a:hover, .nav-links a.active { color:var(--teal-light); }
.nav-cta { display:flex; align-items:center; gap:var(--s-4); }
.nav-toggle { display:none; background:none; border:none; cursor:pointer; padding:var(--s-2); }
.nav-toggle svg { width:26px; height:26px; color:#fff; }

/* Hero */
.hero { padding: var(--s-24) 0 var(--s-20); }
.hero-grid { display:grid; grid-template-columns:1.12fr 0.88fr; gap:var(--s-16); align-items:center; }
.hero h1 { margin-bottom:var(--s-6); }
.hero .lead { margin-bottom:var(--s-8); }
.hero-actions { display:flex; flex-wrap:wrap; gap:var(--s-4); margin-bottom:var(--s-8); }
.hero-trust { display:flex; align-items:center; gap:var(--s-4); color:var(--text-dim); font-size:0.86rem; }
.hero-trust .stars { color:var(--teal-light); letter-spacing:2px; }

/* Glass card */
.glass { background:var(--glass); border:1px solid var(--glass-border); border-radius:var(--r-card); backdrop-filter:blur(14px); transition:border-color .25s ease, transform .25s ease, background .25s ease; }
.glass:hover { border-color:var(--glass-border-hover); transform:translateY(-4px); background:var(--glass-2); }

.hero-aside { padding:var(--s-8); }
.hero-aside h4 { font-family:var(--font-body); font-size:0.8rem; text-transform:uppercase; letter-spacing:0.1em; color:var(--text-muted); margin-bottom:var(--s-6); font-weight:600; }
.aside-stat { padding:var(--s-5) 0; border-bottom:1px solid rgba(255,255,255,0.08); }
.aside-stat:last-child { border-bottom:none; padding-bottom:0; }
.aside-stat:first-of-type { padding-top:0; }
.aside-stat .num { font-family:var(--font-title); font-size:2rem; color:var(--teal-light); line-height:1; }
.aside-stat .lab { font-size:0.9rem; color:var(--text-muted); margin-top:var(--s-1); }

/* Stat band */
.stat-band { display:grid; grid-template-columns:repeat(4,1fr); gap:var(--s-6); }
.stat { text-align:center; padding:var(--s-8) var(--s-4); }
.stat .num { font-family:var(--font-title); font-size:clamp(2.2rem,4vw,3rem); color:#fff; line-height:1; }
.stat .num.glow { color:var(--teal-light); text-shadow:var(--glow-soft); }
.stat .lab { font-size:0.9rem; color:var(--text-muted); margin-top:var(--s-3); }

/* Card grid */
.grid { display:grid; gap:var(--s-6); }
.grid-3 { grid-template-columns:repeat(3,1fr); }
.grid-2 { grid-template-columns:repeat(2,1fr); }
.card { padding:var(--s-8); }
.card .ico { width:50px; height:50px; border-radius:var(--r-component); background:rgba(29,158,117,0.16); color:var(--teal-light); display:flex; align-items:center; justify-content:center; margin-bottom:var(--s-5); border:1px solid rgba(93,202,165,0.25); }
.card .ico svg { width:24px; height:24px; }
.card h3 { margin-bottom:var(--s-3); color:#fff; }
.card p { font-size:0.96rem; }

/* Steps */
.steps { display:grid; grid-template-columns:repeat(4,1fr); gap:var(--s-6); }
.step { padding:var(--s-6); }
.step .n { font-family:var(--font-title); font-size:1rem; color:var(--teal-light); width:42px; height:42px; border:1.5px solid var(--teal); border-radius:50%; display:flex; align-items:center; justify-content:center; margin-bottom:var(--s-5); box-shadow:var(--glow-soft); }
.step h3 { font-size:1.1rem; margin-bottom:var(--s-2); color:#fff; }
.step p { font-size:0.94rem; }

/* Testimonials */
.quote-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:var(--s-6); }
.quote { padding:var(--s-8); display:flex; flex-direction:column; }
.quote .stars { color:var(--teal-light); letter-spacing:2px; margin-bottom:var(--s-4); font-size:0.9rem; }
.quote blockquote { font-size:1rem; color:var(--text); line-height:1.6; flex:1; }
.quote .who { display:flex; align-items:center; gap:var(--s-3); margin-top:var(--s-6); }
.quote .av { width:42px; height:42px; border-radius:50%; background:linear-gradient(135deg,#1D9E75,#5DCAA5); color:var(--night); display:flex; align-items:center; justify-content:center; font-weight:700; font-size:0.85rem; flex-shrink:0; }
.quote .who strong { display:block; font-size:0.92rem; font-weight:600; color:#fff; }
.quote .who span { font-size:0.82rem; color:var(--text-muted); }

/* Google rating badge */
.g-rating { display:inline-flex; align-items:center; gap:var(--s-3); margin-top:var(--s-6); padding:10px 20px; border-radius:var(--r-pill); background:var(--glass); border:1px solid var(--glass-border); backdrop-filter:blur(10px); }
.g-rating .stars { color:var(--teal-light); letter-spacing:2px; font-size:0.95rem; }
.g-rating strong { color:#fff; font-size:1.05rem; font-weight:600; }
.g-rating span:last-child { color:var(--text-muted); font-size:0.9rem; }

/* CTA band */
.cta-band { text-align:center; }
.cta-band h2 { margin-bottom:var(--s-4); max-width:20ch; margin-inline:auto; }
.cta-band p { margin-bottom:var(--s-8); max-width:50ch; margin-inline:auto; }

/* Service blocks */
.svc-block { display:grid; grid-template-columns:0.8fr 1.2fr; gap:var(--s-12); padding:var(--s-16) 0; border-top:1px solid rgba(255,255,255,0.08); align-items:start; }
.svc-block:first-of-type { border-top:none; padding-top:0; }
.svc-intro h2 { margin-bottom:var(--s-4); }
.svc-items { display:grid; gap:var(--s-5); }
.svc-item { padding:var(--s-6); }
.svc-item h3 { font-size:1.1rem; margin-bottom:var(--s-2); color:#fff; }
.svc-item p { font-size:0.95rem; margin-bottom:var(--s-4); }
.svc-meta { display:flex; flex-wrap:wrap; gap:var(--s-2); align-items:center; }
.tag { font-size:0.78rem; font-weight:600; color:var(--mint); background:rgba(29,158,117,0.18); padding:4px 12px; border-radius:var(--r-pill); border:1px solid rgba(93,202,165,0.22); }
.svc-item a.more { font-size:0.9rem; font-weight:600; color:var(--teal-light); display:inline-flex; align-items:center; gap:6px; margin-top:var(--s-4); }
.svc-item a.more svg { width:15px; height:15px; transition:transform .2s ease; }
.svc-item a.more:hover svg { transform:translateX(3px); }

/* Pricing */
.pricing { display:grid; grid-template-columns:repeat(3,1fr); gap:var(--s-6); align-items:stretch; }
.plan { padding:var(--s-8); display:flex; flex-direction:column; position:relative; }
.plan.featured { border-color:var(--glass-border-hover); background:var(--glass-2); box-shadow:var(--glow-soft); }
.plan .badge { position:absolute; top:-13px; left:var(--s-8); background:linear-gradient(135deg,#1D9E75,#5DCAA5); color:var(--night); font-size:0.72rem; font-weight:700; letter-spacing:0.05em; text-transform:uppercase; padding:5px 14px; border-radius:var(--r-pill); box-shadow:var(--glow); }
.plan .tier { font-size:0.78rem; font-weight:600; letter-spacing:0.1em; text-transform:uppercase; color:var(--text-muted); }
.plan h3 { font-size:1.6rem; margin:var(--s-2) 0 var(--s-1); color:#fff; }
.plan .price { font-family:var(--font-title); font-size:2.6rem; color:var(--teal-light); line-height:1; text-shadow:var(--glow-soft); }
.plan .price small { font-family:var(--font-body); font-size:0.9rem; font-weight:500; color:var(--text-muted); }
.plan .commit { font-size:0.82rem; color:var(--text-dim); margin:var(--s-2) 0 var(--s-6); }
.plan ul { display:grid; gap:var(--s-3); margin-bottom:var(--s-8); flex:1; }
.plan li { display:flex; gap:var(--s-3); font-size:0.92rem; color:var(--text); line-height:1.5; }
.plan li svg { width:18px; height:18px; color:var(--teal-light); flex-shrink:0; margin-top:2px; }
.plan li span { color:var(--text-muted); font-size:0.86rem; display:block; }

/* FAQ */
.faq { max-width:780px; margin:0 auto; }
.faq details { border:1px solid var(--glass-border); border-radius:var(--r-card); background:var(--glass); margin-bottom:var(--s-4); padding:var(--s-5) var(--s-6); transition:border-color .2s ease; }
.faq details[open] { border-color:var(--glass-border-hover); }
.faq summary { font-family:var(--font-title); font-size:1.15rem; color:#fff; cursor:pointer; list-style:none; display:flex; justify-content:space-between; align-items:center; gap:var(--s-4); }
.faq summary::-webkit-details-marker { display:none; }
.faq summary .pm { width:22px; height:22px; flex-shrink:0; color:var(--teal-light); transition:transform .2s ease; }
.faq details[open] summary .pm { transform:rotate(45deg); }
.faq details p { margin-top:var(--s-4); font-size:0.98rem; }

/* About */
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:var(--s-16); align-items:center; }
.about-portrait { border-radius:var(--r-card); overflow:hidden; border:1px solid var(--glass-border); position:relative; }
.about-portrait::after { content:""; position:absolute; inset:0; box-shadow:inset 0 0 80px rgba(4,52,44,0.5); pointer-events:none; }
.values { display:grid; gap:var(--s-5); margin-top:var(--s-8); }
.value { display:flex; gap:var(--s-4); }
.value .ico { width:46px; height:46px; border-radius:var(--r-component); background:rgba(29,158,117,0.16); color:var(--teal-light); display:flex; align-items:center; justify-content:center; flex-shrink:0; border:1px solid rgba(93,202,165,0.25); }
.value .ico svg { width:22px; height:22px; }
.value h3 { font-size:1.05rem; margin-bottom:var(--s-1); color:#fff; }
.value p { font-size:0.93rem; }
.map-embed { width:100%; height:380px; border:1px solid var(--glass-border); border-radius:var(--r-card); filter:saturate(0.85); }

/* Contact */
.contact-grid { display:grid; grid-template-columns:0.85fr 1.15fr; gap:var(--s-16); align-items:start; }
.contact-info .info-row { display:flex; gap:var(--s-4); padding:var(--s-5) 0; border-bottom:1px solid rgba(255,255,255,0.08); }
.contact-info .info-row:last-child { border-bottom:none; }
.contact-info .ico { width:46px; height:46px; border-radius:var(--r-component); background:rgba(29,158,117,0.16); color:var(--teal-light); display:flex; align-items:center; justify-content:center; flex-shrink:0; border:1px solid rgba(93,202,165,0.25); }
.contact-info .ico svg { width:22px; height:22px; }
.contact-info h4 { font-family:var(--font-body); font-size:0.95rem; font-weight:600; margin-bottom:2px; color:#fff; }
.contact-info p { font-size:0.92rem; }
.contact-info a { color:var(--teal-light); }
.steps-after { padding:var(--s-8); margin-top:var(--s-8); }
.steps-after h4 { color:#fff; font-family:var(--font-body); font-size:0.85rem; text-transform:uppercase; letter-spacing:0.1em; margin-bottom:var(--s-5); }
.steps-after ol { list-style:none; counter-reset:a; display:grid; gap:var(--s-4); }
.steps-after li { counter-increment:a; display:flex; gap:var(--s-4); font-size:0.92rem; color:var(--text-muted); }
.steps-after li::before { content:counter(a); font-family:var(--font-title); color:var(--teal-light); border:1px solid rgba(93,202,165,0.4); width:28px; height:28px; border-radius:50%; display:flex; align-items:center; justify-content:center; flex-shrink:0; font-size:0.85rem; }

/* Form */
.form-card { padding:var(--s-10); }
.form-card h2 { font-size:1.6rem; margin-bottom:var(--s-6); }
.field { margin-bottom:var(--s-5); }
.field label { display:block; font-size:0.88rem; font-weight:600; margin-bottom:var(--s-2); color:#fff; }
.field label .req { color:var(--teal-light); }
.field input, .field select, .field textarea {
  width:100%; font-family:var(--font-body); font-size:0.96rem; color:#fff;
  padding:13px 15px; border:1px solid var(--glass-border); border-radius:var(--r-component);
  background:rgba(255,255,255,0.04); transition:border-color .15s ease, box-shadow .15s ease;
}
.field input::placeholder, .field textarea::placeholder { color:var(--text-dim); }
.field select option { background:var(--night); color:#fff; }
.field input:focus, .field select:focus, .field textarea:focus {
  outline:none; border-color:var(--teal); background:rgba(255,255,255,0.07);
  box-shadow:0 0 0 3px rgba(29,158,117,0.18);
}
.field textarea { resize:vertical; min-height:130px; }
.field .helper { font-size:0.82rem; color:var(--text-dim); margin-top:6px; }
.form-foot { font-size:0.84rem; color:var(--text-dim); text-align:center; margin-top:var(--s-4); }

/* Page hero */
.page-hero { padding:var(--s-20) 0 var(--s-12); }
.page-hero h1 { margin-bottom:var(--s-5); max-width:20ch; }
.page-hero .lead { margin:0; }

/* Footer */
.site-footer { background:var(--ink); border-top:1px solid rgba(255,255,255,0.08); padding:var(--s-20) 0 var(--s-10); position:relative; }
.footer-grid { display:grid; grid-template-columns:1.6fr 1fr 1fr; gap:var(--s-12); margin-bottom:var(--s-16); }
.site-footer .brand { margin-bottom:var(--s-5); }
.site-footer p { color:var(--text-muted); font-size:0.92rem; max-width:38ch; }
.footer-col h4 { font-family:var(--font-body); color:#fff; font-size:0.82rem; text-transform:uppercase; letter-spacing:0.1em; margin-bottom:var(--s-5); }
.footer-col a { display:block; font-size:0.92rem; color:var(--text-muted); padding:5px 0; transition:color .15s ease; }
.footer-col a:hover { color:var(--teal-light); }
.footer-bottom { border-top:1px solid rgba(255,255,255,0.08); padding-top:var(--s-6); display:flex; justify-content:space-between; flex-wrap:wrap; gap:var(--s-3); font-size:0.84rem; color:var(--text-dim); }
.footer-bottom a:hover { color:var(--teal-light); }

/* Blog index */
.post-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:var(--s-6); }
.post-card { padding:var(--s-6); display:flex; flex-direction:column; }
.post-card .ico { width:44px; height:44px; border-radius:var(--r-component); background:rgba(29,158,117,0.16); color:var(--teal-light); display:flex; align-items:center; justify-content:center; margin-bottom:var(--s-5); border:1px solid rgba(93,202,165,0.25); }
.post-card .ico svg { width:22px; height:22px; }
.post-card .cat { font-size:0.74rem; font-weight:600; letter-spacing:0.08em; text-transform:uppercase; color:var(--teal-light); margin-bottom:var(--s-3); }
.post-card h3 { font-size:1.2rem; margin-bottom:var(--s-3); color:#fff; line-height:1.25; }
.post-card p { font-size:0.94rem; flex:1; }
.post-card .meta { font-size:0.8rem; color:var(--text-dim); margin-top:var(--s-5); padding-top:var(--s-4); border-top:1px solid rgba(255,255,255,0.08); display:flex; align-items:center; gap:8px; }
.post-card .meta .more { margin-left:auto; color:var(--teal-light); font-weight:600; display:inline-flex; align-items:center; gap:5px; }
.post-card .meta .more svg { width:14px; height:14px; transition:transform .2s ease; }
.post-card:hover .meta .more svg { transform:translateX(3px); }
.post-card.featured { grid-column:1 / -1; flex-direction:row; gap:var(--s-8); align-items:center; }
.post-card.featured .pc-body { flex:1; }
.post-card.featured .ico { margin-bottom:0; width:64px; height:64px; flex-shrink:0; }
.post-card.featured h3 { font-size:1.7rem; }

/* Breadcrumb */
.breadcrumb { font-size:0.84rem; color:var(--text-dim); margin-bottom:var(--s-6); }
.breadcrumb a { color:var(--text-muted); }
.breadcrumb a:hover { color:var(--teal-light); }
.breadcrumb .sep { margin:0 8px; opacity:0.5; }

/* Article */
.article-hero { padding:var(--s-16) 0 var(--s-8); }
.article-hero .wrap { max-width:780px; margin:0 auto; }
.article-hero h1 { margin:var(--s-3) 0 var(--s-6); font-size:clamp(2rem,4vw,3rem); }
.article-meta { display:flex; flex-wrap:wrap; gap:var(--s-5); font-size:0.88rem; color:var(--text-dim); align-items:center; }
.article-meta .item { display:inline-flex; align-items:center; gap:7px; }
.article-meta svg { width:16px; height:16px; color:var(--teal-light); }
.article-back { display:inline-flex; align-items:center; gap:7px; color:var(--teal-light); font-weight:600; font-size:0.9rem; margin-top:var(--s-6); }
.article-back svg { width:16px; height:16px; }
.article-body { max-width:760px; margin:0 auto; padding-bottom:var(--s-12); font-size:1.06rem; }
.article-body h2 { font-size:1.7rem; margin:var(--s-12) 0 var(--s-4); color:#fff; }
.article-body h3 { font-size:1.25rem; margin:var(--s-8) 0 var(--s-3); color:var(--teal-light); }
.article-body h4 { font-size:1.1rem; margin:var(--s-6) 0 var(--s-2); color:#fff; }
.article-body p { color:var(--text); margin-bottom:var(--s-5); line-height:1.75; }
.article-body ul, .article-body ol { margin:0 0 var(--s-5) 0; padding-left:0; display:grid; gap:var(--s-3); }
.article-body li { color:var(--text); line-height:1.65; padding-left:30px; position:relative; }
.article-body ul li::before { content:""; position:absolute; left:6px; top:11px; width:7px; height:7px; border-radius:50%; background:var(--teal-light); box-shadow:var(--glow-soft); }
.article-body ol { counter-reset:n; }
.article-body ol li { counter-increment:n; }
.article-body ol li::before { content:counter(n); position:absolute; left:0; top:1px; width:22px; height:22px; border:1px solid rgba(93,202,165,0.4); border-radius:50%; color:var(--teal-light); font-size:0.75rem; font-weight:600; display:flex; align-items:center; justify-content:center; }
.article-body strong { color:#fff; font-weight:600; }
.article-body a { color:var(--teal-light); text-decoration:underline; text-underline-offset:3px; }
.article-body p strong:only-child { display:block; padding:var(--s-5) var(--s-6); background:var(--glass); border-left:3px solid var(--teal); border-radius:0 var(--r-component) var(--r-component) 0; color:var(--text); font-weight:400; }
.article-body p strong:only-child::first-line { color:#fff; }
.article-cta { max-width:780px; margin:var(--s-8) auto 0; padding:var(--s-10); text-align:center; }
.article-cta h2 { font-size:1.6rem; margin-bottom:var(--s-3); }
.article-cta p { margin-bottom:var(--s-6); }

/* Reveal */
.reveal { opacity:0; transform:translateY(20px); transition:opacity .7s ease, transform .7s ease; }
.reveal.in { opacity:1; transform:none; }

/* Focus */
a:focus-visible, button:focus-visible, summary:focus-visible, input:focus-visible, select:focus-visible, textarea:focus-visible {
  outline:2px solid var(--teal-light); outline-offset:2px; border-radius:var(--r-component);
}

/* Responsive */
@media (max-width:960px) {
  .hero-grid, .about-grid, .contact-grid { grid-template-columns:1fr; gap:var(--s-10); }
  .grid-3, .quote-grid, .pricing, .post-grid { grid-template-columns:1fr 1fr; }
  .post-card.featured { flex-direction:column; align-items:flex-start; grid-column:auto; }
  .post-card.featured .ico { margin-bottom:var(--s-5); }
  .steps, .stat-band { grid-template-columns:1fr 1fr; gap:var(--s-5); }
  .svc-block { grid-template-columns:1fr; gap:var(--s-8); }
  .footer-grid { grid-template-columns:1fr 1fr; gap:var(--s-8); }
}
@media (max-width:680px) {
  section { padding:var(--s-16) 0; }
  .nav-links { display:none; }
  .nav-links.open { display:flex; position:absolute; top:74px; left:0; right:0; flex-direction:column; gap:0; background:var(--night); border-bottom:1px solid var(--glass-border); padding:var(--s-4) var(--s-6); }
  .nav-links.open a { padding:var(--s-3) 0; border-bottom:1px solid rgba(255,255,255,0.08); }
  .nav-toggle { display:block; }
  .nav-cta .btn-glass { display:none; }
  .grid-3, .grid-2, .quote-grid, .pricing, .post-grid { grid-template-columns:1fr; }
  .steps, .stat-band { grid-template-columns:1fr; }
  .footer-grid { grid-template-columns:1fr; }
  .footer-bottom { flex-direction:column; }
  body { font-size:16px; }
}

@media (prefers-reduced-motion: reduce) {
  *, .bg-orb { animation:none !important; transition:none !important; scroll-behavior:auto !important; }
  .reveal { opacity:1; transform:none; }
}
