/* ================================================================
   LandWatch.ie — Design System
   Earth / Forest / Gold palette
   ================================================================ */

:root{
  --forest:#1b4332;
  --forest-dark:#0d2a1f;
  --forest-mid:#2d6a4f;
  --forest-light:#74c69d;
  --gold:#c9a227;
  --gold-dark:#a8851d;
  --gold-soft:#e9d49a;
  --terracotta:#b85c3c;
  --cream:#f5f1e8;
  --cream-light:#faf7f0;
  --stone:#d6cfbd;
  --stone-light:#e9e3d3;
  --ink:#1c2321;
  --ink-soft:#4a544f;
  --ink-muted:#6b7570;
  --white:#ffffff;
  --success:#4a7c59;
  --warn:#b85c3c;

  --radius-sm:4px;
  --radius:8px;
  --radius-lg:14px;
  --shadow:0 1px 2px rgba(28,35,33,.06),0 4px 12px rgba(28,35,33,.06);
  --shadow-lg:0 4px 12px rgba(28,35,33,.08),0 24px 48px rgba(28,35,33,.08);
  --max:1160px;

  --sans:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  --serif:'Fraunces','Georgia',serif;
}

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

h1,h2,h3,h4,h5{
  font-family:var(--serif);
  color:var(--forest-dark);
  line-height:1.2;
  font-weight:600;
  letter-spacing:-.01em;
  margin:0 0 .6em;
}
h1{font-size:clamp(2rem,4.2vw,3.2rem);font-weight:500}
h2{font-size:clamp(1.6rem,3vw,2.2rem)}
h3{font-size:clamp(1.2rem,2vw,1.45rem)}
h4{font-size:1.1rem;font-weight:600}
p{margin:0 0 1.1em}
a{color:var(--forest-mid);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(--stone);margin:2.5rem 0}

/* ---- Layout ---- */
.wrap{max-width:var(--max);margin:0 auto;padding:0 1.25rem}
.section{padding:4.5rem 0}
.section--tight{padding:3rem 0}
.section--cream{background:var(--cream)}
.section--forest{background:var(--forest-dark);color:var(--cream-light)}
.section--forest h1,.section--forest h2,.section--forest h3{color:var(--cream-light)}
.section--forest a{color:var(--gold-soft)}
.section--forest a:hover{color:var(--white)}

/* ---- Header ---- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(250,247,240,.92);
  backdrop-filter:saturate(160%) blur(10px);
  -webkit-backdrop-filter:saturate(160%) blur(10px);
  border-bottom:1px solid var(--stone);
}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;padding-top:.9rem;padding-bottom:.9rem;gap:1.25rem}
.brand{display:flex;align-items:center;gap:.6rem;font-family:var(--serif);font-size:1.25rem;font-weight:600;color:var(--forest-dark);text-decoration:none}
.brand:hover{color:var(--forest-dark)}
.brand-mark{width:32px;height:32px;border-radius:50%;background:var(--forest);display:inline-flex;align-items:center;justify-content:center;color:var(--gold);font-weight:700;font-family:var(--serif);font-size:1.05rem}
.nav{display:flex;gap:1.5rem;align-items:center;flex-wrap:wrap}
.nav a{color:var(--ink-soft);text-decoration:none;font-size:.95rem;font-weight:500}
.nav a:hover{color:var(--forest-dark)}
.nav .btn{padding:.55rem 1rem}

/* ---- Buttons ---- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  padding:.85rem 1.5rem;border-radius:var(--radius);
  font-weight:600;font-size:.95rem;
  text-decoration:none;cursor:pointer;
  border:1px solid transparent;
  transition:transform .1s,background .15s,border-color .15s,color .15s;
  font-family:var(--sans);
}
.btn:hover{transform:translateY(-1px)}
.btn--primary{background:var(--forest);color:var(--cream-light);border-color:var(--forest)}
.btn--primary:hover{background:var(--forest-dark);color:var(--white)}
.btn--gold{background:var(--gold);color:var(--forest-dark);border-color:var(--gold)}
.btn--gold:hover{background:var(--gold-dark);color:var(--forest-dark)}
.btn--ghost{background:transparent;color:var(--forest-dark);border-color:var(--forest)}
.btn--ghost:hover{background:var(--forest);color:var(--cream-light)}
.btn--sm{padding:.55rem 1rem;font-size:.85rem}

/* ---- Hero ---- */
.hero{
  padding:5rem 0 4rem;
  background:
    radial-gradient(ellipse at top right,rgba(201,162,39,.08),transparent 60%),
    radial-gradient(ellipse at bottom left,rgba(45,106,79,.06),transparent 55%),
    var(--cream-light);
  border-bottom:1px solid var(--stone);
}
.hero-grid{display:grid;grid-template-columns:1.15fr 1fr;gap:3.5rem;align-items:center}
@media(max-width:880px){.hero-grid{grid-template-columns:1fr;gap:2rem}}
.eyebrow{display:inline-block;font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-dark);font-weight:700;margin-bottom:1rem}
.hero p.lede{font-size:1.15rem;color:var(--ink-soft);max-width:36rem;margin-bottom:1.75rem}

