/*
Design Blueprint: Corporate “report” style + KPIs + tables + charts (SVG)
Palette Family: Earth tones (olive/beige/slate) with copper accent
Color Mode: Tinted light (ivory background) + ink text
Fonts: Fraunces (display) + Plus Jakarta Sans (text)
Signature Blocks: Sticky request rail • KPI scorecards • Scope Estimator • Filterable Case Studies
*/
:root{
  --bg:#F1E7D3; --surface:#FAF7EF; --surface-2:#FFFFFF;
  --ink:#0D1714; --muted:#2B3A35;
  --border:rgba(13,23,20,.16);
  --primary:#205A4D; --accent:#BA7740;
  --shadow:0 18px 45px rgba(13,23,20,.12);
  --shadow-sm:0 10px 25px rgba(13,23,20,.10);
  --radius:18px; --container:1160px;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:"Plus Jakarta Sans",system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--ink);
  background:
    radial-gradient(900px 300px at 20% 0%, rgba(32,90,77,.16), transparent 60%),
    radial-gradient(800px 280px at 90% 10%, rgba(186,119,64,.14), transparent 55%),
    var(--bg);
  line-height:1.55;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
a:hover{text-decoration:underline}
.container{max-width:var(--container);margin:0 auto;padding:0 22px}
.skiplink{position:absolute;left:-999px;top:auto;width:1px;height:1px;overflow:hidden}
.skiplink:focus{left:18px;top:18px;width:auto;height:auto;background:var(--surface-2);padding:10px 12px;border-radius:10px;box-shadow:var(--shadow-sm);z-index:9999}

.topbar{position:sticky;top:0;z-index:50;backdrop-filter:blur(10px);background:rgba(241,231,211,.78);border-bottom:1px solid var(--border)}
.topbar__inner{display:flex;align-items:center;gap:18px;padding:14px 0}
.brand{display:flex;align-items:center;gap:12px}
.brand__mark{width:28px;height:28px;color:var(--ink)}
.brand__name{font-family:"Fraunces",serif;letter-spacing:-.02em;font-weight:650;font-size:18px;text-transform:lowercase}
.brand__sub{display:block;font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:rgba(13,23,20,.7)}

.nav{display:none;gap:14px;margin-left:auto;align-items:center}
.nav a{padding:10px 10px;border-radius:12px;font-weight:550;font-size:14px}
.nav a.nav__muted{color:rgba(13,23,20,.72)}
.nav a.nav__cta{border:1px solid var(--border);background:rgba(250,247,239,.85)}
.nav a:hover{background:rgba(250,247,239,.9);text-decoration:none}

.topbar__actions{display:flex;align-items:center;gap:12px;margin-left:auto}
.iconbtn{display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border);background:rgba(250,247,239,.85);border-radius:12px;width:42px;height:42px;cursor:pointer}
.iconbtn:hover{transform:translateY(-1px)}
.lang{display:none;align-items:center;gap:8px;padding:8px 10px;border-radius:12px;border:1px solid var(--border);background:rgba(250,247,239,.85)}
.lang__label{font-size:12px;color:rgba(13,23,20,.7)}
.lang a{font-size:12px;font-weight:650;padding:6px 8px;border-radius:999px;border:1px solid transparent}
.lang a.is-active{border-color:rgba(13,23,20,.22);background:rgba(32,90,77,.10);text-decoration:none}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:12px 14px;border-radius:999px;border:1px solid transparent;font-weight:650;letter-spacing:.01em;cursor:pointer}
.btn--sm{padding:9px 12px;font-size:13px}
.btn--primary{background:var(--ink);color:var(--surface-2);box-shadow:var(--shadow-sm)}
.btn--primary:hover{transform:translateY(-1px);text-decoration:none}
.btn--ghost{background:rgba(250,247,239,.86);border-color:var(--border)}
.btn--ghost:hover{transform:translateY(-1px);text-decoration:none}

.mobileNav{border-top:1px solid var(--border);background:rgba(250,247,239,.92)}
.mobileNav__inner{display:grid;gap:10px;padding:14px 0}
.mobileNav a{padding:12px 12px;border-radius:14px;border:1px solid var(--border);background:rgba(255,255,255,.55)}

.stickyRail{position:sticky;top:76px;z-index:40;border-bottom:1px solid var(--border);background:rgba(250,247,239,.55);backdrop-filter:blur(10px)}
.stickyRail__inner{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:10px 0}
.stickyRail__left{display:flex;align-items:center;gap:10px}
.dot{width:6px;height:6px;border-radius:99px;background:var(--accent)}
.muted{color:rgba(13,23,20,.72)}
.stickyRail__right{display:flex;align-items:center;gap:10px}
.chip{display:inline-flex;align-items:center;padding:8px 12px;border-radius:999px;border:1px solid var(--border);background:rgba(255,255,255,.5);font-size:13px;font-weight:650}
.chip:hover{background:rgba(32,90,77,.10);text-decoration:none}

.section{padding:72px 0}
.section--tight{padding:52px 0}
.kicker{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:rgba(13,23,20,.72)}
.h1{font-family:"Fraunces",serif;font-size:54px;line-height:1.03;letter-spacing:-.03em;margin:14px 0 14px}
.h2{font-family:"Fraunces",serif;font-size:34px;line-height:1.12;letter-spacing:-.02em;margin:0 0 12px}
.h3{font-size:18px;font-weight:750;letter-spacing:-.01em;margin:0 0 10px}
.lede{font-size:18px;color:rgba(13,23,20,.82);max-width:70ch}
.grid{display:grid;gap:18px}
.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}

