/* =================================================================
   LIBERTY4U Web Solutions — Design System
   Palette: Navy + Teal  |  Mobile-first  |  WCAG AA
   ================================================================= */

/* ---------- 1. Design tokens ---------- */
:root{
  /* Brand */
  --navy-900:#0B1F32;
  --navy:#0F2A43;
  --navy-700:#1B3A57;
  --teal:#14B8A6;
  --teal-600:#0D9488;
  --teal-050:#E6FAF6;

  /* Neutrals */
  --ink:#1A2433;
  --body:#39495A;
  --muted:#5B6B7C;
  --bg:#FFFFFF;
  --bg-soft:#F5F8FB;
  --bg-navy:#0F2A43;
  --border:#E3E9EF;
  --border-strong:#CBD6E0;

  /* Accent helpers */
  --amber:#F5A524;

  /* Typography */
  --font:'Plus Jakarta Sans',system-ui,-apple-system,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  --h1:clamp(2.1rem,5.2vw,3.5rem);
  --h2:clamp(1.7rem,3.6vw,2.5rem);
  --h3:clamp(1.2rem,2vw,1.45rem);
  --lead:clamp(1.05rem,1.6vw,1.2rem);

  /* Layout */
  --maxw:1180px;
  --gutter:clamp(18px,4vw,32px);
  --radius:16px;
  --radius-sm:12px;
  --radius-pill:999px;
  --shadow-sm:0 1px 2px rgba(15,42,67,.06),0 2px 8px rgba(15,42,67,.05);
  --shadow:0 6px 22px rgba(15,42,67,.08);
  --shadow-lg:0 18px 50px rgba(15,42,67,.14);
  --nav-h:72px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ---------- 2. Reset & base ---------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;font-family:var(--font);
  font-size:17px;line-height:1.65;color:var(--body);
  background:var(--bg);-webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--teal-600);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{color:var(--ink);line-height:1.18;margin:0 0 .5em;font-weight:700;letter-spacing:-.01em}
