/* ============================================================
   GermanyPromo – germanypromo.de
   Design: Informational Editorial, German market
   Fonts: Cormorant Garamond (headings) + Karla (body)
   ============================================================ */

/* === DESIGN TOKENS === */
:root {
  --green-dark:    #0A3F31;
  --green-mid:     #136A51;
  --green-light:   #E8F4F0;
  --gold:          #C8A84B;
  --gold-dark:     #A88838;
  --gold-light:    #FFF8E6;
  --bg:            #F9F8F5;
  --surface:       #FFFFFF;
  --surface-alt:   #F3F1EC;
  --text:          #191917;
  --text-muted:    #625F58;
  --border:        #E0DDD5;
  --rg-bg:         #FFFAEC;
  --rg-border:     #E8C94A;
  --radius:        8px;
  --radius-sm:     4px;
  --shadow-sm:     0 1px 4px rgba(10,63,49,.06);
  --shadow-md:     0 4px 16px rgba(10,63,49,.10);
  --transition:    .22s ease;
  --max-w:         1180px;
  --font-head:     'Cormorant Garamond', Georgia, serif;
  --font-body:     'Karla', system-ui, sans-serif;
}

/* === RESET === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}

/* === BASE === */
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.65;
  color:var(--text);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4,h5{
  font-family:var(--font-head);
  font-weight:600;
  line-height:1.2;
  color:var(--green-dark);
}
h1{font-size:clamp(2rem,4vw,3.2rem);font-weight:700}
h2{font-size:clamp(1.5rem,3vw,2.2rem)}
h3{font-size:clamp(1.1rem,2vw,1.4rem)}
h4{font-size:1.1rem}
p{margin-bottom:.9rem}
p:last-child{margin-bottom:0}

/* === LAYOUT === */
.container{width:100%;max-width:var(--max-w);margin-inline:auto;padding-inline:1.25rem}
.section{padding:3.5rem 0}
.section--alt{background:var(--surface)}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}

/* === HEADER === */
.site-header{
  background:var(--surface);
  border-bottom:1px solid var(--border);
  position:sticky;top:0;z-index:100;
  box-shadow:var(--shadow-sm);
}
.header-inner{
  display:flex;align-items:center;
  justify-content:space-between;
  padding-block:.85rem;
}
.logo{display:flex;align-items:center;gap:.6rem}
.logo-img{height:40px;width:auto}
.logo-text{
  font-family:var(--font-head);
  font-size:1.45rem;
  font-weight:700;
  color:var(--green-dark);
  letter-spacing:-.02em;
}
.logo-text span{color:var(--gold)}

.site-nav{display:flex;align-items:center;gap:2rem}
.site-nav a{
  font-size:.9rem;
  font-weight:600;
  letter-spacing:.02em;
  text-transform:uppercase;
  color:var(--text-muted);
  transition:color var(--transition);
  padding:.25rem 0;
  border-bottom:2px solid transparent;
}
.site-nav a:hover,
.site-nav a.active{color:var(--green-dark);border-bottom-color:var(--gold)}

.badge-18{
  background:var(--green-dark);
  color:#fff;
  border-radius:50%;
  width:36px;height:36px;
  display:flex;align-items:center;justify-content:center;
  font-size:.75rem;font-weight:700;
  flex-shrink:0;
}
.header-right{display:flex;align-items:center;gap:1rem}

/* Mobile menu */
.hamburger{
  display:none;flex-direction:column;gap:5px;
  padding:.4rem;border-radius:var(--radius-sm);
  transition:background var(--transition);
}
.hamburger:hover{background:var(--surface-alt)}
.hamburger span{
  width:22px;height:2px;
  background:var(--green-dark);
  transition:transform var(--transition),opacity var(--transition);
  display:block;border-radius:2px;
}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

.mobile-menu{
  display:none;
  position:absolute;top:100%;left:0;right:0;
  background:var(--surface);
  border-bottom:1px solid var(--border);
  box-shadow:var(--shadow-md);
  padding:1rem 1.25rem;
  z-index:99;
}
.mobile-menu.open{display:block}
.mobile-menu a{
  display:block;
  padding:.75rem 0;
  font-weight:600;
  font-size:.95rem;
  color:var(--text);
  border-bottom:1px solid var(--border);
}
.mobile-menu a:last-child{border-bottom:none}

