/* ==========================================================================
   58. Internationale Friedenswanderung — Šventoji–Palanga 2027
   Design tokens
   ========================================================================== */
:root{
  --cream:#F5EFE1;
  --cream-2:#EFE6D2;
  --orange:#DE7315;
  --orange-deep:#B4590E;
  --ink:#191510;
  --ink-soft:#4a4238;
  --white:#FFFFFF;
  --sand:#D9C7A2;
  --sea:#2C4552;
  --sea-deep:#1C2E37;

  --font-script: 'Caveat', cursive;
  --font-display: 'Big Shoulders', sans-serif;
  --font-body: 'Source Sans 3', system-ui, -apple-system, sans-serif;

  --radius: 6px;
  --container: 1160px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  background:var(--cream);
  color:var(--ink);
  font-family:var(--font-body);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;}
a{color:inherit;}
.wrap{max-width:var(--container); margin:0 auto; padding:0 28px;}

/* -------------------- focus / motion -------------------- */
a:focus-visible, button:focus-visible, .btn:focus-visible{
  outline:3px solid var(--orange-deep);
  outline-offset:3px;
}
@media (prefers-reduced-motion: reduce){
  *{animation-duration:0.001ms !important; animation-iteration-count:1 !important; transition-duration:0.001ms !important; scroll-behavior:auto !important;}
}

/* -------------------- i18n --------------------
   Elements are duplicated with .i18n-en / .i18n-de.
   Default (English) is shown; body.de-mode swaps them.
   display:revert restores each tag's normal display
   (block for <p>/<div>, inline-flex for flex children, etc.) */
.i18n-de{display:none !important;}
body.de-mode .i18n-en{display:none !important;}
body.de-mode .i18n-de{display:revert !important;}

/* -------------------- header -------------------- */
.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(245,239,225,0.92);
  backdrop-filter:blur(6px);
  border-bottom:1px solid rgba(25,21,16,0.08);
}
.site-header .wrap{
  display:flex; align-items:center; justify-content:space-between;
  height:76px;
}
.brand{
  display:flex; align-items:center; gap:12px;
  text-decoration:none;
  font-family:var(--font-display);
  font-weight:700;
  letter-spacing:0.02em;
  color:var(--ink);
}
.brand .mark{width:34px;height:34px;flex-shrink:0;}
.brand-text{display:flex; flex-direction:column; line-height:1.05;}
.brand-text .kicker{font-family:var(--font-body); font-size:11px; font-weight:600; letter-spacing:0.14em; text-transform:uppercase; color:var(--orange-deep);}
.brand-text .name{font-size:19px; text-transform:uppercase;}

.nav{display:flex; align-items:center; gap:28px;}
.nav-links{display:flex; gap:26px; list-style:none; margin:0; padding:0;}
.nav-links a{
  text-decoration:none;
  font-family:var(--font-display);
  font-weight:600;
  font-size:16px;
  letter-spacing:0.03em;
  text-transform:uppercase;
  color:var(--ink);
  padding:6px 2px;
  position:relative;
}
.nav-links a::after{
  content:'';
  position:absolute; left:0; bottom:-2px;
  width:0; height:2px; background:var(--orange);
  transition:width .25s ease;
}
.nav-links a:hover::after, .nav-links a[aria-current="page"]::after{width:100%;}
.nav-links a[aria-current="page"]{color:var(--orange-deep);}

.lang-toggle{
  display:flex; border:1.5px solid var(--ink); border-radius:999px; overflow:hidden;
  font-family:var(--font-display); font-weight:700; font-size:13px; letter-spacing:0.04em;
}
.lang-toggle button{
  border:none; background:transparent; color:var(--ink);
  padding:7px 14px; cursor:pointer; font-family:inherit; font-weight:inherit; font-size:inherit;
}
.lang-toggle button.active{background:var(--orange); color:var(--white);}

.nav-toggle{display:none;}

