/* ================================================
   headlinesstream.com — Editorial, modern UI (No JS)
   v3: Enhanced fonts & hover/hero interactions
   ================================================ */

/* TOKENS */
:root{
  /* Colors */
  --bg: #ffffff;
  --ink: #071b12;
  --muted: #345042;
  --accent: #0d6e41;      /* dark green */
  --accent-2: #e6f6ee;    /* light green tint */
  --line: #e2ebe6;        /* soft border */
  --panel: #f7fbf8;       /* panel surface */
  --footer: #0e1a14;
  /* Type */
  --sans: 'Inter', system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, 'Apple Color Emoji','Segoe UI Emoji';
  --serif: 'Playfair Display', Georgia, 'Times New Roman', serif;
  /* Radii & shadows */
  --r-lg: 20px;
  --r-md: 12px;
  --shadow-1: 0 8px 24px rgba(7,27,18,.07);
  --shadow-2: 0 18px 60px rgba(7,27,18,.10);
  /* Layout */
  --container: 1160px;
  --gutter: clamp(1rem, 2.6vw, 2rem);
  /* Space scale */
  --s1:.25rem; --s2:.5rem; --s3:.75rem; --s4:1rem; --s5:1.5rem;
  --s6:2rem; --s7:3rem; --s8:4.5rem; --s9:6rem;
  /* Focus */
  --focus: 0 0 0 3px #c6f6d5, 0 0 0 6px rgba(13,110,65,.35);
  /* Motion */
  --t-fast: .18s;
  --t-med: .28s;
}