/* ---- Alert signup form ---- */
.alert-card{
  background:var(--white);
  border:1px solid var(--stone);
  border-radius:var(--radius-lg);
  padding:2rem;
  box-shadow:var(--shadow-lg);
}
.alert-card h3{margin-top:0}
.alert-form{display:flex;flex-direction:column;gap:.9rem}
.alert-form label{font-size:.85rem;font-weight:600;color:var(--ink-soft);display:block;margin-bottom:.4rem}
.alert-form input[type=email],
.alert-form select,
.alert-form input[type=text]{
  width:100%;padding:.8rem 1rem;
  border:1px solid var(--stone);border-radius:var(--radius);
  font-family:var(--sans);font-size:1rem;background:var(--cream-light);color:var(--ink);
}
.alert-form input:focus,.alert-form select:focus{outline:2px solid var(--forest-light);outline-offset:2px;border-color:var(--forest)}
.checks{display:grid;grid-template-columns:1fr 1fr;gap:.5rem .9rem}
.check{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:var(--ink-soft)}
.check input{accent-color:var(--forest)}
.alert-form .btn{width:100%;margin-top:.3rem}
.tiny-note{font-size:.8rem;color:var(--ink-muted);margin:0}

/* ---- Grid card layouts ---- */
.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.5rem}
.card{
  background:var(--white);
  border:1px solid var(--stone);
  border-radius:var(--radius-lg);
  padding:1.6rem;
  transition:transform .15s,box-shadow .15s,border-color .15s;
}
.card:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:var(--gold-soft)}
.card h3{margin-top:0}
.card .card-label{display:inline-block;background:var(--stone-light);color:var(--forest-dark);font-size:.75rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:.25rem .6rem;border-radius:var(--radius-sm);margin-bottom:.8rem}
.card--highlight{border-color:var(--forest);box-shadow:var(--shadow)}
.card--highlight .card-label{background:var(--gold-soft);color:var(--forest-dark)}
.card p:last-child{margin-bottom:0}
.card a.card-link{display:inline-block;margin-top:.75rem;font-weight:600;font-size:.9rem;text-decoration:none;color:var(--forest-mid)}
.card a.card-link::after{content:' →';transition:transform .15s;display:inline-block}
.card a.card-link:hover::after{transform:translateX(3px)}

/* ---- Page hero (secondary) ---- */
.page-hero{
  padding:4rem 0 3rem;
  background:
    linear-gradient(180deg,rgba(27,67,50,.04),transparent),
    var(--cream-light);
  border-bottom:1px solid var(--stone);
}
.page-hero h1{margin-bottom:.6rem}
.page-hero .lede{font-size:1.1rem;color:var(--ink-soft);max-width:42rem}
.breadcrumb{font-size:.85rem;color:var(--ink-muted);margin-bottom:1rem}
.breadcrumb a{color:var(--ink-muted);text-decoration:none}
.breadcrumb a:hover{color:var(--forest-dark)}

/* ---- Prose ---- */
.prose{max-width:46rem}
.prose h2{margin-top:2.5rem}
.prose h3{margin-top:1.75rem}
.prose ul,.prose ol{padding-left:1.2rem;margin-bottom:1.25rem}
.prose li{margin-bottom:.5rem}
.prose blockquote{
  margin:1.5rem 0;padding:1rem 1.3rem;
  border-left:3px solid var(--gold);
  background:var(--cream);
  border-radius:0 var(--radius) var(--radius) 0;
  font-style:italic;color:var(--ink-soft);
}
.prose code{background:var(--stone-light);padding:.1em .35em;border-radius:var(--radius-sm);font-size:.9em}

/* ---- Comparison / data tables ---- */
.table-wrap{overflow-x:auto;border:1px solid var(--stone);border-radius:var(--radius-lg);background:var(--white)}
.data-table{width:100%;border-collapse:collapse;font-size:.95rem}
.data-table th,.data-table td{padding:.9rem 1rem;text-align:left;border-bottom:1px solid var(--stone-light)}
.data-table th{background:var(--cream);font-family:var(--serif);font-weight:600;color:var(--forest-dark);letter-spacing:.01em;font-size:.95rem}
.data-table tr:last-child td{border-bottom:none}
.data-table tr:hover td{background:var(--cream-light)}
.data-table .num{font-variant-numeric:tabular-nums;text-align:right}

/* ---- Badges / status ---- */
.badge{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .6rem;border-radius:99px;font-size:.75rem;font-weight:600;letter-spacing:.02em}
.badge--ok{background:rgba(74,124,89,.12);color:var(--success)}
.badge--hold{background:rgba(184,92,60,.12);color:var(--terracotta)}
.badge--info{background:rgba(201,162,39,.18);color:var(--gold-dark)}
.badge--neutral{background:var(--stone-light);color:var(--ink-soft)}

