:root{
  --bg: #fbfaf8;
  --surface: #ffffff;
  --text: #1d1b18;
  --muted: #5a554f;
  --border: rgba(29,27,24,.12);
  --shadow: 0 14px 40px rgba(20, 18, 16, .10);
  --shadow-soft: 0 10px 24px rgba(20, 18, 16, .08);

  --brand: #2b5a56;      /* deep teal */
  --brand-2: #b06b3e;    /* warm terracotta */
  --accent: #d6b24c;     /* muted gold */
  --focus: #1a73e8;

  --radius: 18px;
  --radius-sm: 12px;
  --container: 1120px;

  --font-body: "Inter", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  --font-head: "Playfair Display", Georgia, "Times New Roman", serif;
}

*{box-sizing:border-box}
html{color-scheme: light}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--text);
  background:
    radial-gradient(1200px 500px at 10% -10%, rgba(214,178,76,.20), transparent 55%),
    radial-gradient(900px 400px at 90% 0%, rgba(43,90,86,.18), transparent 55%),
    var(--bg);
  line-height:1.65;
}
img{max-width:100%; height:auto; display:block}
a{color:inherit}

.container{
  width:min(var(--container), 92vw);
  margin-inline:auto;
}

.skip-link{
  position:absolute;
  left:-999px;
  top:auto;
  width:1px;height:1px;
  overflow:hidden;
}
.skip-link:focus{
  left:16px; top:16px;
  width:auto; height:auto;
  padding:10px 12px;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:12px;
  z-index:9999;
  outline:3px solid rgba(26,115,232,.25);
}

/* Header */
.site-header{
  position:sticky;
  top:0;
  z-index:50;
  backdrop-filter:saturate(150%) blur(12px);
  background:rgba(251,250,248,.72);
  border-bottom:1px solid var(--border);
}
.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:14px 0;
}
.brand{
  display:flex;
  align-items:center;
  gap:10px;
  text-decoration:none;
}
.brand-mark{
  width:38px;height:38px;
  border-radius:14px;
  background:linear-gradient(135deg, rgba(43,90,86,1), rgba(176,107,62,1));
  box-shadow:0 10px 20px rgba(43,90,86,.18);
  position:relative;
}
.brand-mark:before{
  content:"";
  position:absolute;
  inset:9px;
  border-radius:10px;
  border:1px solid rgba(255,255,255,.55);
}
.brand-title{
  font-family:var(--font-head);
  font-weight:700;
  letter-spacing:.2px;
  line-height:1.05;
  font-size:1.18rem;
}
.brand-sub{
  display:block;
  font-size:.78rem;
  color:var(--muted);
  letter-spacing:.2px;
  margin-top:2px;
}

.nav{
  display:flex;
  align-items:center;
  gap:16px;
}
.nav a{
  text-decoration:none;
  color:var(--muted);
  font-weight:600;
  padding:10px 10px;
  border-radius:12px;
}
.nav a:hover{color:var(--text); background:rgba(43,90,86,.06)}
.nav a[aria-current="page"]{color:var(--text); background:rgba(214,178,76,.16)}

.header-actions{
  display:flex;
  align-items:center;
  gap:10px;
}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  text-decoration:none;
  border:1px solid var(--border);
  background:var(--surface);
  color:var(--text);
  border-radius:999px;
  padding:10px 14px;
  box-shadow:0 6px 16px rgba(20,18,16,.06);
  font-weight:700;
}
.btn:hover{box-shadow:var(--shadow-soft)}
.btn-primary{
  background:linear-gradient(135deg, rgba(43,90,86,1), rgba(43,90,86,.90));
  color:#fff;
  border-color:rgba(43,90,86,.35);
}
.btn-primary:hover{filter:saturate(1.02) brightness(1.02)}

.burger{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:44px; height:44px;
  border-radius:14px;
  border:1px solid var(--border);
  background:var(--surface);
  box-shadow:0 6px 16px rgba(20,18,16,.06);
}
.burger svg{width:20px;height:20px}

/* Mobile nav panel */
.nav-panel{
  display:none;
  padding:0 0 14px 0;
}
.nav-panel.open{display:block}
.nav-panel .nav{
  flex-direction:column;
  align-items:stretch;
  gap:6px;
}
.nav-panel .nav a{
  padding:12px 12px;
  background:rgba(255,255,255,.65);
  border:1px solid var(--border);
}

@media (min-width: 880px){
  .burger{display:none}
  .nav-panel{display:none !important}
}
@media (max-width: 879.98px){
  .nav{display:none}
}

