/* ================================================================
   FundWatch.ie — Design System
   Indigo + warm gold + cream — wealth-management aesthetic
   ================================================================ */

:root{
  /* Palette */
  --indigo:#131e3f;
  --indigo-dark:#0a1229;
  --indigo-mid:#1f2d55;
  --indigo-soft:#e8ebf3;
  --gold:#c9a22a;
  --gold-dark:#a5841b;
  --gold-light:#ecd887;
  --gold-pale:#faf3d6;
  --cream:#faf7ef;
  --cream-warm:#f4eedd;
  --parchment:#fffdf7;
  --ink:#1a1d2e;
  --ink-soft:#3d4356;
  --ink-muted:#6e7485;
  --border:#e6e2d4;
  --border-strong:#c8c2ae;
  --white:#ffffff;
  --green:#2f7a5a;
  --green-pale:#e0f0e6;
  --red:#b34242;
  --red-pale:#fbe7e4;

  /* Layout */
  --radius-sm:4px;
  --radius:8px;
  --radius-lg:14px;
  --radius-xl:20px;
  --shadow-sm:0 1px 2px rgba(19,30,63,.06),0 2px 6px rgba(19,30,63,.04);
  --shadow-md:0 2px 8px rgba(19,30,63,.08),0 10px 24px rgba(19,30,63,.06);
  --shadow-lg:0 4px 14px rgba(19,30,63,.1),0 24px 48px rgba(19,30,63,.1);
  --max:1180px;

  /* Type */
  --serif:'Source Serif 4','Times New Roman',Georgia,serif;
  --sans:'DM Sans',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--sans);
  color:var(--ink);
  background:var(--cream);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

h1,h2,h3,h4,h5{
  font-family:var(--serif);
  color:var(--indigo-dark);
  line-height:1.18;
  font-weight:600;
  letter-spacing:-.015em;
  margin:0 0 .55em;
}
h1{font-size:clamp(2rem,4.4vw,3.4rem);font-weight:500}
h2{font-size:clamp(1.6rem,3vw,2.3rem)}
h3{font-size:clamp(1.2rem,2vw,1.5rem)}
h4{font-size:1.1rem;font-weight:600}
h5{font-size:.95rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-soft)}
p{margin:0 0 1.1em;color:var(--ink-soft)}
a{color:var(--indigo);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px;transition:color .15s}
a:hover{color:var(--gold-dark)}
small{color:var(--ink-muted);font-size:.85rem}
hr{border:0;border-top:1px solid var(--border);margin:2.5rem 0}
code{font-family:ui-monospace,Menlo,monospace;font-size:.88em;background:var(--indigo-soft);padding:.12em .4em;border-radius:4px;color:var(--indigo-dark)}