.status-row{display:flex;align-items:center;gap:.6rem;margin:1rem 0;font-size:.9rem;color:var(--ink-soft)}
.dot{width:8px;height:8px;border-radius:50%;display:inline-block}
.dot--ok{background:var(--success)}
.dot--hold{background:var(--terracotta)}
.dot--info{background:var(--gold-dark)}

/* ---- Review card blocks ---- */
.review-meta{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.8rem;
  margin:1.5rem 0 2rem;padding:1.25rem;
  background:var(--cream);border:1px solid var(--stone);border-radius:var(--radius-lg);
}
.review-meta .item{font-size:.9rem}
.review-meta .item-label{font-size:.75rem;color:var(--ink-muted);text-transform:uppercase;letter-spacing:.08em;font-weight:700;margin-bottom:.25rem}
.review-meta .item-value{font-weight:600;color:var(--forest-dark);font-size:1rem}

.pros-cons{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;margin:1.5rem 0}
@media(max-width:640px){.pros-cons{grid-template-columns:1fr}}
.pros,.cons{padding:1.25rem;border-radius:var(--radius-lg);border:1px solid var(--stone)}
.pros{background:rgba(74,124,89,.06)}
.cons{background:rgba(184,92,60,.06)}
.pros h4,.cons h4{margin:0 0 .7rem}
.pros ul,.cons ul{list-style:none;padding-left:0;margin:0}
.pros li,.cons li{padding-left:1.4rem;position:relative;margin-bottom:.5rem;font-size:.95rem}
.pros li::before{content:'✓';position:absolute;left:0;color:var(--success);font-weight:700}
.cons li::before{content:'–';position:absolute;left:0;color:var(--terracotta);font-weight:700}

/* ---- CTA block ---- */
.cta-block{
  background:var(--forest);color:var(--cream-light);
  border-radius:var(--radius-lg);padding:2.5rem;
  text-align:center;margin:3rem 0;
}
.cta-block h2{color:var(--cream-light)}
.cta-block p{color:rgba(245,241,232,.85);margin-bottom:1.5rem}
.cta-block .btn{background:var(--gold);color:var(--forest-dark);border-color:var(--gold)}
.cta-block .btn:hover{background:var(--gold-dark)}

/* ---- Inline alert strip ---- */
.inline-alert{
  background:linear-gradient(135deg,var(--forest),var(--forest-dark));
  color:var(--cream-light);
  border-radius:var(--radius-lg);
  padding:2rem;
  display:grid;grid-template-columns:1fr auto;gap:1.5rem;align-items:center;
  margin:2.5rem 0;
}
.inline-alert h3{color:var(--gold-soft);margin:0 0 .4rem;font-size:1.25rem}
.inline-alert p{color:rgba(245,241,232,.85);margin:0;font-size:.95rem}
.inline-alert .btn{background:var(--gold);color:var(--forest-dark);border-color:var(--gold)}
.inline-alert .btn:hover{background:var(--gold-dark)}
@media(max-width:640px){.inline-alert{grid-template-columns:1fr}}

/* ---- Stats row ---- */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1.5rem;margin:2rem 0}
.stat{text-align:center;padding:1.25rem;background:var(--cream);border-radius:var(--radius-lg);border:1px solid var(--stone)}
.stat-num{font-family:var(--serif);font-size:2.2rem;color:var(--forest-dark);font-weight:600;line-height:1}
.stat-label{font-size:.85rem;color:var(--ink-soft);margin-top:.4rem;text-transform:uppercase;letter-spacing:.06em;font-weight:600}

/* ---- Footer ---- */
.site-footer{
  background:var(--forest-dark);color:rgba(245,241,232,.75);
  padding:3.5rem 0 1.75rem;margin-top:4rem;
}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:2.5rem;margin-bottom:2.5rem}
@media(max-width:800px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:500px){.footer-grid{grid-template-columns:1fr}}
.site-footer h5{color:var(--gold-soft);font-family:var(--sans);font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;font-weight:700;margin-bottom:1rem}
.site-footer ul{list-style:none;padding:0;margin:0}
.site-footer li{margin-bottom:.55rem}
.site-footer a{color:rgba(245,241,232,.75);text-decoration:none;font-size:.9rem}
.site-footer a:hover{color:var(--gold-soft)}
.footer-brand{font-family:var(--serif);color:var(--cream-light);font-size:1.3rem;font-weight:600;margin-bottom:.75rem}
.footer-bottom{border-top:1px solid rgba(245,241,232,.12);padding-top:1.5rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;font-size:.85rem}

/* ---- Utilities ---- */
.flex{display:flex}.flex-between{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}
.mt-0{margin-top:0}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}
.mb-0{margin-bottom:0}.mb-4{margin-bottom:2rem}
.text-center{text-align:center}
.muted{color:var(--ink-muted)}
.highlight{color:var(--gold-dark);font-weight:600}

/* ---- Responsive nav ---- */
@media(max-width:720px){
  .nav{gap:.75rem;font-size:.85rem}
  .nav a:not(.btn){display:none}
  .nav .btn{padding:.5rem .85rem;font-size:.82rem}
}