/* Hero */
.hero{
  padding:26px 0 14px;
}
.hero-card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  overflow:hidden;
}
.hero-grid{
  display:grid;
  grid-template-columns:1fr;
}
.hero-media{
  min-height:220px;
}
.hero-media img{
  width:100%;
  height:100%;
  object-fit:cover;
  aspect-ratio: 16 / 10;
}
.hero-body{
  padding:18px 18px 20px;
}
.kicker{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  align-items:center;
  color:var(--muted);
  font-weight:700;
  font-size:.9rem;
}
.tag{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid var(--border);
  background:rgba(214,178,76,.14);
  color:rgba(29,27,24,.92);
}
.date{
  font-weight:700;
  color:var(--muted);
}
.hero-title{
  font-family:var(--font-head);
  font-weight:800;
  letter-spacing:.2px;
  line-height:1.1;
  margin:10px 0 10px;
  font-size:2.0rem;
}
.lead{
  margin:0 0 14px;
  color:var(--muted);
  font-size:1.02rem;
}

@media (min-width: 880px){
  .hero{padding:34px 0 18px}
  .hero-grid{
    grid-template-columns: 1.15fr .85fr;
  }
  .hero-body{padding:26px 26px 28px}
  .hero-title{font-size:2.4rem}
  .hero-media img{aspect-ratio: 16 / 12}
}

/* Main layout */
.layout{
  display:grid;
  grid-template-columns:1fr;
  gap:16px;
  padding:14px 0 34px;
}
.panel{
  background:rgba(255,255,255,.66);
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:0 10px 26px rgba(20,18,16,.06);
}
.panel-inner{padding:16px}

.section-title{
  font-family:var(--font-head);
  font-weight:800;
  margin:0 0 12px;
  letter-spacing:.2px;
}
.section-sub{
  margin:0 0 14px;
  color:var(--muted);
}

.toolbar{
  display:flex;
  flex-direction:column;
  gap:10px;
  margin-bottom:12px;
}
.search{
  display:flex;
  gap:10px;
}
.search input{
  width:100%;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid var(--border);
  background:#fff;
  font:inherit;
}
.search input:focus{
  outline:3px solid rgba(26,115,232,.18);
  border-color:rgba(26,115,232,.45);
}
.chips{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.chip{
  border:1px solid var(--border);
  background:rgba(43,90,86,.06);
  color:var(--text);
  padding:8px 10px;
  border-radius:999px;
  font-weight:800;
  font-size:.9rem;
  cursor:pointer;
}
.chip[aria-pressed="true"]{
  background:rgba(43,90,86,.18);
  border-color:rgba(43,90,86,.34);
}

@media (min-width: 740px){
  .toolbar{flex-direction:row; align-items:center; justify-content:space-between}
  .search{max-width:420px}
}
@media (min-width: 1040px){
  .layout{
    grid-template-columns: 1.3fr .7fr;
    gap:18px;
  }
}

/* Cards grid */
.cards{
  display:grid;
  grid-template-columns: 1fr;
  gap:14px;
}
.card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:0 10px 22px rgba(20,18,16,.06);
  overflow:hidden;
  display:grid;
  grid-template-columns:1fr;
}
.card-media img{
  width:100%;
  height:100%;
  object-fit:cover;
  aspect-ratio: 16 / 10;
}
.card-body{
  padding:14px 14px 16px;
}
.card-title{
  margin:10px 0 8px;
  font-family:var(--font-head);
  font-weight:800;
  line-height:1.12;
  letter-spacing:.2px;
  font-size:1.34rem;
}
.excerpt{
  margin:0 0 12px;
  color:var(--muted);
}
.meta-row{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  align-items:center;
  margin-top:2px;
}
.card .btn{padding:10px 12px}

@media (min-width: 740px){
  .cards{grid-template-columns: repeat(2, 1fr)}
}
@media (min-width: 1040px){
  .cards{grid-template-columns: repeat(2, 1fr)}
}

/* Sidebar */
.side-block + .side-block{margin-top:12px}
.side-title{
  margin:0 0 10px;
  font-family:var(--font-head);
  font-weight:800;
  letter-spacing:.2px;
}
.list{
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  gap:10px;
}
.list a{
  display:flex;
  justify-content:space-between;
  gap:12px;
  text-decoration:none;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.78);
}
.list a:hover{box-shadow:0 10px 22px rgba(20,18,16,.06)}
.list .small{color:var(--muted); font-weight:700}

.note{
  border-radius:var(--radius);
  border:1px dashed rgba(43,90,86,.45);
  background:rgba(43,90,86,.06);
  padding:14px;
  color:rgba(29,27,24,.92);
}
.note strong{color:var(--brand)}

