/* =========================================================
   Dimitar Tashev — Presidential Campaign
   Design system: deep green, navy, white, subtle red.
   ========================================================= */

:root{
  --green:#0B6E3F;
  --green-dark:#08512E;
  --navy:#0A1F44;
  --navy-2:#132a5a;
  --red:#C8102E;
  --white:#FFFFFF;
  --cream:#F7F5EF;
  --ink:#0E1320;
  --muted:#5b6478;
  --border:#e6e3da;
  --radius:14px;
  --shadow-sm:0 4px 14px rgba(10,31,68,.06);
  --shadow-md:0 18px 40px -18px rgba(10,31,68,.25);
  --container:1200px;
  --serif:'Playfair Display',Georgia,'Times New Roman',serif;
  --sans:'Inter','Helvetica Neue',Arial,sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--sans);
  color:var(--ink);
  background:var(--white);
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block;height:auto}
a{color:var(--navy);text-decoration:none;transition:color .2s ease}
a:hover{color:var(--green)}
:focus-visible{outline:3px solid var(--green);outline-offset:3px;border-radius:4px}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--navy);color:#fff;padding:.75rem 1rem;z-index:100}
.skip-link:focus{left:1rem;top:1rem}

h1,h2,h3,h4{font-family:var(--serif);font-weight:700;color:var(--navy);line-height:1.15;letter-spacing:-.01em;margin:0 0 .6em}
h1{font-size:clamp(2.4rem,5.2vw,4.6rem)}
h2{font-size:clamp(1.9rem,3.6vw,3rem)}
h3{font-size:clamp(1.25rem,1.8vw,1.6rem)}
p{margin:0 0 1em;color:#2a3142}

.container{max-width:var(--container);margin:0 auto;padding:0 24px}
.section{padding:96px 0}
.section--tight{padding:64px 0}
.section--cream{background:var(--cream)}
.section--navy{background:linear-gradient(160deg,var(--navy) 0%,var(--navy-2) 100%);color:#eef1f8}
.section--navy h2,.section--navy h3{color:#fff}
.section--navy p{color:#cfd6e6}

.eyebrow{
  display:inline-block;font-family:var(--sans);font-weight:600;font-size:.78rem;
  letter-spacing:.18em;text-transform:uppercase;color:var(--green);
  padding:.4rem .8rem;border:1px solid rgba(11,110,63,.25);border-radius:999px;margin-bottom:1rem;
}
.section--navy .eyebrow{color:#aef0ce;border-color:rgba(174,240,206,.3)}

/* ===== Header ===== */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.85);
  backdrop-filter:saturate(140%) blur(12px);
  -webkit-backdrop-filter:saturate(140%) blur(12px);
  border-bottom:1px solid var(--border);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{display:flex;align-items:center;gap:.7rem;font-family:var(--serif);font-weight:700;color:var(--navy);font-size:1.15rem}
.brand-mark{
  width:38px;height:38px;border-radius:10px;display:grid;place-items:center;color:#fff;font-weight:800;
  background:linear-gradient(180deg,var(--white) 0 33%,var(--green) 33% 66%,var(--red) 66% 100%);
  border:1px solid var(--border);font-family:var(--sans);font-size:.95rem;letter-spacing:.02em;
}
.brand-mark span{background:rgba(10,31,68,.85);padding:2px 6px;border-radius:6px;color:#fff;font-size:.75rem}
.nav-links{display:flex;align-items:center;gap:1.5rem}
.nav-links a{font-weight:500;font-size:.95rem;color:#26314a}
.nav-links a.active,.nav-links a:hover{color:var(--green)}
.nav-cta{display:flex;align-items:center;gap:.6rem}
.lang-toggle{
  border:1px solid var(--border);background:#fff;border-radius:999px;
  padding:.35rem .8rem;font-size:.78rem;font-weight:600;cursor:pointer;color:var(--navy);
}
.lang-toggle:hover{border-color:var(--navy)}
.menu-btn{display:none;background:none;border:0;font-size:1.5rem;cursor:pointer;color:var(--navy)}

@media (max-width:900px){
  .menu-btn{display:block}
  .nav-links{
    position:fixed;inset:74px 0 auto 0;background:#fff;flex-direction:column;
    padding:1.2rem 1.5rem 2rem;border-bottom:1px solid var(--border);gap:1rem;
    transform:translateY(-110%);transition:transform .25s ease;
  }
  .nav-links.open{transform:translateY(0)}
  .nav-links a{font-size:1.05rem;width:100%;padding:.5rem 0;border-bottom:1px solid var(--border)}
}

/* ===== Buttons ===== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-family:var(--sans);font-weight:600;font-size:.98rem;
  padding:.95rem 1.6rem;border-radius:999px;border:1px solid transparent;cursor:pointer;
  transition:transform .15s ease,box-shadow .2s ease,background .2s ease,color .2s ease;
}
.btn-primary{background:var(--green);color:#fff;box-shadow:var(--shadow-sm)}
.btn-primary:hover{background:var(--green-dark);color:#fff;transform:translateY(-1px);box-shadow:var(--shadow-md)}
.btn-secondary{background:#fff;color:var(--navy);border-color:var(--border)}
.btn-secondary:hover{border-color:var(--navy);color:var(--navy)}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.45)}
.btn-ghost:hover{background:rgba(255,255,255,.1);color:#fff}
.btn-red{background:var(--red);color:#fff}
.btn-red:hover{background:#a30c25;color:#fff;transform:translateY(-1px)}

/* ===== Hero ===== */
.hero{
  position:relative;overflow:hidden;
  background:radial-gradient(1200px 600px at 80% 0%,rgba(11,110,63,.08),transparent 60%),
             linear-gradient(180deg,#fff 0%,var(--cream) 100%);
  padding:80px 0 100px;
}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:center}
.hero-flag-bar{display:flex;gap:.4rem;margin-bottom:1.5rem}
.hero-flag-bar span{width:34px;height:5px;border-radius:3px}
.hero-flag-bar span:nth-child(1){background:#fff;border:1px solid var(--border)}
.hero-flag-bar span:nth-child(2){background:var(--green)}
.hero-flag-bar span:nth-child(3){background:var(--red)}
.hero h1{font-size:clamp(2.6rem,5.6vw,5rem);margin-bottom:1rem}
.hero h1 em{font-style:normal;color:var(--green);background:linear-gradient(transparent 70%,rgba(11,110,63,.12) 70%)}
.hero .lede{font-size:1.2rem;color:#3a4258;max-width:560px;margin-bottom:2rem}
.hero-ctas{display:flex;gap:.8rem;flex-wrap:wrap;margin-bottom:2.4rem}
.hero-stats{display:flex;gap:2.5rem;flex-wrap:wrap}
.hero-stats .stat strong{display:block;font-family:var(--serif);font-size:1.8rem;color:var(--navy);line-height:1}
.hero-stats .stat span{font-size:.82rem;color:var(--muted);letter-spacing:.04em;text-transform:uppercase;font-weight:600}

.hero-portrait{position:relative}
.hero-portrait img{
  width:100%;border-radius:18px;box-shadow:0 40px 80px -30px rgba(10,31,68,.45);
  aspect-ratio:4/5;object-fit:cover;
}
.hero-portrait::before{
  content:"";position:absolute;inset:-18px -18px auto auto;width:60%;height:60%;
  background:linear-gradient(180deg,var(--green) 0 50%,var(--red) 50% 100%);
  border-radius:18px;z-index:-1;opacity:.18;
}
.hero-badge{
  position:absolute;left:-20px;bottom:30px;background:#fff;border:1px solid var(--border);
  padding:1rem 1.2rem;border-radius:14px;box-shadow:var(--shadow-md);max-width:240px;
}
.hero-badge strong{font-family:var(--serif);color:var(--navy);display:block;font-size:1.05rem}
.hero-badge span{font-size:.85rem;color:var(--muted)}

@media (max-width:900px){
  .hero{padding:48px 0 64px}
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .hero-badge{position:static;margin-top:1rem;max-width:none}
}

/* ===== Section heads ===== */
.section-head{max-width:760px;margin:0 auto 56px;text-align:center}
.section-head.left{margin-left:0;text-align:left}
.section-head p{color:var(--muted);font-size:1.1rem}

/* ===== About preview ===== */
.about-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:64px;align-items:center}
.about-grid img{border-radius:18px;box-shadow:var(--shadow-md);aspect-ratio:4/5;object-fit:cover}
.about-grid ul{list-style:none;padding:0;margin:1.5rem 0 2rem;display:grid;gap:.7rem}
.about-grid li{padding-left:1.7rem;position:relative;color:#2a3142}
.about-grid li::before{content:"";position:absolute;left:0;top:.55em;width:14px;height:14px;border-radius:50%;background:var(--green);box-shadow:0 0 0 4px rgba(11,110,63,.15)}
@media (max-width:900px){.about-grid{grid-template-columns:1fr;gap:32px}}

/* ===== Vision pillars ===== */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.pillar{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:32px;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;
}
.pillar:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:transparent}
.pillar .icon{
  width:52px;height:52px;border-radius:12px;background:rgba(11,110,63,.1);color:var(--green);
  display:grid;place-items:center;margin-bottom:1.2rem;font-size:1.6rem;
}
.pillar h3{margin-bottom:.5rem}
.pillar p{color:var(--muted);margin:0}
@media (max-width:900px){.pillars{grid-template-columns:1fr 1fr}}
@media (max-width:600px){.pillars{grid-template-columns:1fr}}

/* ===== Why Bulgaria Matters ===== */
.why-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:64px;align-items:center}
.why-stats{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:1.5rem}
.why-stats .stat{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:12px;padding:18px}
.why-stats .stat strong{display:block;font-family:var(--serif);color:#fff;font-size:1.7rem;line-height:1.1}
.why-stats .stat span{font-size:.85rem;color:#cfd6e6}
.map-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.12);border-radius:18px;padding:24px}
.map-card svg{width:100%;height:auto}
@media (max-width:900px){.why-grid{grid-template-columns:1fr;gap:32px}}

/* ===== Priorities ===== */
.priorities{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;counter-reset:p}
.priority{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:28px;position:relative;counter-increment:p}
.priority::before{content:"0" counter(p);position:absolute;top:18px;right:22px;font-family:var(--serif);color:var(--green);opacity:.4;font-size:1.4rem}
.priority h3{font-size:1.2rem;margin-bottom:.4rem}
.priority p{color:var(--muted);margin:0;font-size:.95rem}
@media (max-width:900px){.priorities{grid-template-columns:1fr 1fr}}
@media (max-width:600px){.priorities{grid-template-columns:1fr}}

/* ===== News ===== */
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.news-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:transform .2s ease,box-shadow .2s ease}
.news-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.news-thumb{aspect-ratio:16/10;background:linear-gradient(135deg,var(--navy) 0%,var(--green) 100%);position:relative}
.news-thumb::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 30%,rgba(255,255,255,.12),transparent 60%)}
.news-body{padding:22px}
.news-tag{font-size:.74rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--green)}
.news-body h3{font-size:1.15rem;margin:.4rem 0 .5rem}
.news-body time{font-size:.85rem;color:var(--muted)}
@media (max-width:900px){.news-grid{grid-template-columns:1fr 1fr}}
@media (max-width:600px){.news-grid{grid-template-columns:1fr}}

/* ===== Events ===== */
.events-list{display:grid;gap:14px}
.event{display:grid;grid-template-columns:90px 1fr auto;gap:24px;align-items:center;background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:20px 24px}
.event .date{text-align:center;background:var(--cream);border-radius:10px;padding:8px}
.event .date strong{display:block;font-family:var(--serif);font-size:1.6rem;color:var(--navy);line-height:1}
.event .date span{font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted)}
.event h3{margin:0 0 .15rem;font-size:1.1rem}
.event p{margin:0;color:var(--muted);font-size:.92rem}
@media (max-width:700px){.event{grid-template-columns:80px 1fr}.event .btn{grid-column:1/-1}}

/* ===== Endorsements ===== */
.endorsements{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.quote{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:28px;position:relative}
.quote::before{content:"\201C";position:absolute;top:6px;left:18px;font-family:var(--serif);font-size:4rem;color:var(--green);opacity:.25;line-height:1}
.quote p{font-style:italic;color:#2a3142;margin:0 0 1.2rem;padding-top:.8rem}
.quote .who{font-weight:600;color:var(--navy);font-size:.95rem}
.quote .role{color:var(--muted);font-size:.85rem}
@media (max-width:900px){.endorsements{grid-template-columns:1fr 1fr}}
@media (max-width:600px){.endorsements{grid-template-columns:1fr}}

/* ===== Forms ===== */
.form{display:grid;gap:16px;max-width:680px;margin:0 auto}
.form.wide{max-width:none}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media (max-width:600px){.form-row{grid-template-columns:1fr}}
.field{display:flex;flex-direction:column;gap:.4rem}
.field label{font-size:.88rem;font-weight:600;color:var(--navy)}
.field input,.field select,.field textarea{
  font:inherit;color:var(--ink);background:#fff;border:1px solid var(--border);border-radius:10px;
  padding:.85rem 1rem;transition:border-color .15s ease,box-shadow .15s ease;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 4px rgba(11,110,63,.15)}
.field textarea{min-height:140px;resize:vertical}
.field .err{display:none;color:var(--red);font-size:.82rem}
.field.invalid .err{display:block}
.field.invalid input,.field.invalid textarea,.field.invalid select{border-color:var(--red)}
.checkbox{display:flex;gap:.6rem;align-items:flex-start;font-size:.95rem;color:#2a3142}
.checkbox input{width:18px;height:18px;margin-top:3px;accent-color:var(--green)}
.honey{position:absolute;left:-9999px;opacity:0;pointer-events:none}
.form-note{font-size:.85rem;color:var(--muted)}
.form-status{padding:14px 16px;border-radius:10px;display:none}
.form-status.ok{display:block;background:rgba(11,110,63,.1);color:var(--green-dark);border:1px solid rgba(11,110,63,.25)}
.form-status.err{display:block;background:rgba(200,16,46,.08);color:#8b0a1f;border:1px solid rgba(200,16,46,.25)}

/* ===== Donate ===== */
.donate-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.donate-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:32px}
.donate-card h3{margin-bottom:.5rem}
.amount-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin:1rem 0}
.amount-grid button{
  background:#fff;border:1px solid var(--border);border-radius:10px;padding:.7rem 0;
  font-weight:700;color:var(--navy);cursor:pointer;transition:all .15s ease;
}
.amount-grid button:hover,.amount-grid button.active{border-color:var(--green);background:rgba(11,110,63,.06);color:var(--green-dark)}
@media (max-width:700px){.donate-grid{grid-template-columns:1fr}.amount-grid{grid-template-columns:repeat(2,1fr)}}

/* ===== CTA strip ===== */
.cta-strip{
  background:linear-gradient(120deg,var(--green) 0%,var(--green-dark) 100%);
  color:#fff;padding:64px 0;text-align:center;
}
.cta-strip h2{color:#fff;margin-bottom:.5rem}
.cta-strip p{color:rgba(255,255,255,.9);max-width:620px;margin:0 auto 1.6rem}
.cta-strip .btn-secondary{background:#fff;color:var(--green-dark);border-color:#fff}

/* ===== Footer ===== */
.site-footer{background:var(--navy);color:#cfd6e6;padding:64px 0 24px;font-size:.92rem}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:32px}
.footer-grid h4{color:#fff;font-family:var(--sans);font-size:.85rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:1rem}
.footer-grid a{color:#cfd6e6;display:block;padding:.25rem 0}
.footer-grid a:hover{color:#fff}
.newsletter{display:flex;gap:8px;margin-top:.5rem}
.newsletter input{flex:1;padding:.7rem .9rem;border-radius:8px;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.05);color:#fff}
.newsletter input::placeholder{color:#9aa6c2}
.newsletter button{background:var(--green);color:#fff;border:0;padding:.7rem 1rem;border-radius:8px;font-weight:600;cursor:pointer}
.social{display:flex;gap:10px;margin-top:.8rem}
.social a{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.08);display:grid;place-items:center;color:#fff;padding:0}
.social a:hover{background:var(--green)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:48px;padding-top:20px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;color:#9aa6c2;font-size:.85rem}
@media (max-width:900px){.footer-grid{grid-template-columns:1fr 1fr}}
@media (max-width:600px){.footer-grid{grid-template-columns:1fr}}

/* ===== Reveal animation ===== */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  *{animation:none!important;transition:none!important}
}

/* ===== Page hero (sub-pages) ===== */
.page-hero{background:linear-gradient(160deg,var(--navy) 0%,var(--navy-2) 100%);color:#fff;padding:80px 0 64px}
.page-hero .eyebrow{color:#aef0ce;border-color:rgba(174,240,206,.3)}
.page-hero h1{color:#fff;max-width:780px}
.page-hero p{color:#cfd6e6;max-width:680px;font-size:1.15rem}

/* ===== Prose ===== */
.prose{max-width:780px;margin:0 auto}
.prose h2{margin-top:2rem}
.prose h3{margin-top:1.5rem;color:var(--green-dark)}
.prose ul{padding-left:1.2rem}
.prose li{margin-bottom:.4rem}