/* === BREADCRUMB === */
.breadcrumb{
  padding:.75rem 0;
  font-size:.8rem;
  color:var(--text-muted);
}
.breadcrumb a{color:var(--green-mid);text-decoration:underline}
.breadcrumb span{margin-inline:.4rem;opacity:.5}

/* === HERO === */
.hero{
  background:linear-gradient(135deg,var(--green-dark) 0%,#1A5E46 100%);
  color:#fff;
  padding:5rem 0 4rem;
  position:relative;
  overflow:hidden;
}
.hero::before{
  content:'';
  position:absolute;inset:0;
  background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}
.hero-inner{position:relative;z-index:1;max-width:820px}
.hero h1{
  color:#fff;
  font-size:clamp(1.9rem,4.5vw,3.4rem);
  margin-bottom:1rem;
  font-weight:700;
}
.hero-sub{
  font-size:1.05rem;
  color:rgba(255,255,255,.85);
  line-height:1.7;
  margin-bottom:2rem;
  max-width:600px;
}
.hero-cta{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1.75rem}

.btn{
  display:inline-flex;align-items:center;gap:.45rem;
  padding:.75rem 1.5rem;
  border-radius:var(--radius);
  font-family:var(--font-body);
  font-size:.9rem;
  font-weight:600;
  letter-spacing:.01em;
  transition:all var(--transition);
  cursor:pointer;
}
.btn-primary{background:var(--gold);color:var(--green-dark);border:2px solid var(--gold)}
.btn-primary:hover{background:var(--gold-dark);border-color:var(--gold-dark)}
.btn-outline{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.4)}
.btn-outline:hover{border-color:#fff;background:rgba(255,255,255,.1)}
.btn-green{background:var(--green-dark);color:#fff;border:2px solid var(--green-dark)}
.btn-green:hover{background:var(--green-mid);border-color:var(--green-mid)}

.trust-badges{display:flex;flex-wrap:wrap;gap:.5rem}
.trust-badge{
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.2);
  color:#fff;
  font-size:.78rem;
  font-weight:600;
  padding:.3rem .8rem;
  border-radius:2rem;
  letter-spacing:.03em;
}

/* === OVERVIEW CARD === */
.overview-card{
  background:var(--surface);
  border-radius:var(--radius);
  box-shadow:var(--shadow-md);
  padding:2rem;
  border-left:4px solid var(--gold);
  margin:-2.5rem 0 0;
  position:relative;z-index:2;
}
.overview-card h3{margin-bottom:1rem}
.overview-list li{
  display:flex;
  padding:.55rem 0;
  border-bottom:1px solid var(--border);
  font-size:.9rem;
  gap:1rem;
}
.overview-list li:last-child{border-bottom:none}
.overview-list .label{
  font-weight:600;
  color:var(--text-muted);
  min-width:160px;
  flex-shrink:0;
}
.overview-list .value{color:var(--text)}
.overview-footer{
  margin-top:1rem;
  font-size:.8rem;
  color:var(--text-muted);
}
.overview-footer a{color:var(--green-mid);text-decoration:underline}

/* === INFO SECTIONS === */
.info-section{padding:3rem 0}
.info-section h2{margin-bottom:.75rem}
.info-section p{color:var(--text-muted);font-size:.95rem}
.info-section+.info-section{border-top:1px solid var(--border)}

.section-header{
  display:flex;align-items:flex-start;gap:1rem;
  margin-bottom:1.25rem;
}
.section-icon{
  width:48px;height:48px;flex-shrink:0;
  background:var(--green-light);
  border-radius:var(--radius);
  display:flex;align-items:center;justify-content:center;
  font-size:1.4rem;
}

/* === ADVANTAGES/NOTES === */
.adv-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-top:1rem}
.adv-card{
  background:var(--surface);
  border-radius:var(--radius);
  padding:1.5rem;
  box-shadow:var(--shadow-sm);
}
.adv-card.green{border-top:3px solid var(--green-mid)}
.adv-card.amber{border-top:3px solid var(--gold)}
.adv-card h3{margin-bottom:1rem;font-size:1.1rem}
.adv-list li{
  display:flex;align-items:flex-start;gap:.6rem;
  padding:.4rem 0;
  font-size:.9rem;
  color:var(--text-muted);
}
.adv-list .icon{flex-shrink:0;font-size:1rem;margin-top:.1rem}