/* Article */
.article-hero{
  padding:18px 0 10px;
}
.article-wrap{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  overflow:hidden;
}
.article-media img{
  width:100%;
  height:100%;
  object-fit:cover;
  aspect-ratio: 16 / 9;
}
.article-head{
  padding:18px 18px 14px;
}
.article-title{
  margin:10px 0 8px;
  font-family:var(--font-head);
  font-weight:900;
  line-height:1.08;
  letter-spacing:.2px;
  font-size:2.0rem;
}
.article-meta{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  color:var(--muted);
  font-weight:800;
}
.article-body{
  padding:0 18px 18px;
}
.article-body p{margin:12px 0; color:rgba(29,27,24,.92)}
.article-body h2, .article-body h3{
  font-family:var(--font-head);
  margin:18px 0 10px;
  letter-spacing:.2px;
  line-height:1.2;
}
.article-body h2{font-size:1.55rem}
.article-body h3{font-size:1.22rem}
.article-body ul, .article-body ol{padding-left:18px}
.article-body li{margin:8px 0}
.article-body blockquote{
  margin:16px 0;
  padding:14px 14px;
  border-left:4px solid rgba(176,107,62,.75);
  background:rgba(176,107,62,.07);
  border-radius:14px;
  color:rgba(29,27,24,.92);
}
.tip{
  margin:18px 0;
  border-radius:var(--radius);
  border:1px solid rgba(214,178,76,.55);
  background:linear-gradient(135deg, rgba(214,178,76,.22), rgba(43,90,86,.08));
  padding:14px 14px;
}
.tip-title{
  font-weight:900;
  letter-spacing:.2px;
  color:rgba(29,27,24,.95);
  margin:0 0 6px;
}
.related{
  margin-top:18px;
  padding-top:14px;
  border-top:1px solid var(--border);
}
.related-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:10px;
}
.related a{
  text-decoration:none;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.82);
  display:flex;
  justify-content:space-between;
  gap:12px;
}
.related a:hover{box-shadow:0 10px 22px rgba(20,18,16,.06)}
.related .small{color:var(--muted); font-weight:800}
@media (min-width: 740px){
  .article-head{padding:24px 26px 16px}
  .article-body{padding:0 26px 26px}
  .article-title{font-size:2.5rem}
  .related-grid{grid-template-columns: repeat(3, 1fr)}
  .related a{flex-direction:column; align-items:flex-start}
}

/* Contact */
.grid-2{
  display:grid;
  grid-template-columns:1fr;
  gap:14px;
}
@media (min-width: 960px){
  .grid-2{grid-template-columns: .9fr 1.1fr}
}
.contact-card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  overflow:hidden;
}
.contact-inner{padding:18px}
.kv{
  display:grid;
  gap:10px;
  margin:12px 0 0;
}
.kv-item{
  border:1px solid var(--border);
  border-radius:14px;
  background:rgba(255,255,255,.82);
  padding:12px;
}
.kv-item span{display:block; color:var(--muted); font-weight:800; font-size:.9rem}
.kv-item a{color:var(--brand); font-weight:900; text-decoration:none}
.kv-item a:hover{text-decoration:underline}

form{
  display:grid;
  gap:10px;
  margin-top:12px;
}
label{font-weight:900}
input, textarea, select{
  width:100%;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid var(--border);
  background:#fff;
  font:inherit;
}
textarea{min-height:140px; resize:vertical}
.row-2{
  display:grid;
  grid-template-columns:1fr;
  gap:10px;
}
@media (min-width: 740px){
  .row-2{grid-template-columns:1fr 1fr}
}
.check{
  display:flex;
  gap:10px;
  align-items:flex-start;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.82);
}
.check input{width:auto; margin-top:4px}
.muted{color:var(--muted)}

.faq{
  margin-top:14px;
  display:grid;
  gap:10px;
}
.faq details{
  border:1px solid var(--border);
  border-radius:14px;
  background:rgba(255,255,255,.82);
  padding:12px 12px;
}
.faq summary{
  cursor:pointer;
  font-weight:900;
}
.faq p{margin:10px 0 0; color:rgba(29,27,24,.92)}

/* Footer */
.site-footer{
  border-top:1px solid var(--border);
  background:rgba(255,255,255,.65);
}
.footer-inner{
  padding:22px 0;
  display:grid;
  gap:12px;
}
.footer-top{
  display:grid;
  grid-template-columns:1fr;
  gap:14px;
}
.footer-about p{margin:8px 0 0; color:var(--muted)}
.footer-nav{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.footer-nav a{
  text-decoration:none;
  padding:8px 10px;
  border-radius:12px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.72);
  color:var(--muted);
  font-weight:800;
}
.footer-nav a:hover{color:var(--text)}
.social{
  display:flex;
  gap:10px;
}
.social a{
  width:44px;height:44px;
  border-radius:14px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.72);
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.social a:hover{box-shadow:0 10px 22px rgba(20,18,16,.06)}
.social svg{width:18px;height:18px; fill:rgba(29,27,24,.85)}
.footer-bottom{
  padding-top:12px;
  border-top:1px solid var(--border);
  color:var(--muted);
  font-weight:700;
  display:flex;
  flex-direction:column;
  gap:6px;
}
@media (min-width: 900px){
  .footer-top{grid-template-columns: 1.4fr 1fr 1fr; align-items:start}
  .footer-bottom{flex-direction:row; justify-content:space-between; align-items:center}
}

/* Small helpers */
.sr-only{
  position:absolute;
  width:1px;height:1px;
  padding:0;margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

.pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.72);
  color:var(--muted);
  font-weight:900;
  font-size:.9rem;
}

.divider{
  height:1px;
  background:var(--border);
  margin:12px 0;
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  *{scroll-behavior:auto !important; transition:none !important; animation:none !important}
}