h1{font-size:var(--h1);font-weight:800}
h2{font-size:var(--h2);font-weight:800}
h3{font-size:var(--h3)}
p{margin:0 0 1rem}
ul{margin:0 0 1rem}
:focus-visible{outline:3px solid var(--teal);outline-offset:2px;border-radius:6px}
.skip-link{position:absolute;left:-999px;top:0;background:var(--navy);color:#fff;padding:.7rem 1rem;z-index:200;border-radius:0 0 8px 0}
.skip-link:focus{left:0}

/* ---------- 3. Layout helpers ---------- */
.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}
.section{padding:clamp(48px,7vw,88px) 0}
.section--soft{background:var(--bg-soft)}
.section--navy{background:var(--navy);color:#D6E2EC}
.section--navy h2,.section--navy h3{color:#fff}
.section--tight{padding-block:clamp(36px,5vw,56px)}
.eyebrow{display:inline-block;font-size:.82rem;font-weight:700;letter-spacing:.09em;
  text-transform:uppercase;color:var(--teal-600);margin-bottom:.7rem}
.section--navy .eyebrow{color:var(--teal)}
.section-head{max-width:720px;margin-bottom:clamp(28px,4vw,44px)}
.section-head.center{margin-inline:auto;text-align:center}
.lead{font-size:var(--lead);color:var(--muted)}
.section--navy .lead{color:#AFC2D2}
.muted{color:var(--muted)}

/* ---------- 4. Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-family:inherit;font-size:1rem;font-weight:700;line-height:1;
  padding:.92rem 1.5rem;border-radius:var(--radius-pill);
  border:2px solid transparent;cursor:pointer;text-decoration:none;
  transition:transform .15s var(--ease),background .2s,box-shadow .2s,border-color .2s;
}
.btn:hover{text-decoration:none;transform:translateY(-2px)}
.btn:active{transform:translateY(0)}
.btn--primary{background:var(--teal);color:#06241F;box-shadow:0 6px 18px rgba(20,184,166,.35)}
.btn--primary:hover{background:var(--teal-600);color:#fff}
.btn--secondary{background:transparent;color:var(--navy);border-color:var(--border-strong)}
.btn--secondary:hover{border-color:var(--navy);background:var(--navy);color:#fff}
.btn--ghost-light{background:rgba(255,255,255,.08);color:#fff;border-color:rgba(255,255,255,.35)}
.btn--ghost-light:hover{background:#fff;color:var(--navy)}
.btn--light{background:#fff;color:var(--navy)}
.btn--light:hover{background:var(--teal);color:#06241F}
.btn--block{width:100%}
.btn--sm{padding:.62rem 1.05rem;font-size:.92rem}
.btn-row{display:flex;flex-wrap:wrap;gap:.8rem}
.btn-row.center{justify-content:center}

/* ---------- 5. Header / Nav ---------- */
.site-header{
  position:sticky;top:0;z-index:100;background:rgba(255,255,255,.92);
  backdrop-filter:saturate(160%) blur(10px);
  border-bottom:1px solid var(--border);
}
.nav{display:flex;align-items:center;gap:1rem;height:var(--nav-h)}
.brand{display:flex;align-items:center;gap:.6rem;font-weight:800;color:var(--ink);
  font-size:1.18rem;letter-spacing:-.02em;flex:0 0 auto}
.brand:hover{text-decoration:none}
.brand img{width:36px;height:36px;border-radius:0;flex:0 0 auto}
.brand b{color:inherit;font-weight:800}
.nav-spacer{flex:1 1 auto}
.nav-links{display:none;align-items:center;gap:.35rem;list-style:none;margin:0;padding:0}
.nav-links a{
  display:block;padding:.55rem .8rem;border-radius:10px;font-weight:600;
  font-size:.96rem;color:var(--ink);
}
.nav-links a:hover{background:var(--bg-soft);text-decoration:none;color:var(--teal-600)}
.nav-cta{display:none}

/* Dropdown */
.has-drop{position:relative}
.drop-toggle{display:inline-flex;align-items:center;gap:.3rem;background:none;border:0;
  font:inherit;font-weight:600;font-size:.96rem;color:var(--ink);cursor:pointer;
  padding:.55rem .8rem;border-radius:10px}
.drop-toggle:hover{background:var(--bg-soft);color:var(--teal-600)}
.drop-toggle svg{width:14px;height:14px;transition:transform .2s}
.has-drop[data-open="true"] .drop-toggle svg{transform:rotate(180deg)}
.drop-menu{
  position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%) translateY(6px);
  background:#fff;border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow-lg);
  padding:.5rem;min-width:300px;opacity:0;visibility:hidden;transition:.18s var(--ease);
  list-style:none;margin:0;z-index:110;
}
.has-drop[data-open="true"] .drop-menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.drop-menu a{display:flex;flex-direction:column;padding:.55rem .7rem;border-radius:9px;color:var(--ink)}
.drop-menu a:hover{background:var(--teal-050);text-decoration:none}
.drop-menu a span{font-weight:700;font-size:.95rem}
.drop-menu a small{color:var(--muted);font-size:.8rem}

/* Hamburger */
.hamburger{display:inline-flex;flex-direction:column;justify-content:center;gap:5px;
  width:46px;height:46px;border:1px solid var(--border-strong);border-radius:11px;
  background:#fff;cursor:pointer;padding:0 11px;flex:0 0 auto}
.hamburger span{height:2.5px;background:var(--navy);border-radius:2px;transition:.25s var(--ease)}
.hamburger[aria-expanded="true"] span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.hamburger[aria-expanded="true"] span:nth-child(2){opacity:0}
.hamburger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

/* Mobile drawer */
.drawer{position:fixed;inset:var(--nav-h) 0 0 0;background:rgba(11,31,50,.45);
  opacity:0;visibility:hidden;transition:.25s;z-index:99}
.drawer[data-open="true"]{opacity:1;visibility:visible}
.drawer-panel{position:absolute;top:0;right:0;width:min(86%,360px);height:100%;
  background:#fff;padding:1.2rem var(--gutter) 2rem;overflow-y:auto;
  transform:translateX(100%);transition:transform .28s var(--ease);box-shadow:var(--shadow-lg)}
.drawer[data-open="true"] .drawer-panel{transform:translateX(0)}
.drawer-panel a{display:block;padding:.8rem .2rem;font-weight:600;font-size:1.05rem;
  color:var(--ink);border-bottom:1px solid var(--border)}
.drawer-panel a:hover{color:var(--teal-600);text-decoration:none}
.drawer-group>summary{cursor:pointer;list-style:none;padding:.8rem .2rem;font-weight:700;
  font-size:1.05rem;color:var(--ink);border-bottom:1px solid var(--border);
  display:flex;justify-content:space-between;align-items:center}
.drawer-group>summary::-webkit-details-marker{display:none}
.drawer-group>summary::after{content:"+";color:var(--teal-600);font-weight:700}
.drawer-group[open]>summary::after{content:"–"}
.drawer-group .sub a{padding-left:1rem;font-weight:500;font-size:.98rem;color:var(--body)}
.drawer-cta{margin-top:1.3rem}

/* ---------- 6. Hero ---------- */
.hero{position:relative;background:
  radial-gradient(1200px 500px at 80% -10%,rgba(20,184,166,.18),transparent 60%),
  linear-gradient(165deg,var(--navy-900),var(--navy) 55%,var(--navy-700));
  color:#E8F0F6;overflow:hidden}
.hero::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(700px 320px at 12% 110%,rgba(20,184,166,.12),transparent 70%)}
.hero-grid{display:grid;gap:2.4rem;align-items:center;
  padding:clamp(48px,8vw,86px) 0 clamp(56px,8vw,92px);position:relative;z-index:1}
.hero h1{color:#fff;max-width:14ch}
.hero h1 em{font-style:normal;color:var(--teal);
  background:linear-gradient(transparent 62%,rgba(20,184,166,.22) 0);padding:0 .05em}
.hero p.sub{font-size:var(--lead);color:#B8CADA;max-width:50ch;margin-bottom:1.6rem}
.hero .btn-row{margin-bottom:1.6rem}
.hero-rating{display:flex;align-items:center;gap:.6rem;font-size:.92rem;color:#AFC2D2}
.hero-rating .stars{color:var(--amber);letter-spacing:2px}
.hero-media{position:relative}
.hero-media img{border-radius:var(--radius);box-shadow:var(--shadow-lg);
  border:1px solid rgba(255,255,255,.12)}
.hero-badge{position:absolute;background:#fff;color:var(--ink);border-radius:14px;
  box-shadow:var(--shadow-lg);padding:.7rem .9rem;display:flex;align-items:center;gap:.55rem;
  font-weight:700;font-size:.86rem}
.hero-badge svg{width:30px;height:30px;flex:0 0 auto}
.hero-badge.b1{bottom:-18px;left:-10px}
.hero-badge small{display:block;font-weight:500;color:var(--muted);font-size:.74rem}

/* ---------- 7. Trust bar ---------- */
.trustbar{background:var(--navy-900);color:#C7D6E2;border-top:1px solid rgba(255,255,255,.06)}
.trustbar .container{display:flex;flex-wrap:wrap;gap:.7rem 2rem;align-items:center;
  justify-content:center;padding-block:1rem;font-size:.92rem;font-weight:600}
.trustbar .ti{display:inline-flex;align-items:center;gap:.5rem}
.trustbar .ti svg{width:18px;height:18px;color:var(--teal)}
.trustbar .dot{width:5px;height:5px;border-radius:50%;background:rgba(255,255,255,.25)}

/* ---------- 8. Cards & grids ---------- */
.grid{display:grid;gap:clamp(16px,2.4vw,24px)}
.grid-2{grid-template-columns:1fr}
.grid-3{grid-template-columns:1fr}
.grid-4{grid-template-columns:1fr 1fr}
.card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:1.5rem;box-shadow:var(--shadow-sm);transition:.2s var(--ease);height:100%}
.card:hover{box-shadow:var(--shadow);transform:translateY(-3px);border-color:var(--border-strong)}
.card h3{margin-bottom:.4rem;font-size:1.16rem}
.card p{margin-bottom:.8rem;color:var(--muted);font-size:.97rem}
.card .card-link{font-weight:700;font-size:.92rem;color:var(--teal-600);
  display:inline-flex;align-items:center;gap:.3rem}
.card .card-link svg{width:15px;height:15px;transition:transform .18s}
.card:hover .card-link svg{transform:translateX(3px)}
.card-icon{width:50px;height:50px;border-radius:13px;display:grid;place-items:center;
  background:var(--teal-050);color:var(--teal-600);margin-bottom:1rem}
.card-icon svg{width:26px;height:26px}
a.card{color:inherit}
a.card:hover{text-decoration:none}

/* Feature list (why us) */
.feature{display:flex;gap:.9rem;align-items:flex-start}
.feature .fi{flex:0 0 auto;width:44px;height:44px;border-radius:12px;display:grid;
  place-items:center;background:var(--teal-050);color:var(--teal-600)}
.section--navy .feature .fi{background:rgba(20,184,166,.16);color:var(--teal)}
.feature .fi svg{width:23px;height:23px}
.feature h3{font-size:1.08rem;margin-bottom:.25rem}
.feature p{font-size:.95rem;color:var(--muted);margin:0}
.section--navy .feature p{color:#A6BACA}

/* Checklist */
.checks{list-style:none;padding:0;margin:0;display:grid;gap:.6rem}
.checks li{position:relative;padding-left:1.9rem;color:var(--body)}
.checks li::before{content:"";position:absolute;left:0;top:.15em;width:20px;height:20px;
  border-radius:50%;background:var(--teal-050);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%230D9488' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:center}
.section--navy .checks li{color:#C7D6E2}

/* ---------- 9. Pricing ---------- */
.price-grid{display:grid;gap:clamp(16px,2.4vw,22px);grid-template-columns:1fr}
.price-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:1.7rem 1.5rem;display:flex;flex-direction:column;box-shadow:var(--shadow-sm);
  position:relative;transition:.2s var(--ease)}
.price-card:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.price-card.featured{border-color:var(--teal);box-shadow:0 0 0 2px var(--teal),var(--shadow);}
.price-card .ribbon{position:absolute;top:-13px;left:50%;transform:translateX(-50%);
  background:var(--teal);color:#06241F;font-weight:800;font-size:.74rem;letter-spacing:.05em;
  text-transform:uppercase;padding:.35rem .8rem;border-radius:var(--radius-pill);white-space:nowrap}
.price-card h3{font-size:1.18rem;margin-bottom:.3rem}
.price-card .amount{font-size:2.1rem;font-weight:800;color:var(--ink);line-height:1}
.price-card .amount small{font-size:.9rem;font-weight:600;color:var(--muted);display:block;margin-top:.3rem}
.price-card .from{font-size:.82rem;font-weight:700;color:var(--teal-600);text-transform:uppercase;letter-spacing:.06em}
.price-card .desc{font-size:.92rem;color:var(--muted);margin:.6rem 0 1rem}
.price-card .checks{margin-bottom:1.4rem;flex:1}
.price-card .checks li{font-size:.93rem}
.price-card .btn{margin-top:auto}

/* ---------- 10. Process steps ---------- */
.steps{display:grid;gap:clamp(16px,2.4vw,22px);grid-template-columns:1fr;counter-reset:step}
.step{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:1.4rem;position:relative}
.section--navy .step{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.1)}
.step .num{counter-increment:step;width:40px;height:40px;border-radius:11px;
  background:var(--navy);color:#fff;display:grid;place-items:center;font-weight:800;margin-bottom:.8rem}
.section--navy .step .num{background:var(--teal);color:#06241F}
.step .num::before{content:counter(step)}
.step h3{font-size:1.05rem;margin-bottom:.3rem}
.step p{font-size:.93rem;color:var(--muted);margin:0}
.section--navy .step p{color:#A6BACA}

/* ---------- 11. Portfolio ---------- */
.work-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  overflow:hidden;box-shadow:var(--shadow-sm);transition:.2s var(--ease);display:flex;flex-direction:column}
.work-card:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.work-thumb{aspect-ratio:16/10;overflow:hidden;background:var(--bg-soft);border-bottom:1px solid var(--border)}
.work-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .35s var(--ease)}
.work-card:hover .work-thumb img{transform:scale(1.04)}
.work-body{padding:1.2rem 1.3rem 1.4rem}
.work-tag{display:inline-block;font-size:.74rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.06em;color:var(--teal-600);background:var(--teal-050);
  padding:.25rem .6rem;border-radius:var(--radius-pill);margin-bottom:.7rem}
.work-body h3{font-size:1.12rem;margin-bottom:.3rem}
.work-body p{font-size:.93rem;color:var(--muted);margin-bottom:.7rem}

/* ---------- 12. Split / media sections ---------- */
.split{display:grid;gap:clamp(28px,5vw,56px);align-items:center;grid-template-columns:1fr}
.split-media img{border-radius:var(--radius);box-shadow:var(--shadow)}
.split .pill-tag{display:inline-flex;align-items:center;gap:.45rem;background:var(--teal-050);
  color:var(--teal-600);font-weight:700;font-size:.82rem;padding:.4rem .8rem;
  border-radius:var(--radius-pill);margin-bottom:1rem}
.section--navy .split .pill-tag{background:rgba(20,184,166,.16);color:var(--teal)}

/* ---------- 13. CTA band ---------- */
.cta-band{background:linear-gradient(150deg,var(--navy) 0%,var(--navy-700) 100%);
  color:#fff;border-radius:var(--radius);padding:clamp(32px,5vw,56px);text-align:center;
  position:relative;overflow:hidden}
.cta-band::before{content:"";position:absolute;inset:0;
  background:radial-gradient(600px 300px at 85% -20%,rgba(20,184,166,.25),transparent 60%)}
.cta-band>*{position:relative}
.cta-band h2{color:#fff}
.cta-band p{color:#B8CADA;max-width:50ch;margin-inline:auto}

/* ---------- 14. Footer ---------- */
.site-footer{background:var(--navy-900);color:#A9BECE;padding-top:clamp(44px,6vw,72px);font-size:.94rem}
.footer-grid{display:grid;gap:2rem;grid-template-columns:1fr}
.footer-brand .brand{color:#fff;margin-bottom:.8rem}
.footer-brand .brand b{color:inherit}
.footer-brand p{color:#90A8BA;max-width:36ch;font-size:.92rem}
.footer-col h4{color:#fff;font-size:.95rem;letter-spacing:.02em;margin-bottom:.9rem}
.footer-col ul{list-style:none;padding:0;margin:0;display:grid;gap:.5rem}
.footer-col a{color:#A9BECE}
.footer-col a:hover{color:var(--teal)}
.footer-contact li{display:flex;gap:.6rem;align-items:flex-start;margin-bottom:.6rem}
.footer-contact svg{width:18px;height:18px;color:var(--teal);flex:0 0 auto;margin-top:.15em}
.footer-social{display:flex;gap:.6rem;margin-top:1rem}
.footer-social a{width:40px;height:40px;border-radius:11px;display:grid;place-items:center;
  background:rgba(255,255,255,.06);color:#fff;transition:.2s}
.footer-social a:hover{background:var(--teal);color:#06241F}
.footer-social svg{width:19px;height:19px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);margin-top:clamp(32px,5vw,52px);
  padding:1.4rem 0;display:flex;flex-wrap:wrap;gap:.6rem 1.4rem;justify-content:space-between;
  align-items:center;font-size:.85rem;color:#7D94A8}
.footer-bottom a{color:#7D94A8}
.footer-bottom a:hover{color:var(--teal)}
.footer-legal{display:flex;flex-wrap:wrap;gap:.4rem 1.1rem}

/* ---------- 15. Forms ---------- */
.form-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:clamp(1.4rem,3vw,2.2rem);box-shadow:var(--shadow-sm)}
.field{margin-bottom:1.1rem}
.field label{display:block;font-weight:600;font-size:.92rem;color:var(--ink);margin-bottom:.4rem}
.field .req{color:#D6453B}
.field input,.field select,.field textarea{
  width:100%;font:inherit;font-size:1rem;color:var(--ink);background:var(--bg-soft);
  border:1.5px solid var(--border);border-radius:11px;padding:.78rem .9rem;transition:.15s}
.field input:focus,.field select:focus,.field textarea:focus{
  border-color:var(--teal);background:#fff;outline:none;box-shadow:0 0 0 3px rgba(20,184,166,.15)}
.field textarea{min-height:130px;resize:vertical}
.field-row{display:grid;gap:1.1rem;grid-template-columns:1fr}
.form-hint{font-size:.82rem;color:var(--muted);margin-top:.3rem}
.radio-row{display:flex;flex-wrap:wrap;gap:.6rem}
.radio-row label{display:inline-flex;align-items:center;gap:.4rem;font-weight:500;
  background:var(--bg-soft);border:1.5px solid var(--border);border-radius:var(--radius-pill);
  padding:.5rem .9rem;cursor:pointer;margin:0}
.radio-row input{width:auto}

/* ---------- 16. FAQ accordion ---------- */
.faq-list{display:grid;gap:.8rem;max-width:820px;margin-inline:auto}
.faq-item{background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}
.faq-q{width:100%;text-align:left;background:none;border:0;font:inherit;font-weight:700;
  font-size:1.02rem;color:var(--ink);cursor:pointer;padding:1.1rem 1.2rem;
  display:flex;justify-content:space-between;align-items:center;gap:1rem}
.faq-q .chev{flex:0 0 auto;width:22px;height:22px;transition:transform .25s;color:var(--teal-600)}
.faq-item[data-open="true"] .chev{transform:rotate(180deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s var(--ease)}
.faq-a-inner{padding:0 1.2rem 1.2rem;color:var(--muted);font-size:.97rem}

/* ---------- 17. Breadcrumbs ---------- */
.crumbs{font-size:.85rem;color:var(--muted);padding:1rem 0 0}
.crumbs ol{list-style:none;display:flex;flex-wrap:wrap;gap:.4rem;padding:0;margin:0}
.crumbs a{color:var(--muted)}
.crumbs a:hover{color:var(--teal-600)}
.crumbs li+li::before{content:"/";margin-right:.4rem;color:var(--border-strong)}

/* ---------- 18. Page hero (inner pages) ---------- */
.page-hero{background:
  radial-gradient(900px 360px at 90% -30%,rgba(20,184,166,.16),transparent 60%),
  linear-gradient(160deg,var(--navy-900),var(--navy));color:#E8F0F6}
.page-hero .container{padding-block:clamp(34px,5vw,60px) clamp(40px,6vw,68px)}
.page-hero h1{color:#fff;max-width:18ch}
.page-hero p{color:#B8CADA;font-size:var(--lead);max-width:60ch}
.page-hero .crumbs,.page-hero .crumbs a{color:#9DB4C6}
.page-hero .crumbs li+li::before{color:#5A7488}

/* ---------- 19. Utilities ---------- */
.text-center{text-align:center}
.mt-0{margin-top:0}.mb-0{margin-bottom:0}
.tag-pill{display:inline-flex;align-items:center;gap:.4rem;background:var(--teal-050);
  color:var(--teal-600);font-weight:700;font-size:.8rem;padding:.35rem .8rem;border-radius:var(--radius-pill)}
.divider{height:1px;background:var(--border);border:0;margin:0}
.stat{display:grid;gap:.1rem}
.stat b{font-size:1.9rem;font-weight:800;color:var(--ink)}
.section--navy .stat b{color:#fff}
.stat span{font-size:.86rem;color:var(--muted)}
.section--navy .stat span{color:#9DB4C6}
.stats-row{display:flex;flex-wrap:wrap;gap:1.6rem 2.6rem}

/* ---------- 20. Responsive ---------- */
@media (min-width:600px){
  .grid-3{grid-template-columns:1fr 1fr}
  .field-row{grid-template-columns:1fr 1fr}
}
@media (min-width:768px){
  .grid-4{grid-template-columns:repeat(4,1fr)}
  .price-grid{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(3,1fr)}
  .footer-grid{grid-template-columns:1.6fr 1fr 1fr}
}
@media (min-width:900px){
  .nav-links,.nav-cta{display:flex}
  .hamburger{display:none}
  .grid-2{grid-template-columns:1fr 1fr}
  .grid-3{grid-template-columns:repeat(3,1fr)}
  .hero-grid{grid-template-columns:1.05fr .95fr}
  .split{grid-template-columns:1fr 1fr}
  .split.reverse .split-media{order:2}
  .price-grid{grid-template-columns:repeat(4,1fr)}
  .footer-grid{grid-template-columns:1.8fr 1fr 1fr 1.2fr}
}
@media (min-width:1024px){
  .price-grid.cols-3{grid-template-columns:repeat(3,1fr)}
}

/* Reduced motion */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;transition-duration:.001ms!important;
    scroll-behavior:auto!important}
}
/* Reveal on scroll (progressive enhancement) */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none}}

/* =================================================================
   LIBERTY4U — Neon Plasma DARK PREMIUM overrides (Phase 1+2)
   Colour/brand only. Layout, typography, spacing untouched.
   Delete this whole block to revert the rebrand colours.
   ================================================================= */
:root{
  --bg-dark:#0a0f1f; --panel:#11162b; --panel-2:#161d38;
  --purple:#7c3aed; --purple-600:#6d28d9; --purple-300:#c4b5fd;
  --cyan:#06b6d4; --blue:#2563eb; --blue-2:#3b82f6; --hot:#f43f5e; --star:#ffdd55;
  --ink:#111827; --body:#39495a; --muted:#64748b;
  --text-light:#e6ecff; --muted-light:#9aa7cc; --link-light:#9ec7ff;
  --bg-tint:#eef4ff; --border:#e6e9f2; --border-strong:#cbd3e6; --border-dark:rgba(255,255,255,.08);
  --grad-cta:linear-gradient(135deg,#7c3aed 0%,#2563eb 55%,#06b6d4 100%);
  --grad-line:linear-gradient(90deg,transparent,#7c3aed,#06b6d4,transparent);
  --glow-purple:0 10px 30px rgba(124,58,237,.30);
  --glow-cyan:0 0 24px rgba(6,182,212,.20);
  /* legacy aliases -> brand */
  --navy-900:#0a0f1f; --navy:#11162b; --navy-700:#161d38; --bg-navy:#11162b;
  --teal:#06b6d4; --teal-600:#2563eb; --teal-050:#eef4ff; --amber:#ffdd55;
}

/* Logo */
.brand img{width:200px;height:auto;max-width:60vw;border-radius:0;flex:0 0 auto}
@media (min-width:900px){ .brand img{width:215px} }
@media (max-width:600px){ .brand img{width:155px} }
.footer-brand .brand img{width:200px;height:auto}

/* Header / nav (dark, compact) */
.site-header{background:rgba(10,15,31,.94);border-bottom:1px solid rgba(255,255,255,.08)}
.nav-links a{color:var(--text-light)}
.nav-links a:hover{background:rgba(124,58,237,.16);color:#fff}
.drop-toggle{color:var(--text-light)}
.drop-toggle:hover{background:rgba(124,58,237,.16);color:#fff}
.drop-menu{background:#11162b;border:1px solid rgba(255,255,255,.08)}
.drop-menu a{color:var(--text-light)}
.drop-menu a:hover{background:rgba(124,58,237,.18)}
.drop-menu a small{color:var(--muted-light)}
.hamburger{background:transparent;border:1px solid rgba(255,255,255,.18)}
.hamburger span{background:var(--text-light)}

/* Mobile drawer (dark) */
.drawer-panel{background:#0a0f1f}
.drawer-panel a,.drawer-group>summary{color:var(--text-light);border-bottom:1px solid rgba(255,255,255,.08)}
.drawer-panel a:hover{color:var(--link-light)}
.drawer-group>summary::after,.drawer-group[open]>summary::after{color:var(--purple)}
.drawer-group .sub a{color:var(--muted-light)}

/* Hero (dark plasma; layout unchanged) */
.hero{color:var(--text-light);
  background:
    radial-gradient(1100px 480px at 82% -12%,rgba(124,58,237,.28),transparent 60%),
    radial-gradient(600px 300px at 10% 8%,rgba(6,182,212,.12),transparent 60%),
    linear-gradient(165deg,#0a0f1f 0%,#11162b 60%,#0a0f1f 100%)}
.hero::after{background:radial-gradient(700px 320px at 15% 115%,rgba(6,182,212,.10),transparent 70%)}
.hero h1{color:#fff}
.hero h1 em{color:transparent;background:linear-gradient(90deg,#a78bfa,#7c3aed 40%,#06b6d4);-webkit-background-clip:text;background-clip:text;padding:0}
.hero p.sub{color:var(--muted-light)}
.hero-rating{color:var(--muted-light)}
.hero-rating .stars{color:var(--star)}

/* Inner page hero */
.page-hero{color:var(--text-light);
  background:
    radial-gradient(900px 360px at 90% -30%,rgba(124,58,237,.24),transparent 60%),
    radial-gradient(500px 240px at 8% 0%,rgba(6,182,212,.10),transparent 60%),
    linear-gradient(160deg,#0a0f1f,#11162b)}
.page-hero h1{color:#fff}
.page-hero p{color:var(--muted-light)}
.page-hero .crumbs,.page-hero .crumbs a{color:#9aa7cc}

/* Buttons */
.btn--primary{background:var(--grad-cta);color:#fff;box-shadow:var(--glow-purple)}
.btn--primary:hover{background:linear-gradient(135deg,#6d28d9,#2563eb 55%,#06b6d4);color:#fff;box-shadow:0 14px 36px rgba(124,58,237,.40)}
.btn--light:hover{background:var(--purple);color:#fff}

/* Trust bar */
.trustbar{background:#0a0f1f;color:var(--muted-light)}
.trustbar .ti svg{color:var(--cyan)}

/* CTA bands */
.cta-band{background:linear-gradient(150deg,#0a0f1f,#11162b);color:#fff}
.cta-band::before{background:
  radial-gradient(620px 320px at 85% -20%,rgba(124,58,237,.32),transparent 60%),
  radial-gradient(420px 220px at 12% 120%,rgba(6,182,212,.14),transparent 60%)}
.cta-band p{color:var(--muted-light)}

/* Footer (dark premium) */
.site-footer{background:#0a0f1f;color:var(--muted-light);position:relative}
.site-footer::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:var(--grad-line);opacity:.6}
.footer-col h4{color:var(--text-light)}
.footer-col a,.footer-contact a,.footer-contact span,.footer-bottom,.footer-bottom a{color:var(--muted-light)}
.footer-col a:hover,.footer-bottom a:hover{color:var(--link-light)}
.footer-contact svg{color:var(--cyan)}
.footer-social a:hover{background:var(--purple);color:#fff}

/* Reusable dark brand section (used in Phase 3) */
.section--dark{background:#0a0f1f;color:var(--muted-light)}
.section--dark h2,.section--dark h3{color:#fff}
.section--dark .eyebrow{color:var(--purple-300)}
.section--dark .lead{color:var(--muted-light)}
.section--dark .feature .fi{background:rgba(124,58,237,.16);color:var(--purple-300)}
.section--dark .feature p{color:var(--muted-light)}
.section--dark .card{background:#11162b;border-color:rgba(255,255,255,.08)}

/* Cards: light + plasma hover */
.card-icon{background:var(--bg-tint);color:var(--purple)}
.card:hover{border-color:rgba(124,58,237,.35);box-shadow:0 0 0 1px rgba(124,58,237,.30),0 18px 40px rgba(124,58,237,.16)}
.card .card-link{color:var(--blue)}
.work-card:hover{border-color:rgba(124,58,237,.35);box-shadow:0 0 0 1px rgba(124,58,237,.30),0 18px 44px rgba(124,58,237,.18)}
.work-tag--dark{background:#11162b;color:#e6ecff}

/* Checklist tick (was hardcoded teal) */
.checks li::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%237c3aed' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E")}

/* Pricing accents */
.price-card.featured{border-color:var(--purple);box-shadow:0 0 0 2px var(--purple),var(--shadow)}
.ribbon{background:var(--grad-cta);color:#fff}

/* Forms + focus */
:focus-visible{outline:3px solid #7c3aed}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--purple);box-shadow:0 0 0 3px rgba(124,58,237,.18)}

/* =================================================================
   === Phase 2.5: Mobile Hero + Portfolio Card Polish ===
   Scoped polish only. Does not alter the dark premium style or
   desktop layout (except the oversized-arrow fix, which is a bug).
   ================================================================= */

/* ---- 2.5a. Portfolio/work card arrow fix (desktop + mobile) ---- *
   Root cause: .work-card .card-link svg had no size (the 15px rule
   only matched .card .card-link svg), so the inline SVG rendered at
   the browser default (~300x150) — the giant arrow. Constrain it. */
.card-link{display:inline-flex;align-items:center;gap:.4rem;line-height:1.25}
.card-link svg{width:16px;height:16px;max-width:18px;max-height:18px;flex:0 0 auto;transition:transform .18s var(--ease)}
.work-card .card-link{margin-top:.2rem;color:var(--blue);font-weight:700;font-size:.92rem}
.work-card .card-link svg{width:16px;height:16px}
.work-body{padding-bottom:1.25rem}        /* trim blank space the big arrow caused */
/* Desktop-only hover nudge; no movement on touch */
@media (min-width:900px) and (hover:hover){
  .work-card:hover .card-link svg{transform:translateX(4px)}
}
@media (hover:none){
  .work-card:hover .card-link svg{transform:none}
}

/* ---- 2.5b. Safety: never allow horizontal scroll ---- */
html,body{overflow-x:hidden}

/* ---- 2.5c. Mobile hero breathing space (<=600px) ---- */
@media (max-width:600px){
  .container{padding-inline:1.25rem}              /* ~1.15–1.35rem gutter */
  .brand img{width:165px;max-width:220px}          /* compact mobile logo */

  .hero .hero-grid{padding-top:4.75rem;padding-bottom:3.5rem}
  .hero h1{font-size:clamp(2.15rem,10vw,3.1rem);line-height:1.08}
  .hero p.sub{font-size:1.05rem;line-height:1.65}

  /* CTA buttons stack neatly, full width, capped + centred */
  .hero .btn-row{flex-direction:column;align-items:stretch;gap:.7rem}
  .hero .btn-row .btn{width:100%;max-width:22rem;margin-inline:auto;
    justify-content:center;padding:.95rem 1.15rem}

  /* review/trust line wraps cleanly */
  .hero-rating{flex-wrap:wrap;row-gap:.3rem}
}

/* =================================================================
   === Phase 2.6: Mobile Decorative Dot Cleanup ===
   The separator dots between trust-bar items (<span class="dot">)
   look awkward when items wrap on small screens. Hide on mobile
   only; icons + text stay. Used only in the homepage .trustbar,
   so no other lists are affected.
   ================================================================= */
@media (max-width:640px){
  .trustbar .dot{display:none !important}
}

/* =================================================================
   === Phase 2.7: Hero video swap ===
   Hero image replaced by hero-page.mp4. Match the previous image's
   look exactly and lock aspect-ratio so there is no layout shift
   before the video/poster loads. Badge overlay unchanged.
   ================================================================= */
.hero-media video{width:100%;height:100%;display:block;object-fit:cover;
  border-radius:var(--radius);box-shadow:var(--shadow-lg);
  border:1px solid rgba(255,255,255,.12);background:#11162b;aspect-ratio:900/650}

/* =================================================================
   === Phase 3: Dark Bands + Portfolio Preview Polish ===
   "Why Liberty4U" and the homepage portfolio preview are now
   .section--dark (HTML class swap). Styles below upgrade those two
   bands to premium dark panels. Process section stays light.
   ================================================================= */

/* Subtle plasma glow backdrop for dark bands */
.section--dark{position:relative;overflow:hidden}
.section--dark>.container{position:relative;z-index:1}
.section--dark::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(680px 320px at 12% -10%,rgba(124,58,237,.18),transparent 60%),
    radial-gradient(520px 280px at 92% 112%,rgba(6,182,212,.12),transparent 60%)}

/* "Why Liberty4U": feature rows -> premium dark tech panels */
.section--dark .feature{background:#11162b;border:1px solid rgba(255,255,255,.08);
  border-radius:var(--radius);padding:1.25rem;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04),0 14px 30px rgba(0,0,0,.35);
  transition:border-color .2s var(--ease),box-shadow .2s var(--ease),transform .2s var(--ease)}
.section--dark .feature h3{color:#e6ecff}
.section--dark .feature p{color:#9aa7cc}
.section--dark .feature .fi{background:rgba(124,58,237,.16);color:#c4b5fd}

/* Portfolio preview: white cards -> dark premium panels */
.section--dark .work-card{background:#11162b;border:1px solid rgba(255,255,255,.08)}
.section--dark .work-thumb,.section--dark .work-media{
  border-bottom:1px solid rgba(255,255,255,.08);background:#0a0f1f}
.section--dark .work-body h3{color:#e6ecff}
.section--dark .work-body p{color:#9aa7cc}
.section--dark .work-tag{background:rgba(124,58,237,.16);color:#c4b5fd}
.section--dark .work-card .card-link{color:#9ec7ff}

/* Future media area (forward-prep; no markup change required now).
   Use .work-media as a drop-in for .work-thumb when adding video. */
.work-media{aspect-ratio:16/10;overflow:hidden;background:var(--bg-soft);
  border-bottom:1px solid var(--border)}
.work-media img,.work-media video,.work-thumb video{
  width:100%;height:100%;object-fit:cover;display:block}

/* Desktop-only hover polish: lift + soft glow (arrow nudge from Phase 2.5) */
@media (min-width:900px) and (hover:hover){
  .section--dark .feature:hover{transform:translateY(-3px);
    border-color:rgba(124,58,237,.35);
    box-shadow:0 0 0 1px rgba(124,58,237,.28),0 18px 40px rgba(124,58,237,.18)}
  .section--dark .work-card:hover{border-color:rgba(124,58,237,.40);
    box-shadow:0 0 0 1px rgba(124,58,237,.30),0 20px 46px rgba(6,182,212,.12),0 18px 40px rgba(124,58,237,.20)}
}
/* Minimise hover movement on touch */
@media (hover:none){
  .section--dark .feature:hover,.section--dark .work-card:hover{transform:none}
}

/* Mobile: keep panels compact, not tall */
@media (max-width:600px){
  .section--dark .feature{padding:1.05rem}
}

/* Phase 3 fix: secondary buttons must stay readable on dark bands */
.section--dark .btn--secondary{color:#e6ecff;border-color:rgba(255,255,255,.28)}
.section--dark .btn--secondary:hover{background:#fff;color:#11162b;border-color:#fff}

/* =================================================================
   === Phase 5: Colour + Meta Cleanup ===
   Last visible teal remnants. (Other teal literals earlier in this
   file — .btn--primary, .hero, .page-hero, .checks tick, .cta-band,
   field focus — are already overridden by the Phase 1+2 block and
   are not visible; left in place to keep diffs small.)
   ================================================================= */
/* Care strip (.section--navy) pill-tag + feature icon used old teal tint */
.section--navy .split .pill-tag,
.section--navy .feature .fi{background:rgba(124,58,237,.16);color:#c4b5fd}
/* CTA-band phone/email links: subtle hover (inline colour needs !important) */
.cta-band p a:hover{color:#ffffff !important}

/* === Conversion Prefill + Service Image Updates + Hero Review Alignment === */
.hero-rating{align-items:center;gap:.55rem;flex-wrap:wrap}
.hero-rating .stars{font-size:1rem;line-height:1;letter-spacing:2px}
@media (max-width:600px){
  .hero-rating{justify-content:center;text-align:center;row-gap:.25rem}
}

/* === Cookie Consent banner + preferences modal (consent-gated GTM) === */
.l4u-cc{position:fixed;left:0;right:0;bottom:0;z-index:300;
  background:rgba(10,15,31,.97);backdrop-filter:saturate(160%) blur(8px);
  border-top:1px solid rgba(255,255,255,.10);box-shadow:0 -10px 30px rgba(0,0,0,.4);color:var(--text-light)}
.l4u-cc__inner{max-width:var(--maxw);margin-inline:auto;padding:1rem var(--gutter);
  display:flex;flex-wrap:wrap;align-items:center;gap:.8rem 1.4rem;justify-content:space-between}
.l4u-cc__text{margin:0;font-size:.9rem;color:var(--muted-light);max-width:60ch;line-height:1.5}
.l4u-cc__text a{color:var(--link-light)}
.l4u-cc__btns{display:flex;flex-wrap:wrap;gap:.5rem}
.l4u-btn{font:inherit;font-weight:700;font-size:.9rem;cursor:pointer;border-radius:var(--radius-pill);
  padding:.6rem 1.05rem;border:1px solid rgba(255,255,255,.22);background:transparent;color:var(--text-light);
  transition:background .2s,border-color .2s,transform .15s var(--ease)}
.l4u-btn:hover{transform:translateY(-1px)}
.l4u-btn--primary{background:var(--grad-cta);border-color:transparent;color:#fff;box-shadow:var(--glow-purple)}
.l4u-btn--ghost{background:rgba(124,58,237,.14);border-color:rgba(124,58,237,.4)}

.l4u-modal{position:fixed;inset:0;z-index:310;display:flex;align-items:center;justify-content:center;
  padding:var(--gutter);background:rgba(5,8,18,.7)}
.l4u-modal__card{background:#11162b;border:1px solid rgba(255,255,255,.10);border-radius:var(--radius);
  box-shadow:0 24px 60px rgba(0,0,0,.5);max-width:520px;width:100%;padding:clamp(1.3rem,3vw,1.9rem);color:var(--text-light)}
.l4u-modal__card h2{color:#fff;font-size:1.3rem;margin:0 0 .4rem}
.l4u-modal__lead{color:var(--muted-light);font-size:.92rem;margin:0 0 1rem}
.l4u-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding:.8rem 0;border-top:1px solid rgba(255,255,255,.08)}
.l4u-row strong{display:block;color:var(--text-light);font-size:.98rem}
.l4u-row small{display:block;color:var(--muted-light);font-size:.82rem;margin-top:.1rem}
.l4u-always{color:#8ee6c6;font-weight:700;font-size:.82rem;white-space:nowrap}
.l4u-switch{position:relative;flex:0 0 auto;width:46px;height:26px}
.l4u-switch input{position:absolute;opacity:0;width:100%;height:100%;margin:0;cursor:pointer}
.l4u-switch i{position:absolute;inset:0;border-radius:999px;background:rgba(255,255,255,.18);transition:.2s}
.l4u-switch i::after{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;transition:.2s}
.l4u-switch input:checked + i{background:var(--purple)}
.l4u-switch input:checked + i::after{transform:translateX(20px)}
.l4u-switch input:focus-visible + i{outline:3px solid #7c3aed;outline-offset:2px}
.l4u-modal .l4u-cc__btns{margin-top:1.2rem;justify-content:flex-end}

.l4u-cc-link{cursor:pointer}
@media (max-width:600px){
  .l4u-cc__inner{flex-direction:column;align-items:flex-start}
  .l4u-cc__btns{width:100%}
  .l4u-cc__btns .l4u-btn{flex:1 1 auto;text-align:center}
}

/* === Cookie consent visibility fix (class-based; replaces [hidden]) ===
   The earlier .l4u-modal{display:flex} overrode the [hidden] attribute,
   so the overlay never closed. Hide by default; show via .is-open. */
.l4u-cc,.l4u-modal{display:none}
.l4u-cc.is-open{display:block}
.l4u-modal.is-open{display:flex}

/* === Final Polish: Sticky Header === */
/* Phase 2.5 used overflow-x:hidden on html/body, which creates a scroll
   container and breaks position:sticky. overflow-x:clip stops horizontal
   scroll WITHOUT breaking sticky. */
html,body{overflow-x:clip}
.site-header{position:sticky;top:0;z-index:100}
/* Subtle scrolled state (JS toggles .is-scrolled; see script.js) */
.site-header.is-scrolled{background:rgba(10,15,31,.97);box-shadow:0 6px 22px rgba(0,0,0,.35);
  border-bottom-color:rgba(124,58,237,.30)}
/* Keep anchor targets clear of the sticky header */
[id]{scroll-margin-top:calc(var(--nav-h) + 16px)}

/* === Mobile Menu Scroll Lock Fix === */
/* iOS-safe lock: body is fixed at -scrollY (JS), so the page behind the
   open menu cannot scroll; JS restores scroll on close. */
body.nav-open{position:fixed;left:0;right:0;width:100%;overflow:hidden}
/* While the menu is open, pin the header so the logo + close X stay
   visible (sticky doesn't hold under a position:fixed body). */
body.nav-open .site-header{position:fixed;top:0;left:0;right:0;z-index:100}
/* Drawer panel scrolls internally and never chains scroll to the page. */
.drawer-panel{overscroll-behavior:contain;-webkit-overflow-scrolling:touch}