/* === RG BLOCK === */
.rg-block{
  background:var(--rg-bg);
  border:1px solid var(--rg-border);
  border-radius:var(--radius);
  padding:2rem;
  margin-top:2rem;
}
.rg-block h2{color:var(--green-dark);margin-bottom:.75rem}
.rg-block .hotline{
  display:flex;align-items:center;gap:.5rem;
  margin:1rem 0;
  padding:1rem;
  background:#fff;
  border-radius:var(--radius-sm);
  border:1px solid var(--rg-border);
  font-weight:600;
  font-size:.95rem;
}
.rg-links{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem}
.rg-link-chip{
  display:inline-flex;align-items:center;gap:.4rem;
  padding:.4rem 1rem;
  background:#fff;
  border:1px solid var(--rg-border);
  border-radius:2rem;
  font-size:.82rem;
  font-weight:600;
  color:var(--green-dark);
  transition:all var(--transition);
  text-decoration:none;
}
.rg-link-chip:hover{background:var(--gold-light);border-color:var(--gold)}

/* === FAQ === */
.faq-item{
  border-bottom:1px solid var(--border);
}
.faq-question{
  display:flex;align-items:center;justify-content:space-between;
  padding:1.1rem 0;
  font-family:var(--font-head);
  font-size:1.1rem;
  font-weight:600;
  color:var(--green-dark);
  cursor:pointer;
  gap:1rem;
  background:none;
  width:100%;
  text-align:left;
  border:none;
}
.faq-question .faq-icon{
  width:24px;height:24px;flex-shrink:0;
  background:var(--green-light);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:.9rem;
  transition:transform var(--transition),background var(--transition);
  color:var(--green-dark);
}
.faq-item.open .faq-icon{transform:rotate(45deg);background:var(--green-dark);color:#fff}
.faq-answer{
  display:none;
  padding-bottom:1.1rem;
  color:var(--text-muted);
  font-size:.93rem;
  line-height:1.7;
}
.faq-item.open .faq-answer{display:block}

/* === FOOTER === */
.site-footer{
  background:var(--green-dark);
  color:rgba(255,255,255,.8);
  padding:3rem 0 0;
}
.footer-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:2rem;
  padding-bottom:2rem;
  border-bottom:1px solid rgba(255,255,255,.12);
}
.footer-col h4{
  color:#fff;
  font-family:var(--font-head);
  font-size:1rem;
  margin-bottom:.9rem;
  padding-bottom:.5rem;
  border-bottom:1px solid var(--gold);
  display:inline-block;
}
.footer-col a{
  display:block;
  font-size:.85rem;
  color:rgba(255,255,255,.65);
  padding:.25rem 0;
  transition:color var(--transition);
}
.footer-col a:hover{color:#fff}
.footer-col a[target="_blank"]::after{content:' ↗';font-size:.75em;opacity:.6}

.footer-legal{
  padding:2rem 0;
  border-top:1px solid rgba(255,255,255,.08);
  font-size:.78rem;
  line-height:1.7;
  color:rgba(255,255,255,.55);
}
.footer-legal p{margin-bottom:.6rem}
.footer-legal strong{color:rgba(255,255,255,.8)}
.footer-legal a{color:rgba(255,255,255,.55);text-decoration:underline}
.footer-legal a:hover{color:#fff}

.footer-bottom{
  background:rgba(0,0,0,.2);
  padding:.9rem 0;
  text-align:center;
  font-size:.78rem;
  color:rgba(255,255,255,.4);
}

/* === MODAL === */
.modal-overlay{
  position:fixed;inset:0;z-index:1000;
  background:rgba(10,30,20,.75);
  backdrop-filter:blur(4px);
  display:flex;align-items:center;justify-content:center;
  padding:1.25rem;
  opacity:0;pointer-events:none;
  transition:opacity var(--transition);
}
.modal-overlay.active{opacity:1;pointer-events:all}
.modal-box{
  background:var(--surface);
  border-radius:var(--radius);
  padding:2rem;
  max-width:460px;width:100%;
  box-shadow:0 20px 60px rgba(0,0,0,.3);
  transform:translateY(12px);
  transition:transform var(--transition);
}
.modal-overlay.active .modal-box{transform:none}
.modal-box h3{color:var(--green-dark);font-size:1.3rem;margin-bottom:.75rem}
.modal-box p{font-size:.9rem;color:var(--text-muted);margin-bottom:1.25rem;line-height:1.65}
.modal-rg{
  background:var(--rg-bg);
  border:1px solid var(--rg-border);
  border-radius:var(--radius-sm);
  padding:.75rem;
  font-size:.8rem;
  color:var(--text-muted);
  margin-bottom:1.25rem;
}
.modal-actions{display:flex;gap:.75rem;flex-wrap:wrap}
.modal-actions .btn{flex:1;justify-content:center}

/* === PAGE HERO (inner pages) === */
.page-hero{
  background:var(--surface);
  border-bottom:1px solid var(--border);
  padding:2.5rem 0 2rem;
}
.page-hero h1{font-size:clamp(1.5rem,3vw,2.4rem)}
.page-hero p{color:var(--text-muted);margin-top:.5rem;font-size:1rem}

/* === CONTENT BLOCKS (inner pages) === */
.content-block{
  background:var(--surface);
  border-radius:var(--radius);
  padding:1.75rem;
  margin-bottom:1.25rem;
  border:1px solid var(--border);
}
.content-block h2{margin-bottom:1rem;font-size:1.4rem}
.content-block h3{margin-bottom:.6rem;margin-top:1.25rem;font-size:1.1rem}
.content-block p,
.content-block li{color:var(--text-muted);font-size:.93rem;line-height:1.7}
.content-block ul{padding-left:1.25rem;list-style:disc;margin-bottom:.75rem}
.content-block ul li{padding:.15rem 0}

/* === CONTACT FORM === */
.contact-form{display:flex;flex-direction:column;gap:1rem}
.form-group{display:flex;flex-direction:column;gap:.4rem}
.form-group label{font-size:.85rem;font-weight:600;color:var(--text)}
.form-group input,
.form-group textarea,
.form-group select{
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  padding:.7rem 1rem;
  font-family:var(--font-body);
  font-size:.93rem;
  background:var(--surface);
  color:var(--text);
  transition:border-color var(--transition);
}
.form-group input:focus,
.form-group textarea:focus{
  outline:none;
  border-color:var(--green-mid);
}
.form-group textarea{resize:vertical;min-height:120px}

/* === REVIEW PAGE === */
.rating-bar{
  display:flex;align-items:center;gap:.75rem;
  padding:.6rem 0;
  border-bottom:1px solid var(--border);
  font-size:.9rem;
}
.rating-bar .label{flex:1;color:var(--text-muted)}
.rating-bar .bar{
  width:120px;height:6px;
  background:var(--border);
  border-radius:3px;
  overflow:hidden;
}
.rating-bar .bar-fill{height:100%;background:var(--green-mid);border-radius:3px}
.rating-bar .score{width:2rem;text-align:right;font-weight:600;color:var(--green-dark);font-size:.85rem}

/* === UTILITY === */
.text-muted{color:var(--text-muted)}
.text-small{font-size:.85rem}
.text-center{text-align:center}
.mt-1{margin-top:.5rem}
.mt-2{margin-top:1rem}
.mt-3{margin-top:1.5rem}
.mb-2{margin-bottom:1rem}
.notice{
  background:var(--green-light);
  border-left:3px solid var(--green-mid);
  padding:.9rem 1rem;
  border-radius:0 var(--radius-sm) var(--radius-sm) 0;
  font-size:.88rem;
  color:var(--green-dark);
  margin-bottom:1rem;
}

/* === RESPONSIVE === */
@media(max-width:900px){
  .grid-2,.grid-3,.adv-grid,.footer-grid{grid-template-columns:1fr}
  .footer-grid{gap:1.5rem}
}
@media(max-width:768px){
  .site-nav{display:none}
  .hamburger{display:flex}
  .section{padding:2.5rem 0}
  .overview-card{margin-top:-1.5rem;padding:1.25rem}
  .overview-list .label{min-width:120px}
  .hero{padding:3rem 0 3rem}
  .modal-actions{flex-direction:column}
}
@media(max-width:480px){
  .hero-cta{flex-direction:column}
  .btn{justify-content:center}
  .rg-links{gap:.4rem}
}
