/* ============================================================
   ProbateMatch.ie — Design System
   Deep navy + gold/amber. DM Serif Display + DM Sans.
   ============================================================ */
:root{
  --navy:#0E1C2B; --navy-2:#16293c; --slate:#33475b; --mid:#5a6b7b;
  --gold:#C8A24B; --gold-dark:#A8842F; --gold-light:#F6EEDB;
  --green:#1E7A5A; --green-light:#e6f4ee;
  --cream:#FBF8F1; --light:#F5F7FA; --white:#ffffff; --border:#e3e8ee;
  --danger:#c0392b;
  --shadow:0 6px 28px rgba(14,28,43,0.10);
  --shadow-sm:0 2px 10px rgba(14,28,43,0.06);
  --radius:14px; --radius-sm:10px;
  --maxw:1080px;
}
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:'DM Sans',system-ui,sans-serif;background:var(--light);color:var(--navy);line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased;}
a{color:var(--gold-dark);text-decoration:none;}
a:hover{text-decoration:underline;}
img{max-width:100%;display:block;}
h1,h2,h3,h4{font-family:'DM Serif Display',Georgia,serif;font-weight:400;line-height:1.18;color:var(--navy);}

/* ---------- Layout helpers ---------- */
.container{max-width:var(--maxw);margin:0 auto;padding:0 22px;}
.narrow{max-width:760px;margin-left:auto;margin-right:auto;}
.section{padding:64px 0;}
.section-sm{padding:40px 0;}
.center{text-align:center;}
.muted{color:var(--mid);}
.eyebrow{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1.6px;color:var(--gold-dark);margin-bottom:10px;}