/* Base */
*{box-sizing:border-box}
html:focus-within{scroll-behavior:smooth}
body{
  margin:0;background:var(--bg);color:var(--ink);
  font-family:var(--sans);line-height:1.66;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  font-feature-settings:"liga","kern","ss01";
  font-kerning:normal;font-optical-sizing:auto;
}
img{max-width:100%;height:auto;display:block}
.container{max-width:var(--container);margin-inline:auto;padding-inline:var(--gutter)}
a{color:var(--accent);text-underline-offset:3px}
:focus-visible{outline:none;box-shadow:var(--focus);border-radius:10px}
.skip-link{position:absolute;left:50%;transform:translateX(-50%);top:-100%;background:#fff;border:2px solid var(--accent);padding:.5rem .75rem;border-radius:10px;box-shadow:var(--shadow-1)}
.skip-link:focus{top:.75rem}

/* Header */
.site-header{position:sticky;top:0;z-index:40;background:rgba(255,255,255,.95);backdrop-filter:saturate(130%) blur(8px);border-bottom:1px solid var(--line)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:var(--s5);min-height:72px}
.brand{display:flex;align-items:center;gap:.65rem;font-weight:700;text-decoration:none;color:inherit}
.brand-wordmark{font-family:var(--serif);font-size:1.22rem;letter-spacing:.15px}
.site-nav ul{display:flex;gap:clamp(.6rem,2vw,1.1rem);list-style:none;padding:0;margin:0}
.site-nav a{position:relative;display:inline-block;padding:.5rem .6rem;border-radius:12px;text-decoration:none;color:inherit;transition:background var(--t-fast) ease, transform var(--t-fast) ease}
.site-nav a[aria-current="page"]{background:var(--panel);}
.site-nav a::after{content:"";position:absolute;left:.6rem;right:.6rem;bottom:.35rem;height:2px;background:linear-gradient(90deg,var(--accent),transparent);transform:scaleX(0);transform-origin:left;transition:transform var(--t-fast) ease}
.site-nav a:hover{transform:translateY(-1px)}
.site-nav a:hover::after{transform:scaleX(1)}

/* Typography */
.hdg{
  font-family:var(--serif);font-weight:700;line-height:1.12;
  font-size:clamp(2rem,3.4vw,2.6rem);margin:0 0 var(--s4);
  text-wrap:balance;
}
.dek{color:var(--muted);font-size:clamp(1.06rem,1.5vw,1.2rem);margin:0 0 var(--s5)}
.dek.max{max-width:72ch}

/* Sections */
.section{padding-block:clamp(var(--s7), 8vw, var(--s9))}

/* HERO */
.hero{position:relative;overflow:hidden;border-bottom:1px solid var(--line);}
.hero .hero-surface{
  position:absolute;inset:0;
  background:
    linear-gradient(120deg, rgba(13,110,65,.06), transparent 40%),
    radial-gradient(1000px 350px at 90% -30%, rgba(13,110,65,.10), transparent 60%);
}
.ring{position:absolute;border-radius:999px;border:1px solid rgba(13,110,65,.22);filter:drop-shadow(0 8px 20px rgba(13,110,65,.08));animation:float var(--t-med) ease-in-out infinite alternate}
.ring-a{width:420px;height:420px;right:-140px;top:-120px;animation-duration:6s}
.ring-b{width:260px;height:260px;left:-80px;bottom:-80px;animation-duration:7.5s}
.ring-c{width:160px;height:160px;right:120px;bottom:-40px;animation-duration:5.5s}
@keyframes float{to{transform:translateY(6px)}}

.hero-grid{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:var(--s8);align-items:center}
@media (max-width: 980px){.hero-grid{grid-template-columns:1fr;gap:var(--s6)}}
.badge{display:inline-block;font:600 .85rem var(--sans);letter-spacing:.35px;text-transform:uppercase;color:var(--accent);background:var(--accent-2);padding:.45rem .7rem;border-radius:999px;border:1px solid #d8efe3}
.hero-copy h1{
  font-family:var(--serif);font-weight:780;font-variation-settings:"opsz" 36;
  font-size:clamp(2.6rem,5.6vw,3.8rem);line-height:1.04;margin:.6rem 0 var(--s4);
}
.hero-copy h1 em{font-style:italic;text-decoration:underline;text-decoration-thickness:3px;text-underline-offset:6px}
.text-gradient{
  background:linear-gradient(90deg,#0d6e41,#0b5a36);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.cta-row{display:flex;gap:.9rem;flex-wrap:wrap;margin-block:var(--s5)}
.btn{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:.55rem;padding:.9rem 1.15rem;border-radius:999px;border:1px solid var(--line);font-weight:650;text-decoration:none;color:inherit;transition:transform var(--t-fast) ease, box-shadow var(--t-med) ease, background var(--t-fast) ease}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--accent);color:#fff;border-color:transparent;box-shadow:var(--shadow-1)}
.btn-primary:hover{box-shadow:var(--shadow-2);transform:translateY(-1px)}
.btn-ghost{background:transparent}
.btn-ghost:hover{background:var(--panel);transform:translateY(-1px)}
/* Shine effect (CSS only) */
.btn-shine span{position:relative;z-index:2}
.btn-shine::before{
  content:"";position:absolute;inset:-1px;border-radius:inherit;background:linear-gradient(120deg, rgba(255,255,255,.0) 30%, rgba(255,255,255,.35) 50%, rgba(255,255,255,.0) 70%);
  transform:translateX(-120%);transition:transform .8s ease;
}
.btn-shine:hover::before{transform:translateX(120%);}

.quick-stats{display:flex;gap:1rem;flex-wrap:wrap;padding:0;margin:var(--s4) 0 0;list-style:none;color:var(--muted)}
.quick-stats strong{font-family:var(--serif);font-size:1.25rem;color:var(--ink)}

.hero-cover .cover-card{
  border-radius:var(--r-lg);
  background:
    linear-gradient(#fff,#fff) padding-box,
    linear-gradient(120deg, rgba(13,110,65,.25), rgba(13,110,65,0)) border-box;
  border:1px solid transparent;
  padding:var(--s6);
  box-shadow:var(--shadow-2);
}
.cover-meta{display:flex;gap:.5rem;flex-wrap:wrap;margin:0 0 var(--s5)}
.cover-meta span{padding:.35rem .6rem;border-radius:999px;background:var(--panel);border:1px solid var(--line);font-weight:600;color:#2f453a}
.cover-graph{display:grid;grid-template-columns:repeat(5,1fr);gap:.5rem;height:140px;align-items:end}
.cover-graph i{display:block;height:var(--h);background:linear-gradient(180deg,#0d6e41,#0b5a36);border-radius:8px;box-shadow:0 6px 16px rgba(13,110,65,.18)}
.cover-note{color:var(--muted);margin:var(--s4) 0 0}

/* Trust bar */
.trust{padding-block:var(--s6);background:var(--panel);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.trust-inner{display:flex;align-items:center;justify-content:space-between;gap:var(--s5);flex-wrap:wrap}
.trust-kicker{font-weight:650;color:var(--muted);text-transform:uppercase;font-size:.85rem;letter-spacing:.35px}
.trust-logos{display:flex;gap:1rem;list-style:none;margin:0;padding:0;flex-wrap:wrap}
.trust-logos li{padding:.7rem 1rem;border:1px dashed var(--line);border-radius:999px;background:#fff;color:#2f453a;font-weight:650;transition:transform var(--t-fast) ease}
.trust-logos li:hover{transform:translateY(-2px)}

/* Features */
.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s6)}
@media (max-width: 1000px){.feature-grid{grid-template-columns:1fr}}
.feature{
  background:linear-gradient(#fff,#fff) padding-box, radial-gradient(120% 100% at 0% 0%, rgba(13,110,65,.12), transparent 60%) border-box;
  border:1px solid var(--line);border-radius:var(--r-lg);padding:var(--s6);box-shadow:var(--shadow-1);
  transition:transform var(--t-fast) ease, box-shadow var(--t-med) ease, border-color var(--t-fast) ease;
}
.feature:hover{transform:translateY(-3px);box-shadow:var(--shadow-2);border-color:#cfe8db}
.feature-icon{width:46px;height:46px;border-radius:12px;background:var(--accent-2);display:grid;place-items:center;margin-bottom:.85rem;color:var(--accent);border:1px solid #d8efe3}
.feature-icon svg{width:24px;height:24px}
.link{font-weight:650;text-decoration:none;border-bottom:2px solid currentColor;padding-bottom:2px;transition:color var(--t-fast) ease}
.link:hover{color:#083b23}

/* Services page */
.service-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s6)}
@media (max-width: 1000px){.service-grid{grid-template-columns:1fr}}
.service{border:1px solid var(--line);border-radius:var(--r-lg);padding:var(--s6);background:#fff;transition:transform var(--t-fast) ease, box-shadow var(--t-med) ease, border-color var(--t-fast) ease}
.service h2{margin:0 0 .25rem;font-family:var(--serif);font-size:1.42rem}
.service p{color:var(--muted)}
.service ul{margin:var(--s4) 0 0;padding-left:1rem}
.hover-pop:hover{transform:translateY(-3px);box-shadow:var(--shadow-2);border-color:#cfe8db}

/* Cases */
.case-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s6)}
@media (max-width: 1000px){.case-grid{grid-template-columns:1fr}}
.case{border:1px solid var(--line);border-radius:var(--r-lg);padding:var(--s6);background:conic-gradient(from 180deg at 0% 0%, rgba(13,110,65,.06), #fff 30%)}
.case .muted{color:var(--muted);margin:-.25rem 0 .5rem}
.metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin:.75rem 0 0}
.metrics dt{font-weight:650;color:var(--muted)}
.metrics dd{margin:0;font-weight:780}

/* Contact */
.contact-grid{display:grid;grid-template-columns:1fr .9fr;gap:var(--s6);align-items:start}
@media (max-width: 980px){.contact-grid{grid-template-columns:1fr}}
.contact-form{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:var(--s6);box-shadow:var(--shadow-1)}
.form-row{display:grid;gap:.45rem;margin-bottom:var(--s4)}
label{font-weight:650}
input, textarea{border:1px solid var(--line);border-radius:12px;padding:.9rem 1rem;font:inherit;background:#fff;color:inherit;transition:border-color var(--t-fast) ease, box-shadow var(--t-fast) ease}
input:hover, textarea:hover{border-color:#d3e7db}
input:focus-visible, textarea:focus-visible{box-shadow:var(--focus)}
.fine-print{font-size:.9rem;color:var(--muted)}
.contact-details{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:var(--s6);box-shadow:var(--shadow-1)}
.map-wrap{margin-top:var(--s5);border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden}
.map-wrap iframe{display:block;width:100%;height:400px;border:0}

/* Footer */
.site-footer{color:#dbe7e1;background:var(--footer);margin-top:var(--s8)}
.footer-top{border-top:4px solid var(--accent);padding-block:var(--s6)}
.footer-grid{display:grid;grid-template-columns:1.2fr .8fr .8fr;gap:var(--s6);align-items:start}
@media (max-width: 800px){.footer-grid{display:grid;grid-template-columns:1.2fr .8fr .8fr;gap:var(--s6);align-items:start}}
.brand--footer .brand-wordmark{color:#eaf5f0}
.footer-tagline{margin:.5rem 0 0;color:#a9c0b6}
.footer-nav{display:flex;gap:1rem;list-style:none;margin:0;padding:0;flex-wrap:wrap}
.footer-nav a{color:#cfe1d9}
.footer-bottom{border-top:1px solid #1f2a24}
.footer-bottom-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding-block:1rem;color:#a9c0b6}
.footer-bottom-inner a{color:#eaf5f0}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  *{animation:none!important;transition:none!important}
}



/* --- Footer Refresh --- */
.site-footer{color:#dbe7e1;background:var(--footer);margin-top:var(--s8)}
.footer-top{border-top:4px solid var(--accent);padding-block:var(--s7)}
.footer-nav a{color:#dbe7e1;text-decoration:none}
.footer-nav a:hover{opacity:.9;text-decoration:underline}
.footer-contact p{margin:.35rem 0 0 0}
.footer-contact p:first-child{margin-top:.25rem}
.footer-contact a{color:#dbe7e1}
.footer-contact strong{display:block;font-size:.875rem;color:#9db3aa;font-weight:600;margin-bottom:.15rem;letter-spacing:.01em}
.footer-bottom{border-top:1px solid #183328}
.footer-bottom-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding-block:1rem;color:#9db3aa}
.footer-bottom-inner a{color:#bcd1c8}
@media (max-width: 900px){
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width: 640px){
  .footer-grid{grid-template-columns:1fr;gap:var(--s5)}
  .footer-bottom-inner{flex-direction:column;gap:.5rem;text-align:center}
}



/* --- Header / Nav polish --- */
.site-header{backdrop-filter:saturate(140%) blur(8px)}
.site-nav ul{display:flex;gap:1rem;list-style:none;margin:0;padding:0}
.site-nav a{display:inline-block;padding:.4rem .6rem;border-radius:10px;color:inherit;text-decoration:none}
.site-nav a:hover{background:rgba(255,255,255,.06);text-decoration:underline}
.site-nav a[aria-current="page"]{outline-offset:2px;box-shadow:0 0 0 2px rgba(255,255,255,.12) inset}

/* --- Buttons --- */
.btn, .button, button[type="submit"]{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.7rem 1rem;border-radius:12px;border:1px solid var(--line);
  background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(0,0,0,.06));
  color:var(--ink);text-decoration:none;cursor:pointer;
}
.btn:hover, .button:hover, button[type="submit"]:hover{
  transform:translateY(-1px);
  box-shadow:0 6px 16px rgba(0,0,0,.12);
}

/* --- Card polish (if used) --- */
.card{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:1.1rem;box-shadow:0 10px 20px rgba(0,0,0,.06)}
.card h3{margin-top:0}

.footer-contact{font-size:.95rem;line-height:1.6}


/* Hero illustration image */
.hero-illustration{max-width:520px;margin:0 auto;}
.hero-illustration img{display:block;width:100%;height:auto;border-radius:20px;box-shadow:var(--shadow-2);}