.card{background:rgba(250,247,239,.74);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:18px}
.card--flat{box-shadow:none;background:rgba(255,255,255,.55)}
.card__head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}
.badge{display:inline-flex;align-items:center;gap:8px;padding:7px 10px;border-radius:999px;border:1px solid var(--border);background:rgba(255,255,255,.55);font-size:12px;font-weight:700}
.hr{height:1px;background:var(--border);margin:18px 0}

.hero{padding:28px 0 0}
.hero__wrap{display:grid;gap:18px;align-items:stretch}
.hero__panel{background:rgba(250,247,239,.70);border:1px solid var(--border);border-radius:24px;padding:22px;box-shadow:var(--shadow)}
.hero__media{border-radius:24px;overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow)}
.hero__actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}
.hero__meta{display:flex;gap:12px;flex-wrap:wrap;margin-top:14px}
.stat{display:flex;flex-direction:column;gap:4px;padding:12px 14px;border-radius:16px;border:1px dashed rgba(13,23,20,.22);background:rgba(255,255,255,.5)}
.stat b{font-size:16px}
.stat span{font-size:12px;color:rgba(13,23,20,.7)}

.table{width:100%;border-collapse:separate;border-spacing:0;overflow:hidden;border-radius:18px;border:1px solid var(--border);background:rgba(255,255,255,.55)}
.table th,.table td{padding:12px 12px;border-bottom:1px solid var(--border);vertical-align:top}
.table th{text-align:left;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:rgba(13,23,20,.72)}
.table tr:last-child td{border-bottom:none}

.form{display:grid;gap:12px}
.input{display:grid;gap:6px}
.input label{font-size:13px;font-weight:700}
.input input,.input textarea,.input select{padding:12px 12px;border-radius:14px;border:1px solid var(--border);background:rgba(255,255,255,.75);font-family:inherit;font-size:14px}
.help{font-size:12px;color:rgba(13,23,20,.72)}
.notice{padding:14px 14px;border-radius:16px;border:1px solid rgba(32,90,77,.25);background:rgba(32,90,77,.10)}
.notice--warn{border-color:rgba(186,119,64,.35);background:rgba(186,119,64,.12)}
.notice--danger{border-color:rgba(172,55,55,.35);background:rgba(172,55,55,.10)}

.footer{padding:54px 0 36px;border-top:1px solid var(--border);background:rgba(250,247,239,.65)}
.footer__grid{display:grid;gap:22px}
.footer__name{font-family:"Fraunces",serif;font-size:20px;letter-spacing:-.02em;margin-top:10px}
.footer__tagline{color:rgba(13,23,20,.78);max-width:44ch}
.footer__meta{display:grid;gap:14px;margin-top:14px}
.footer__col{display:grid;gap:10px;align-content:start}
.footer__title{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:rgba(13,23,20,.72)}
.footer__social{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}
.footer__bottom{display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-top:22px}
.bullets{padding-left:18px;margin:0;display:grid;gap:8px}
.bullets li{color:rgba(13,23,20,.78)}

.cookie{position:fixed;left:0;right:0;bottom:12px;z-index:90}
.cookie__inner{display:flex;justify-content:space-between;gap:14px;align-items:center;border:1px solid var(--border);border-radius:18px;background:rgba(255,255,255,.78);padding:14px 14px;box-shadow:var(--shadow)}
.cookie__title{font-weight:800}
.cookie__desc{font-size:13px;color:rgba(13,23,20,.72);max-width:70ch}
.cookie__actions{display:flex;gap:10px;flex-wrap:wrap}

.accordion{border:1px solid var(--border);border-radius:18px;overflow:hidden;background:rgba(255,255,255,.55)}
.acc__item{border-bottom:1px solid var(--border)}
.acc__item:last-child{border-bottom:none}
.acc__btn{width:100%;text-align:left;padding:14px 14px;background:transparent;border:0;cursor:pointer;display:flex;justify-content:space-between;gap:16px;font-family:inherit}
.acc__btn b{font-size:14px}
.acc__panel{padding:0 14px 14px;display:none;color:rgba(13,23,20,.78)}
.acc__item.is-open .acc__panel{display:block}
.tabs{display:flex;gap:10px;flex-wrap:wrap;margin:16px 0}
.tab{padding:9px 12px;border-radius:999px;border:1px solid var(--border);background:rgba(255,255,255,.55);cursor:pointer;font-weight:750;font-size:13px}
.tab.is-active{background:rgba(13,23,20,.08)}

.filterbar{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}
.pill{padding:10px 12px;border-radius:999px;border:1px dashed rgba(13,23,20,.22);background:rgba(255,255,255,.4);font-weight:700;cursor:pointer}
.pill.is-active{border-style:solid;background:rgba(32,90,77,.12)}

@media (min-width:880px){
  .nav{display:flex}
  .lang{display:flex}
  .iconbtn{display:none}
  .grid-2{grid-template-columns:1.15fr .85fr}
  .grid-3{grid-template-columns:repeat(3,1fr)}
  .grid-4{grid-template-columns:repeat(4,1fr)}
  .hero__wrap{grid-template-columns:1.1fr .9fr}
  .footer__grid{grid-template-columns:1.4fr .7fr .7fr .9fr}
  .footer__meta{grid-template-columns:1fr 1fr}
}



/* CSS Patch: hero media sizing + safer sticky topbar */
.topbar__inner{padding-top:calc(14px + env(safe-area-inset-top));}

.hero__media{min-height:320px;position:relative}
.hero__media img{width:100%;height:100%;object-fit:cover;object-position:center}
@media (min-width:880px){
  .hero__media{min-height:560px}
}