/* ---------- Nav ---------- */
nav.site-nav{background:var(--navy);height:66px;position:sticky;top:0;z-index:100;box-shadow:0 2px 18px rgba(0,0,0,0.2);}
.nav-inner{max-width:var(--maxw);margin:0 auto;height:100%;padding:0 22px;display:flex;align-items:center;justify-content:space-between;}
.brand{font-family:'DM Serif Display',serif;font-size:21px;color:#fff;letter-spacing:0.2px;}
.brand span{color:var(--gold);}
.nav-links{display:flex;align-items:center;gap:6px;}
.nav-links a{color:rgba(255,255,255,0.78);font-family:'DM Sans',sans-serif;font-size:14px;font-weight:500;padding:8px 12px;border-radius:8px;transition:all .18s;}
.nav-links a:hover{color:#fff;background:rgba(255,255,255,0.08);text-decoration:none;}
.nav-cta{background:var(--gold)!important;color:var(--navy)!important;font-weight:700!important;padding:9px 18px!important;}
.nav-cta:hover{background:var(--gold-dark)!important;color:#fff!important;}
.nav-toggle{display:none;background:none;border:none;color:#fff;font-size:24px;cursor:pointer;}

/* ---------- Hero ---------- */
.hero{background:linear-gradient(150deg,var(--navy) 0%,var(--navy-2) 55%,#1d3850 100%);color:#fff;padding:76px 0 84px;position:relative;overflow:hidden;}
.hero::after{content:"";position:absolute;right:-120px;top:-120px;width:360px;height:360px;border-radius:50%;background:radial-gradient(circle,rgba(200,162,75,0.18),transparent 70%);}
.hero .container{position:relative;z-index:2;}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(200,162,75,0.14);border:1px solid rgba(200,162,75,0.35);color:var(--gold);font-size:13px;font-weight:600;padding:7px 16px;border-radius:30px;margin-bottom:22px;}
.hero h1{font-size:clamp(33px,5.4vw,56px);color:#fff;max-width:760px;margin-bottom:18px;}
.hero h1 em{font-style:italic;color:var(--gold);}
.hero p.lead{color:rgba(255,255,255,0.74);font-size:19px;max-width:560px;margin-bottom:34px;font-weight:300;}
.hero-stats{display:flex;gap:38px;flex-wrap:wrap;margin-top:40px;}
.hero-stats .num{font-family:'DM Serif Display',serif;font-size:30px;color:#fff;}
.hero-stats .lbl{font-size:12px;text-transform:uppercase;letter-spacing:0.6px;color:rgba(255,255,255,0.5);margin-top:2px;}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;padding:14px 30px;border-radius:var(--radius-sm);border:none;font-family:'DM Sans',sans-serif;font-size:15px;font-weight:700;cursor:pointer;transition:all .18s;text-decoration:none;}
.btn-gold{background:var(--gold);color:var(--navy);box-shadow:0 6px 18px rgba(200,162,75,0.32);}
.btn-gold:hover{background:var(--gold-dark);color:#fff;transform:translateY(-1px);text-decoration:none;}
.btn-navy{background:var(--navy);color:#fff;}
.btn-navy:hover{background:var(--navy-2);color:#fff;text-decoration:none;}
.btn-ghost{background:transparent;color:var(--navy);border:1.5px solid var(--border);}
.btn-ghost:hover{background:var(--light);text-decoration:none;}
.btn-lg{padding:16px 38px;font-size:16px;}
.btn:disabled{opacity:.55;cursor:not-allowed;transform:none;}

/* ---------- Cards / grids ---------- */
.grid{display:grid;gap:22px;}
.grid-2{grid-template-columns:repeat(2,1fr);}
.grid-3{grid-template-columns:repeat(3,1fr);}
.grid-4{grid-template-columns:repeat(4,1fr);}
.card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow-sm);}
.card h3{font-size:19px;margin-bottom:10px;}
.card .ico{font-size:30px;margin-bottom:12px;display:block;}
.feature p{color:var(--mid);font-size:15px;}

/* ---------- Form ---------- */
.form-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:34px;}
.form-card h2{font-size:24px;margin-bottom:6px;}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:22px;}
.fg{display:flex;flex-direction:column;gap:6px;}
.fg.full{grid-column:1/-1;}
label{font-size:13.5px;font-weight:600;color:var(--navy);}
label .req{color:var(--gold-dark);}
input,select,textarea{padding:12px 14px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-family:'DM Sans',sans-serif;font-size:15px;color:var(--navy);background:#fff;outline:none;transition:border-color .18s,box-shadow .18s;width:100%;}
input:focus,select:focus,textarea:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(200,162,75,0.16);}
textarea{resize:vertical;min-height:96px;}
.hint{font-size:12px;color:#94a3b8;}
.consent{display:flex;align-items:flex-start;gap:10px;background:var(--light);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:14px;margin-top:20px;font-size:13px;color:var(--mid);}
.consent input{width:18px;height:18px;margin-top:2px;flex-shrink:0;}

/* ---------- Confirmation ---------- */
.confirm{display:none;text-align:center;padding:46px 24px;}
.confirm .big{font-size:60px;margin-bottom:14px;}
.confirm h2{font-size:30px;margin-bottom:12px;}
.confirm p{color:var(--mid);font-size:17px;max-width:480px;margin:0 auto 10px;}
.ref-chip{display:inline-block;background:var(--gold-light);border:1px solid rgba(200,162,75,0.4);border-radius:var(--radius-sm);padding:12px 22px;margin-top:18px;}
.ref-chip .l{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--gold-dark);}
.ref-chip .v{font-family:'DM Serif Display',serif;font-size:22px;}

/* ---------- Steps / how it works ---------- */
.steps3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;counter-reset:s;}
.steps3 .step{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:28px;position:relative;}
.steps3 .step .n{width:40px;height:40px;border-radius:50%;background:var(--navy);color:var(--gold);font-family:'DM Serif Display',serif;font-size:18px;display:flex;align-items:center;justify-content:center;margin-bottom:14px;}
.steps3 .step h3{font-size:18px;margin-bottom:8px;}
.steps3 .step p{font-size:14.5px;color:var(--mid);}

/* ---------- Trust band ---------- */
.trust{background:var(--cream);border-top:1px solid var(--border);border-bottom:1px solid var(--border);}
.trust .row{display:flex;flex-wrap:wrap;gap:30px;justify-content:center;align-items:center;color:var(--slate);font-size:14px;font-weight:600;}
.trust .row span{display:inline-flex;align-items:center;gap:8px;}

/* ---------- Content (article) pages ---------- */
.content h1{font-size:clamp(30px,4.4vw,44px);margin-bottom:14px;}
.content h2{font-size:27px;margin:38px 0 14px;}
.content h3{font-size:20px;margin:26px 0 10px;}
.content p,.content li{font-size:16.5px;color:var(--slate);}
.content p{margin-bottom:16px;}
.content ul,.content ol{margin:0 0 18px 22px;}
.content li{margin-bottom:8px;}
.content .lead{font-size:19px;color:var(--mid);margin-bottom:26px;}
.callout{background:var(--gold-light);border-left:4px solid var(--gold);border-radius:8px;padding:18px 22px;margin:24px 0;font-size:15.5px;color:var(--slate);}
.callout strong{color:var(--navy);}
.breadcrumb{font-size:13px;color:var(--mid);padding:18px 0 0;}
.breadcrumb a{color:var(--mid);}

/* ---------- CTA band ---------- */
.cta-band{background:var(--navy);color:#fff;border-radius:var(--radius);padding:40px;text-align:center;}
.cta-band h2{color:#fff;font-size:28px;margin-bottom:10px;}
.cta-band p{color:rgba(255,255,255,0.72);max-width:520px;margin:0 auto 22px;}

/* ---------- FAQ ---------- */
.faq details{background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);padding:0;margin-bottom:12px;overflow:hidden;}
.faq summary{cursor:pointer;padding:18px 22px;font-weight:600;font-size:16px;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:12px;}
.faq summary::-webkit-details-marker{display:none;}
.faq summary::after{content:"+";color:var(--gold-dark);font-size:22px;font-weight:700;}
.faq details[open] summary::after{content:"\2013";}
.faq details[open] summary{border-bottom:1px solid var(--border);}
.faq .ans{padding:16px 22px;color:var(--slate);font-size:15.5px;}

/* ---------- County chips ---------- */
.county-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px;}
.county-grid a{background:#fff;border:1px solid var(--border);border-radius:8px;padding:11px 14px;font-size:14px;font-weight:500;color:var(--navy);text-align:center;transition:all .15s;}
.county-grid a:hover{border-color:var(--gold);background:var(--gold-light);text-decoration:none;}

/* ---------- Footer ---------- */
footer.site-footer{background:var(--navy);color:rgba(255,255,255,0.6);padding:54px 0 30px;margin-top:72px;font-size:14px;}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:30px;margin-bottom:34px;}
.foot-grid h4{color:#fff;font-family:'DM Sans',sans-serif;font-size:13px;text-transform:uppercase;letter-spacing:1px;margin-bottom:14px;font-weight:700;}
.foot-grid a{color:rgba(255,255,255,0.6);display:block;padding:4px 0;font-size:14px;}
.foot-grid a:hover{color:var(--gold);text-decoration:none;}
.foot-brand{font-family:'DM Serif Display',serif;font-size:20px;color:#fff;margin-bottom:10px;}
.foot-brand span{color:var(--gold);}
.foot-bottom{border-top:1px solid rgba(255,255,255,0.12);padding-top:20px;font-size:12.5px;color:rgba(255,255,255,0.45);display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;}
.foot-disclaimer{font-size:11.5px;color:rgba(255,255,255,0.4);margin-top:14px;line-height:1.6;max-width:760px;}

/* ---------- Toast ---------- */
.toast{position:fixed;bottom:24px;right:24px;background:var(--navy);color:#fff;padding:14px 22px;border-radius:12px;font-size:14px;font-weight:500;box-shadow:0 8px 32px rgba(0,0,0,0.25);z-index:9999;transform:translateY(90px);opacity:0;transition:all .35s;max-width:330px;}
.toast.show{transform:translateY(0);opacity:1;}
.toast.error{border-left:4px solid var(--danger);}
.toast.success{border-left:4px solid var(--green);}

/* ---------- Cookie consent banner ---------- */
.cookie-banner{position:fixed;left:16px;right:16px;bottom:16px;z-index:9998;max-width:760px;margin:0 auto;background:var(--navy);color:rgba(255,255,255,0.9);border:1px solid rgba(255,255,255,0.15);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px 20px;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;}
.cookie-banner[hidden]{display:none;}
.cookie-banner p{font-size:13.5px;margin:0;flex:1;min-width:240px;color:rgba(255,255,255,0.82);}
.cookie-banner a{color:var(--gold);}
.cookie-actions{display:flex;gap:10px;flex-shrink:0;}
.cookie-banner .btn{padding:9px 18px;font-size:14px;}
.cookie-banner .btn-ghost{color:#fff;border-color:rgba(255,255,255,0.4);background:transparent;}
.cookie-banner .btn-ghost:hover{background:rgba(255,255,255,0.08);}

/* ---------- Responsive ---------- */
@media(max-width:860px){
  .grid-3,.grid-4,.steps3{grid-template-columns:1fr 1fr;}
  .foot-grid{grid-template-columns:1fr 1fr;}
}
@media(max-width:640px){
  .nav-links{position:absolute;top:66px;left:0;right:0;background:var(--navy);flex-direction:column;align-items:stretch;padding:10px 16px;gap:2px;display:none;border-top:1px solid rgba(255,255,255,0.1);}
  .nav-links.open{display:flex;}
  .nav-links a{padding:12px;}
  .nav-toggle{display:block;}
  .form-grid,.grid-2,.grid-3,.grid-4,.steps3{grid-template-columns:1fr;}
  .fg.full{grid-column:1;}
  .foot-grid{grid-template-columns:1fr;}
  .section{padding:48px 0;}
  .hero{padding:54px 0 60px;}
  .form-card{padding:24px 20px;}
}