/* ---- Layout ---- */
.wrap{max-width:var(--max);margin:0 auto;padding:0 1.25rem}
.section{padding:5rem 0}
.section--tight{padding:3rem 0}
.section--cream{background:var(--cream-warm)}
.section--white{background:var(--white)}
.section--indigo{background:var(--indigo);color:#d9ddea}
.section--indigo h1,.section--indigo h2,.section--indigo h3,.section--indigo h4{color:var(--white)}
.section--indigo p{color:#aeb5cc}

.eyebrow{
  display:inline-block;
  font-size:.78rem;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:var(--gold-dark);
  margin-bottom:1.1rem;
}
.eyebrow::before{content:"◆  "}
.section--indigo .eyebrow{color:var(--gold-light)}

/* ---- Top bar ---- */
.topbar{
  background:var(--parchment);
  border-bottom:1px solid var(--border);
  padding:.9rem 0;
  position:sticky;top:0;z-index:50;
  backdrop-filter:blur(8px);
  background-color:rgba(255,253,247,.92);
}
.topbar-inner{display:flex;align-items:center;justify-content:space-between;gap:1.5rem}
.brand{font-family:var(--serif);font-size:1.4rem;font-weight:600;color:var(--indigo-dark);text-decoration:none;letter-spacing:-.01em;display:flex;align-items:center;gap:.55rem}
.brand:hover{color:var(--indigo-dark)}
.brand-mark{width:28px;height:28px;border-radius:50%;background:radial-gradient(circle at 30% 30%,var(--gold-light),var(--gold) 60%,var(--gold-dark));display:inline-block;position:relative;flex-shrink:0}
.brand-mark::after{content:"";position:absolute;inset:6px;border-radius:50%;background:var(--indigo-dark)}
.brand em{color:var(--gold-dark);font-style:normal}
.nav{display:flex;align-items:center;gap:1.8rem}
.nav a{color:var(--ink-soft);text-decoration:none;font-size:.94rem;font-weight:500;transition:color .15s}
.nav a:hover{color:var(--indigo)}
.nav a.active{color:var(--indigo-dark);font-weight:600}
.nav-cta{padding:.55rem 1rem;border-radius:var(--radius);background:var(--indigo);color:var(--white)!important;transition:background .15s}
.nav-cta:hover{background:var(--indigo-dark);color:var(--white)!important}
.menu-btn{display:none;background:none;border:0;color:var(--indigo);font-size:1.5rem;cursor:pointer;padding:.25rem}

@media(max-width:860px){
  .nav{position:fixed;top:0;right:0;bottom:0;width:85%;max-width:320px;background:var(--parchment);flex-direction:column;align-items:flex-start;padding:5rem 1.5rem 2rem;gap:.2rem;transform:translateX(100%);transition:transform .28s;box-shadow:var(--shadow-lg)}
  .nav.open{transform:translateX(0)}
  .nav a{display:block;width:100%;padding:.9rem .25rem;border-bottom:1px solid var(--border);font-size:1rem}
  .nav-cta{margin-top:1rem;width:100%;text-align:center;border-bottom:0!important}
  .menu-btn{display:block}
  .menu-btn.open::before{content:"✕"}
  .menu-btn:not(.open)::before{content:"☰"}
}

/* ---- Buttons ---- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.45rem;
  padding:.9rem 1.55rem;border-radius:var(--radius);
  font-family:var(--sans);font-weight:600;font-size:.95rem;
  text-decoration:none;border:1px solid transparent;cursor:pointer;
  transition:transform .08s,background .15s,border-color .15s,color .15s,box-shadow .15s;
  white-space:nowrap;
}
.btn:active{transform:translateY(1px)}
.btn--primary{background:var(--indigo);color:var(--white)}
.btn--primary:hover{background:var(--indigo-dark);color:var(--white);box-shadow:var(--shadow-md)}
.btn--gold{background:var(--gold);color:var(--indigo-dark)}
.btn--gold:hover{background:var(--gold-dark);color:var(--white);box-shadow:var(--shadow-md)}
.btn--ghost{background:transparent;color:var(--indigo);border-color:var(--border-strong)}
.btn--ghost:hover{border-color:var(--indigo);background:var(--white)}
.btn--light{background:var(--white);color:var(--indigo);border-color:var(--border)}
.btn--light:hover{border-color:var(--indigo);color:var(--indigo-dark)}
.btn--sm{padding:.55rem 1rem;font-size:.85rem}

/* ---- Hero ---- */
.hero{
  background:linear-gradient(160deg,var(--indigo-dark) 0%,var(--indigo) 55%,var(--indigo-mid) 100%);
  color:#d9ddea;padding:5rem 0 5.5rem;position:relative;overflow:hidden;
}
.hero::before{
  content:"";position:absolute;top:-20%;right:-10%;width:60%;aspect-ratio:1;border-radius:50%;
  background:radial-gradient(circle,rgba(201,162,42,.22) 0%,transparent 65%);
  pointer-events:none;
}
.hero::after{
  content:"";position:absolute;inset:0;
  background-image:radial-gradient(rgba(255,255,255,.035) 1px,transparent 1px);
  background-size:22px 22px;pointer-events:none;
}
.hero-inner{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.hero h1{color:var(--white);margin-bottom:1.2rem}
.hero h1 em{font-style:italic;color:var(--gold-light);font-weight:400}
.hero p.lead{font-size:1.15rem;color:#c2c8de;margin-bottom:2rem;max-width:46ch}
.hero-ctas{display:flex;gap:.8rem;flex-wrap:wrap}

/* Hero quick-stats panel */
.hero-stats{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.1);
  border-radius:var(--radius-lg);
  padding:2rem;backdrop-filter:blur(4px);
}
.hero-stats h4{color:var(--gold-light);font-family:var(--sans);font-size:.78rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;margin-bottom:1.3rem}
.hero-stat-row{display:flex;justify-content:space-between;align-items:baseline;padding:.85rem 0;border-top:1px dashed rgba(255,255,255,.12)}
.hero-stat-row:first-of-type{border-top:0;padding-top:0}
.hero-stat-label{color:#aeb5cc;font-size:.9rem}
.hero-stat-val{font-family:var(--serif);font-size:1.35rem;color:var(--white);font-weight:500}
.hero-stat-val.up{color:#6fd89a}
.hero-stat-val.down{color:#ff8b85}
.hero-stats-foot{margin-top:1.3rem;font-size:.78rem;color:#8f95ac;padding-top:1rem;border-top:1px solid rgba(255,255,255,.08)}

@media(max-width:860px){.hero-inner{grid-template-columns:1fr;gap:2.5rem}}

/* ---- Cards ---- */
.grid{display:grid;gap:1.5rem}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:860px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}
@media(max-width:1040px){.grid-4{grid-template-columns:repeat(2,1fr)}}

.card{
  background:var(--parchment);border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:1.75rem;transition:box-shadow .2s,border-color .2s,transform .15s;
  display:flex;flex-direction:column;
}
.card:hover{border-color:var(--gold);box-shadow:var(--shadow-md);transform:translateY(-2px)}
.card h3{margin-bottom:.6rem}
.card p{color:var(--ink-soft);margin-bottom:1rem;flex:1}
.card-link{margin-top:auto;font-weight:600;color:var(--indigo);text-decoration:none;display:inline-flex;align-items:center;gap:.3rem;font-size:.92rem}
.card-link:hover{color:var(--gold-dark)}
.card-link::after{content:"→";transition:transform .15s}
.card-link:hover::after{transform:translateX(3px)}

.card-icon{width:40px;height:40px;border-radius:10px;background:var(--gold-pale);color:var(--gold-dark);display:flex;align-items:center;justify-content:center;font-size:1.25rem;margin-bottom:1rem;font-family:var(--serif)}

/* ---- Table ---- */
.table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--parchment);box-shadow:var(--shadow-sm)}
.fund-table{width:100%;border-collapse:collapse;font-size:.93rem;min-width:780px}
.fund-table thead{background:var(--cream-warm)}
.fund-table th{text-align:left;padding:1rem 1.1rem;font-weight:600;color:var(--indigo-dark);border-bottom:1px solid var(--border);font-size:.82rem;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}
.fund-table td{padding:1.1rem;border-bottom:1px solid var(--border);vertical-align:middle}
.fund-table tr:last-child td{border-bottom:0}
.fund-table tbody tr{transition:background .1s}
.fund-table tbody tr:hover{background:var(--cream)}
.fund-table .num{font-family:var(--serif);font-size:1.05rem;color:var(--indigo-dark);font-weight:600}
.fund-table .num.up{color:var(--green)}
.fund-table .num.down{color:var(--red)}
.fund-provider{display:flex;align-items:center;gap:.7rem}
.provider-mark{width:34px;height:34px;border-radius:8px;background:var(--indigo-soft);display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:700;color:var(--indigo);border:1px solid var(--border);flex-shrink:0}
.fund-name{font-weight:600;color:var(--indigo-dark);line-height:1.25}
.fund-provider-name{font-size:.8rem;color:var(--ink-muted);margin-top:.15rem}

/* ---- Pills / tags ---- */
.pill{display:inline-block;padding:.2rem .55rem;border-radius:20px;font-size:.72rem;font-weight:600;letter-spacing:.02em}
.pill-risk{background:var(--indigo-soft);color:var(--indigo-dark)}
.pill-low{background:var(--green-pale);color:var(--green)}
.pill-mid{background:var(--gold-pale);color:var(--gold-dark)}
.pill-high{background:var(--red-pale);color:var(--red)}
.pill-type{background:var(--parchment);color:var(--ink-soft);border:1px solid var(--border)}
.pill-esg{background:#d7ecdc;color:#1f5c3e}
.pill-new{background:var(--indigo);color:var(--white)}

/* ---- Filters ---- */
.filters{
  background:var(--parchment);border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:1.4rem;display:flex;flex-wrap:wrap;gap:1rem;align-items:end;margin-bottom:1.5rem;
}
.filter-group{display:flex;flex-direction:column;gap:.35rem;flex:1;min-width:160px}
.filter-group label{font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-muted)}
.filter-group select,.filter-group input{
  padding:.6rem .8rem;border:1px solid var(--border-strong);border-radius:var(--radius);
  background:var(--white);font-family:var(--sans);font-size:.92rem;color:var(--ink);
}
.filter-group select:focus,.filter-group input:focus{outline:0;border-color:var(--indigo)}

/* ---- Calculator ---- */
.calc{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:start}
@media(max-width:860px){.calc{grid-template-columns:1fr}}
.calc-panel{background:var(--parchment);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem;box-shadow:var(--shadow-sm)}
.calc-field{margin-bottom:1.3rem}
.calc-field label{display:flex;justify-content:space-between;font-weight:600;color:var(--indigo-dark);font-size:.92rem;margin-bottom:.5rem}
.calc-field label span{color:var(--gold-dark);font-family:var(--serif);font-size:1.05rem}
.calc-field input[type=range]{width:100%;accent-color:var(--indigo)}
.calc-field input[type=number]{width:100%;padding:.65rem .85rem;border:1px solid var(--border-strong);border-radius:var(--radius);font-family:var(--sans);font-size:1rem}
.calc-field input[type=number]:focus{outline:0;border-color:var(--indigo)}
.calc-result{background:linear-gradient(140deg,var(--indigo-dark),var(--indigo));color:#d9ddea;border-radius:var(--radius-lg);padding:2rem;box-shadow:var(--shadow-md)}
.calc-result h3{color:var(--white);margin-bottom:1.3rem}
.calc-result-row{display:flex;justify-content:space-between;padding:.85rem 0;border-top:1px dashed rgba(255,255,255,.12)}
.calc-result-row:first-of-type{border-top:0;padding-top:0}
.calc-result-label{color:#aeb5cc}
.calc-result-val{font-family:var(--serif);font-size:1.4rem;font-weight:500;color:var(--white)}
.calc-result-val.hero-val{font-size:2rem;color:var(--gold-light)}

/* ---- News cards ---- */
.news-card{display:flex;flex-direction:column;background:var(--parchment);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:box-shadow .2s,border-color .2s,transform .15s}
.news-card:hover{border-color:var(--gold);box-shadow:var(--shadow-md);transform:translateY(-2px)}
.news-card-img{aspect-ratio:16/9;background:linear-gradient(135deg,var(--indigo-mid),var(--indigo-dark));position:relative;overflow:hidden}
.news-card-img::after{
  content:"";position:absolute;inset:0;
  background-image:radial-gradient(rgba(201,162,42,.18) 1px,transparent 1px);
  background-size:14px 14px;
}
.news-card-img.g2{background:linear-gradient(135deg,#3d2f5c,#1f2d55)}
.news-card-img.g3{background:linear-gradient(135deg,#1f4a3d,var(--indigo-dark))}
.news-card-img.g4{background:linear-gradient(135deg,#5c3d2f,var(--indigo-dark))}
.news-card-body{padding:1.5rem;display:flex;flex-direction:column;flex:1}
.news-card-meta{font-size:.78rem;color:var(--ink-muted);margin-bottom:.6rem;text-transform:uppercase;letter-spacing:.05em}
.news-card h3{font-size:1.2rem;margin-bottom:.7rem;line-height:1.3}
.news-card p{font-size:.93rem;flex:1;margin-bottom:1rem}

/* ---- Footer ---- */
.footer{background:var(--indigo-dark);color:#9ba2bf;padding:4rem 0 2rem}
.footer a{color:#c6cbdd;text-decoration:none}
.footer a:hover{color:var(--gold-light)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3rem}
@media(max-width:860px){.footer-grid{grid-template-columns:1fr 1fr;gap:2rem}}
.footer h5{color:var(--gold-light);font-family:var(--sans);font-size:.78rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;margin-bottom:1rem}
.footer-brand{font-family:var(--serif);font-size:1.4rem;color:var(--white);margin-bottom:.8rem;font-weight:500}
.footer-brand em{color:var(--gold-light);font-style:normal}
.footer p{color:#8189a7;font-size:.9rem;line-height:1.6}
.footer ul{list-style:none;padding:0;margin:0}
.footer li{margin-bottom:.55rem;font-size:.92rem}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:2rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;font-size:.85rem;color:#6b7290}
.footer-bottom a{color:#8189a7;margin-left:1.2rem}

/* ---- Alerts / callouts ---- */
.callout{
  background:var(--gold-pale);border-left:3px solid var(--gold);
  padding:1.1rem 1.3rem;border-radius:0 var(--radius) var(--radius) 0;margin:1.5rem 0;
}
.callout strong{color:var(--indigo-dark)}
.callout--indigo{background:var(--indigo-soft);border-color:var(--indigo)}
.callout--warn{background:var(--red-pale);border-color:var(--red)}

/* ---- Prose (guides) ---- */
.prose{max-width:72ch;margin:0 auto}
.prose h2{margin-top:2.4rem}
.prose h3{margin-top:1.8rem}
.prose ul,.prose ol{padding-left:1.3rem;margin-bottom:1.2rem;color:var(--ink-soft)}
.prose ul li,.prose ol li{margin-bottom:.45rem}
.prose blockquote{border-left:3px solid var(--gold);padding:.3rem 1.2rem;margin:1.5rem 0;font-family:var(--serif);font-style:italic;color:var(--indigo-dark);font-size:1.15rem}

/* ---- Disclaimer bar ---- */
.disclaimer{background:var(--cream-warm);border-bottom:1px solid var(--border);padding:.55rem 0;font-size:.78rem;color:var(--ink-muted);text-align:center}

/* ---- Utilities ---- */
.center{text-align:center}
.mb-0{margin-bottom:0!important}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2.5rem}
.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2.5rem}
.text-muted{color:var(--ink-muted)}
.text-gold{color:var(--gold-dark)}

/* ---- Guide cards ---- */
.guide-card{position:relative;padding-top:1.6rem}
.guide-card .guide-mark{font-family:var(--serif);font-size:2rem;font-weight:500;color:var(--gold-dark);letter-spacing:-.02em;margin-bottom:.6rem;line-height:1}
.guide-card h3{font-size:1.3rem;margin-bottom:.7rem}

/* ---- Extra callout variant ---- */
.callout--gold{background:var(--gold-pale);border-color:var(--gold);color:var(--indigo-dark)}
.callout--gold a{color:var(--indigo-dark);text-decoration:underline;font-weight:600}