/* -------------------- buttons -------------------- */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  background:var(--orange); color:var(--white);
  font-family:var(--font-display); font-weight:700; text-transform:uppercase; letter-spacing:0.04em;
  padding:14px 28px; border-radius:999px; text-decoration:none; font-size:15px;
  border:2px solid var(--orange);
  transition:background .2s ease, color .2s ease, transform .2s ease;
}
.btn:hover{background:var(--orange-deep); border-color:var(--orange-deep); transform:translateY(-1px);}
.btn.outline{background:transparent; color:var(--white); border-color:var(--white);}
.btn.outline:hover{background:var(--white); color:var(--ink);}
.btn.dark{background:var(--ink); border-color:var(--ink);}
.btn.dark:hover{background:#000; border-color:#000;}

/* -------------------- hero -------------------- */
.hero{
  position:relative;
  min-height:88vh;
  display:flex; flex-direction:column; justify-content:flex-end;
  background:linear-gradient(180deg, rgba(20,20,18,0.25) 0%, rgba(18,18,16,0.55) 65%, rgba(12,12,10,0.75) 100%), var(--sea) url('hero-sea.jpg') center 35% / cover no-repeat;
  color:var(--white);
  overflow:hidden;
}
.hero-birds{position:absolute; top:8%; right:8%; width:120px; opacity:0.85;}
.hero-heart{
  position:absolute; top:14%; left:50%; transform:translateX(-50%);
  width:min(46vw, 460px);
  filter:drop-shadow(0 8px 30px rgba(0,0,0,0.25));
}
.hero-heart path{
  fill:none; stroke-linecap:round; stroke-width:16;
  stroke-dasharray:1600; stroke-dashoffset:1600;
  animation:draw 2.6s ease forwards;
}
.hero-heart .stroke-black{stroke:#141210; animation-delay:.1s;}
.hero-heart .stroke-orange{stroke:var(--orange); animation-delay:.5s;}
@keyframes draw{to{stroke-dashoffset:0;}}

.hero-content{position:relative; z-index:2; padding-bottom:0;}
.hero-copy{max-width:820px; padding:0 0 46px;}
.hero-script{
  font-family:var(--font-script); font-size:clamp(28px,4vw,44px); font-weight:600;
  color:var(--white); margin:0 0 4px; line-height:1;
}
.hero-script .accent{color:var(--orange);}
.hero-title{
  font-family:var(--font-display); text-transform:uppercase;
  font-weight:800; font-size:clamp(38px,7vw,84px); line-height:0.95; margin:6px 0 0;
  letter-spacing:0.01em;
}
.hero-sub{
  font-family:var(--font-display); text-transform:uppercase; font-weight:600;
  font-size:clamp(16px,2.4vw,24px); letter-spacing:0.08em; color:var(--sand); margin:10px 0 0;
}

.hero-band{
  position:relative; z-index:2;
  background:var(--orange);
  padding:26px 0 30px;
}
.hero-band::before{
  content:''; position:absolute; top:-38px; left:0; right:0; height:40px;
  background:var(--orange);
  border-radius:50% 50% 0 0 / 100% 100% 0 0;
}
.hero-band .wrap{
  display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:18px;
}
.hero-facts{display:flex; flex-wrap:wrap; gap:34px;}
.hero-fact{display:flex; align-items:center; gap:10px; color:var(--white); font-family:var(--font-display); font-weight:700; font-size:17px; letter-spacing:0.02em;}
.hero-fact svg{width:22px; height:22px; flex-shrink:0;}

/* -------------------- sections -------------------- */
section{padding:88px 0;}
.section-alt{background:var(--cream-2);}
.section-dark{background:var(--sea-deep); color:var(--cream);}
.section-photo{
  background-attachment:scroll; background-size:cover; background-position:center;
  color:var(--white); position:relative;
}
.section-photo::before{content:''; position:absolute; inset:0; background:rgba(15,18,17,0.5);}
.section-photo .wrap{position:relative; z-index:1;}

.eyebrow{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--font-script); font-size:26px; color:var(--orange-deep); margin:0 0 6px;
}
.section-dark .eyebrow, .section-photo .eyebrow{color:var(--orange);}
h2.h-title{
  font-family:var(--font-display); text-transform:uppercase; font-weight:800;
  font-size:clamp(30px,4.2vw,52px); line-height:1.02; margin:0 0 22px; letter-spacing:0.01em;
}
.lead{font-size:19px; max-width:700px; color:var(--ink-soft);}
.section-dark .lead, .section-photo .lead{color:#e7e2d4;}

.grid-2{display:grid; grid-template-columns:1.05fr 0.95fr; gap:56px; align-items:center;}
.grid-3{display:grid; grid-template-columns:repeat(3,1fr); gap:28px;}

.card{
  background:var(--white); border-radius:var(--radius); padding:30px 26px;
  border:1px solid rgba(25,21,16,0.08);
}
.card .num{font-family:var(--font-display); font-weight:800; font-size:15px; color:var(--orange-deep); letter-spacing:0.08em;}
.card h3{font-family:var(--font-display); text-transform:uppercase; font-size:22px; margin:8px 0 10px;}
.card p{margin:0; color:var(--ink-soft);}

.divider-heart{display:flex; justify-content:center; margin:6px 0 30px;}
.divider-heart svg{width:46px; height:34px;}

/* video */
.video-frame{
  position:relative; border-radius:var(--radius); overflow:hidden;
  aspect-ratio:16/9; background:#000;
  box-shadow:0 24px 60px -20px rgba(0,0,0,0.45);
  border:6px solid var(--white);
}
.video-frame iframe{position:absolute; inset:0; width:100%; height:100%; border:0;}

/* gallery */
.gallery{display:grid; grid-template-columns:1.3fr 1fr; grid-template-rows:1fr 1fr; gap:16px; height:520px;}
.gallery a{position:relative; overflow:hidden; border-radius:var(--radius); display:block;}
.gallery a:first-child{grid-row:1 / 3;}
.gallery img{width:100%; height:100%; object-fit:cover; transition:transform .5s ease;}
.gallery a:hover img{transform:scale(1.06);}

/* essentials strip */
.essentials{
  background:var(--ink); color:var(--cream);
  padding:54px 0;
}
.essentials .grid-3{gap:0;}
.essentials .item{padding:0 28px; border-left:1px solid rgba(245,239,225,0.15);}
.essentials .item:first-child{border-left:none; padding-left:0;}
.essentials .tag{font-family:var(--font-script); color:var(--orange); font-size:22px;}
.essentials .val{font-family:var(--font-display); font-weight:800; text-transform:uppercase; font-size:24px; margin-top:4px;}

/* placeholder page blocks */
.placeholder-block{
  border:2px dashed var(--sand); border-radius:var(--radius);
  padding:36px; background:var(--white);
}
.tag-pill{
  display:inline-block; background:var(--orange); color:var(--white);
  font-family:var(--font-display); font-weight:700; text-transform:uppercase; letter-spacing:0.06em;
  font-size:12px; padding:5px 12px; border-radius:999px; margin-bottom:14px;
}

/* -------------------- secondary page banner -------------------- */
.page-banner{
  position:relative; min-height:38vh; display:flex; align-items:flex-end;
  background:linear-gradient(180deg, rgba(20,20,18,0.15) 0%, rgba(18,18,16,0.6) 100%), var(--sea) center / cover no-repeat;
  color:var(--white); padding-top:60px;
}
.page-banner .wrap{padding-bottom:38px;}
.page-banner .eyebrow{color:var(--orange);}
.page-banner h1{
  font-family:var(--font-display); text-transform:uppercase; font-weight:800;
  font-size:clamp(34px,5.5vw,62px); margin:4px 0 0; line-height:1;
}

/* -------------------- footer -------------------- */
footer{background:var(--sea-deep); color:#cfd9dc; padding:60px 0 30px;}
.footer-top{display:flex; justify-content:space-between; flex-wrap:wrap; gap:40px; padding-bottom:40px; border-bottom:1px solid rgba(207,217,220,0.15);}
.footer-heart{width:54px; height:40px; margin-bottom:14px;}
.footer-brand .name{font-family:var(--font-display); text-transform:uppercase; font-weight:800; font-size:22px; color:var(--white);}
.footer-cols{display:flex; gap:60px; flex-wrap:wrap;}
.footer-col h4{font-family:var(--font-display); text-transform:uppercase; letter-spacing:0.06em; color:var(--orange); font-size:14px; margin:0 0 12px;}
.footer-col a, .footer-col p{display:block; color:#cfd9dc; text-decoration:none; margin:0 0 8px; font-size:15px;}
.footer-col a:hover{color:var(--white);}
.footer-bottom{display:flex; justify-content:space-between; flex-wrap:wrap; gap:12px; padding-top:24px; font-size:13px; color:#8fa0a5;}

/* -------------------- responsive -------------------- */
@media (max-width:900px){
  .grid-2, .grid-3{grid-template-columns:1fr;}
  .gallery{grid-template-columns:1fr 1fr; grid-template-rows:200px 200px; height:auto;}
  .gallery a:first-child{grid-row:auto; grid-column:1 / 3;}
  .essentials .grid-3 .item{border-left:none; padding:18px 0 0; border-top:1px solid rgba(245,239,225,0.15);}
  .essentials .grid-3 .item:first-child{border-top:none; padding-top:0;}
}
@media (max-width:760px){
  .nav-links{
    position:absolute; top:76px; left:0; right:0; background:var(--cream);
    flex-direction:column; gap:0; padding:8px 0; border-bottom:1px solid rgba(25,21,16,0.08);
    display:none;
  }
  .nav-links.open{display:flex;}
  .nav-links a{padding:14px 28px; width:100%;}
  .nav-toggle{
    display:inline-flex; align-items:center; justify-content:center;
    width:40px; height:40px; border:1.5px solid var(--ink); border-radius:8px; background:transparent;
    cursor:pointer;
  }
  .nav-toggle svg{width:20px;height:20px;}
  .nav{gap:14px;}
  section{padding:60px 0;}
  .hero{min-height:auto; padding-top:40px;}
  .hero-heart{position:relative; top:0; margin:0 auto 10px; width:70vw;}
  .hero-birds{display:none;}
}
