/* =====================================================
   SAHNE & SES REHBERi - CYAN NEON SAHNE + KARANLIK SALON
   ===================================================== */

/* --- Reset --- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{
  font-family:'Segoe UI',Tahoma,Geneva,Verdana,sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.78;
  min-height:100vh;
  display:flex;
  flex-direction:column;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

/* --- Palette --- */
:root{
  --bg:        #0c0e18;
  --bg-soft:   #111524;
  --bg-card:   #161a2c;
  --bg-card-h: #1c2238;
  --bg-header: #0a0c16;
  --bg-footer: #080a12;

  --cyan:      #00e6cc;
  --cyan-dim:  #00bfa8;
  --cyan-glow: rgba(0,230,204,.10);
  --cyan-glow2:rgba(0,230,204,.18);
  --magenta:   #e84aa0;
  --amber:     #f5c842;
  --amber-dim: #d4a830;

  --text:      #cdd2de;
  --text-hi:   #eef0f6;
  --text-lo:   #8990a6;
  --text-mute: #5c6278;

  --border:    rgba(255,255,255,.06);
  --border-c:  rgba(0,230,204,.12);

  --r:  10px;
  --rl: 16px;
  --shadow: 0 6px 32px rgba(0,0,0,.45);
  --glow:   0 0 24px rgba(0,230,204,.08);
  --trans:  .25s ease;
  --max-w:  1140px;
  --hdr-h:  68px;
}

/* --- Typography --- */
h1,h2,h3,h4{color:var(--text-hi);line-height:1.32;font-weight:700}
h1{font-size:clamp(1.7rem,4vw,2.45rem);margin-bottom:1.1rem}
h2{font-size:clamp(1.3rem,3vw,1.8rem);margin-bottom:.9rem}
h3{font-size:clamp(1.05rem,2.4vw,1.35rem);margin-bottom:.6rem}
h4{font-size:1.05rem;margin-bottom:.5rem}
p{margin-bottom:1rem}
a{color:var(--cyan);text-decoration:none;transition:color var(--trans)}
a:hover{color:var(--cyan-dim)}
a:focus-visible{outline:2px solid var(--cyan);outline-offset:3px;border-radius:3px}
ul,ol{padding-left:1.5rem;margin-bottom:1rem}
li{margin-bottom:.3rem}
strong{color:var(--text-hi)}

/* --- Skip link --- */
.skip-link{position:absolute;top:-100%;left:16px;background:var(--cyan);color:#0a0c16;padding:8px 20px;border-radius:0 0 8px 8px;font-weight:700;z-index:10001;transition:top .2s}
.skip-link:focus{top:0}

/* --- Layout --- */
.container{width:100%;max-width:var(--max-w);margin:0 auto;padding:0 24px}
main{flex:1;padding:40px 0 60px}
section{margin-bottom:52px}

/* ============ HEADER ============ */
.site-header{
  background:var(--bg-header);
  border-bottom:1px solid var(--border);
  position:sticky;top:0;z-index:1000;
  height:var(--hdr-h);
}
.site-header.sticky-header{
  background:var(--bg-header);
}
.header-inner,
.container.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:var(--hdr-h);
  max-width:var(--max-w);margin:0 auto;padding:0 24px;
}

/* Logo */
.logo,.site-logo{
  display:flex;align-items:center;gap:10px;
  font-size:1.2rem;font-weight:700;
  color:var(--text-hi);text-decoration:none;
}
.logo:hover,.site-logo:hover{color:var(--cyan);text-decoration:none}
.logo-icon{width:34px;height:34px;color:var(--cyan)}
.logo-icon svg{width:100%;height:100%}
.logo-text{white-space:nowrap}

/* Nav */
.main-nav{display:flex;align-items:center}
.nav-list{display:flex;list-style:none;gap:2px;padding:0;margin:0}
.nav-list>li{position:relative}
.nav-list a,
.nav-list .nav-link,
.nav-list button.nav-link,
.nav-list button.dropdown-toggle{
  display:block;padding:8px 14px;border-radius:6px;
  font-size:.88rem;color:var(--text-lo);font-weight:500;
  white-space:nowrap;transition:var(--trans);
  background:none;border:none;cursor:pointer;
  font-family:inherit;text-decoration:none;
  line-height:1.5;
}
.nav-list a:hover,
.nav-list .nav-link:hover,
.nav-list button.nav-link:hover,
.nav-list button.dropdown-toggle:hover,
.nav-list a[aria-current="page"],
.nav-list .nav-link[aria-current="page"],
.nav-list a.parent-active,
.nav-list .nav-link.parent-active,
.nav-list button.parent-active{
  color:var(--cyan);background:var(--cyan-glow);text-decoration:none;
}

/* Dropdown arrow */
.has-dropdown>a::after,
.has-dropdown>button::after,
.nav-item.has-dropdown>button::after{
  content:'';display:inline-block;width:0;height:0;
  margin-left:6px;vertical-align:middle;
  border-left:4px solid transparent;border-right:4px solid transparent;
  border-top:5px solid currentColor;
  transition:transform .22s ease;
}
.has-dropdown:hover>a::after,
.has-dropdown:hover>button::after,
.nav-item.has-dropdown:hover>button::after{
  transform:rotate(-180deg);
}

/* Dropdown panel */
.dropdown,
.dropdown-menu,
.nav-dropdown{
  position:absolute;top:100%;left:0;
  min-width:224px;
  background:var(--bg-card);
  border:1px solid var(--border-c);
  border-radius:var(--r);
  box-shadow:var(--shadow);
  padding:8px 0;
  opacity:0;visibility:hidden;
  transform:translateY(10px);
  transition:opacity .22s ease,transform .22s ease,visibility .22s;
  z-index:200;
  list-style:none;
}
.has-dropdown:hover>.dropdown,
.has-dropdown:hover>.dropdown-menu,
.has-dropdown:hover>.nav-dropdown,
.nav-item.has-dropdown:hover>.dropdown-menu{
  opacity:1;visibility:visible;transform:translateY(0);
}
.dropdown a,.dropdown-menu a,.nav-dropdown a{
  padding:10px 20px;font-size:.86rem;border-radius:0;
  display:block;color:var(--text-lo);
}
.dropdown a:hover,.dropdown-menu a:hover,.nav-dropdown a:hover,
.dropdown a[aria-current="page"],.dropdown-menu a[aria-current="page"]{
  background:var(--cyan-glow);color:var(--cyan);text-decoration:none;
}

/* Hamburger / mobile toggle (both naming conventions) */
.nav-toggle,.hamburger{
  display:none;background:none;border:none;
  color:var(--text);cursor:pointer;padding:6px;
  position:relative;width:36px;height:36px;
}
.nav-toggle svg{width:28px;height:28px}
.hamburger-line{
  display:block;width:24px;height:2.5px;
  background:currentColor;border-radius:2px;
  position:absolute;left:6px;
  transition:var(--trans);
}
.hamburger-line:nth-child(1){top:8px}
.hamburger-line:nth-child(2){top:16px}
.hamburger-line:nth-child(3){top:24px}
.hamburger[aria-expanded="true"] .hamburger-line:nth-child(1){transform:rotate(45deg);top:16px}
.hamburger[aria-expanded="true"] .hamburger-line:nth-child(2){opacity:0}
.hamburger[aria-expanded="true"] .hamburger-line:nth-child(3){transform:rotate(-45deg);top:16px}

@media(max-width:960px){
  .nav-toggle,.hamburger{display:flex;align-items:center;justify-content:center}
  .main-nav{
    position:fixed;top:var(--hdr-h);right:0;bottom:0;
    width:290px;background:var(--bg-header);
    border-left:1px solid var(--border);
    flex-direction:column;padding:24px 16px;
    transform:translateX(100%);transition:transform .3s ease;
    overflow-y:auto;z-index:999;
  }
  .main-nav.open{transform:translateX(0)}
  .nav-list{flex-direction:column;gap:2px;width:100%}
  .dropdown,.dropdown-menu,.nav-dropdown{
    position:static;opacity:1;visibility:visible;
    transform:none;box-shadow:none;border:none;
    background:transparent;padding:4px 0 4px 18px;
    min-width:0;
  }
  .has-dropdown>a::after,
  .has-dropdown>button::after,
  .nav-item.has-dropdown>button::after{display:none}
}

/* ============ HERO ============ */
.hero,
.page-hero{
  position:relative;padding:70px 0 56px;
  overflow:hidden;text-align:center;
}
.hero::before,
.page-hero::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse 600px 400px at 30% 20%,rgba(0,230,204,.06),transparent),
    radial-gradient(ellipse 500px 350px at 75% 70%,rgba(232,74,160,.04),transparent);
  pointer-events:none;
}
.hero.city-hero::before,
.hero.hero-city::before{
  background:
    radial-gradient(ellipse 500px 400px at 50% 10%,rgba(245,200,66,.05),transparent),
    radial-gradient(ellipse 600px 300px at 20% 80%,rgba(0,230,204,.05),transparent);
}
.hero-content,
.hero-inner,
.page-hero-content{
  position:relative;z-index:1;
  max-width:780px;margin:0 auto;padding:0 24px;
}
.hero h1{font-size:clamp(2rem,5vw,2.9rem);position:relative}
.hero h1 span,.page-hero h1 span{color:var(--cyan)}
.hero-subtitle,
.hero-sub,
.page-hero-subtitle,
.hero p{
  font-size:clamp(.95rem,2vw,1.15rem);
  color:var(--text-lo);max-width:680px;
  margin:0 auto 2rem;line-height:1.75;
}
.hero-actions,
.hero-cta{
  display:flex;gap:14px;justify-content:center;flex-wrap:wrap;
}
.hero-visual,
.page-hero-visual{
  position:relative;margin-top:36px;
  display:flex;justify-content:center;
}
.hero-decoration,
.page-hero-decoration{
  color:var(--cyan);opacity:.35;
  max-width:420px;width:100%;height:auto;
}

/* ============ BUTTONS ============ */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:12px 28px;border-radius:var(--r);
  font-weight:600;font-size:.93rem;cursor:pointer;
  border:none;transition:var(--trans);
  text-decoration:none;font-family:inherit;
  line-height:1.4;
}
.btn:hover{text-decoration:none;transform:translateY(-1px)}
.btn:focus-visible{outline:2px solid var(--cyan);outline-offset:3px}
.btn-primary,.btn.btn-primary{background:var(--cyan);color:#0a0c16}
.btn-primary:hover{background:var(--cyan-dim);color:#0a0c16}
.btn-secondary,.btn-outline,.btn.btn-secondary,.btn.btn-outline{
  background:transparent;color:var(--cyan);
  border:1.5px solid var(--cyan);
}
.btn-secondary:hover,.btn-outline:hover{background:var(--cyan-glow);color:var(--cyan)}

/* ============ CARDS ============ */
.card-grid-section,
.city-grid-section{padding:0 24px;max-width:var(--max-w);margin:0 auto 52px}
.card-grid-section .container,
.city-grid-section .container{padding:0}
.section-intro{color:var(--text-lo);margin-bottom:28px;max-width:680px}
.card-grid,.related-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(300px,1fr));
  gap:22px;
}
.card,.related-card{
  background:var(--bg-card);
  border:1px solid var(--border-c);
  border-radius:var(--rl);
  padding:28px;
  transition:background var(--trans),border-color var(--trans),transform var(--trans),box-shadow var(--trans);
  position:relative;overflow:hidden;
  text-decoration:none;color:var(--text);
  display:block;
}
.card:hover,.related-card:hover{
  background:var(--bg-card-h);
  border-color:rgba(0,230,204,.22);
  box-shadow:var(--glow);
  transform:translateY(-3px);
  text-decoration:none;
}
.card-icon{width:48px;height:48px;margin-bottom:14px;color:var(--cyan)}
.card-icon svg{width:100%;height:100%}
.card h3,.card h3 a,.related-card h3{color:var(--text-hi);text-decoration:none}
.card h3 a:hover{color:var(--cyan)}
.card p,.related-card p{color:var(--text-lo);font-size:.9rem;margin-bottom:0}

/* City cards */
.city-card{
  background:var(--bg-card);border-radius:var(--rl);
  overflow:hidden;border:1px solid var(--border-c);
  transition:transform var(--trans),box-shadow var(--trans),border-color var(--trans);
}
.city-card:hover{
  transform:translateY(-4px);box-shadow:var(--glow);
  border-color:rgba(0,230,204,.22);
}
.city-visual{
  height:170px;position:relative;overflow:hidden;
  background:linear-gradient(135deg,#111528 0%,#181d32 100%);
}
.city-visual svg{width:100%;height:100%}
.city-content,.city-card-content{padding:24px}
.city-content h3 a,.city-card-content h3 a{color:var(--text-hi);text-decoration:none}
.city-content h3 a:hover,.city-card-content h3 a:hover{color:var(--cyan)}

/* Ticket cards */
.ticket-card{
  background:var(--bg-card);border-radius:var(--rl);
  overflow:hidden;border:1px solid var(--border-c);
  transition:border-color var(--trans),box-shadow var(--trans);
  margin-bottom:22px;
}
.ticket-card:hover{border-color:rgba(0,230,204,.22);box-shadow:var(--glow)}
.ticket-header,.ticket-card-header{
  padding:20px 24px;
  background:linear-gradient(135deg,rgba(0,230,204,.07),rgba(232,74,160,.04));
  border-bottom:1px dashed var(--border);
}
.ticket-header h3,.ticket-card-header h3{margin-bottom:4px}
.ticket-body,.ticket-card-body{padding:24px}
.ticket-body p,.ticket-card-body p{color:var(--text-lo);font-size:.92rem}
.ticket-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;justify-content:flex-end}

/* ============ VISUAL PANELS ============ */
.visual-panel,
.panel-visual{
  position:relative;width:100%;height:220px;
  border-radius:var(--rl);overflow:hidden;
  margin-bottom:32px;
  background:linear-gradient(135deg,#101428,#181e34);
  border:1px solid var(--border-c);
}
.visual-panel svg,.panel-visual svg{position:absolute;inset:0;width:100%;height:100%}

/* Soundwave BG decoration */
.soundwave-bg{position:relative;overflow:hidden}
.soundwave-bg::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:50px;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 50'%3E%3Cpath d='M0 30Q50 8 100 30Q150 52 200 30Q250 8 300 30Q350 52 400 30Q450 8 500 30Q550 52 600 30Q650 8 700 30Q750 52 800 30Q850 8 900 30Q950 52 1000 30Q1050 8 1100 30Q1150 52 1200 30' fill='none' stroke='rgba(0,230,204,.07)' stroke-width='1.5'/%3E%3C/svg%3E") repeat-x;
  pointer-events:none;opacity:.7;
}

/* Spotlight radial */
.spotlight{position:relative}
.spotlight::before{
  content:'';position:absolute;top:-120px;left:50%;transform:translateX(-50%);
  width:500px;height:500px;border-radius:50%;
  background:radial-gradient(circle,rgba(0,230,204,.04),transparent 70%);
  pointer-events:none;
}

/* ============ TABS ============ */
.tabs,.tabs-section,.season-tabs{margin-bottom:32px}
.tab-list{
  display:flex;gap:4px;
  border-bottom:2px solid var(--border);
  margin-bottom:24px;
}
.tab-list [role="tab"],
.tab-btn{
  padding:11px 20px;background:none;border:none;
  color:var(--text-lo);font-weight:500;font-size:.9rem;
  cursor:pointer;border-bottom:2px solid transparent;
  margin-bottom:-2px;transition:var(--trans);
  white-space:nowrap;font-family:inherit;
}
.tab-list [role="tab"]:hover,.tab-btn:hover{color:var(--text)}
.tab-list [role="tab"][aria-selected="true"],
.tab-btn.active{
  color:var(--cyan);border-bottom-color:var(--cyan);
}
.tab-list [role="tab"]:focus-visible,.tab-btn:focus-visible{
  outline:2px solid var(--cyan);outline-offset:-2px;border-radius:4px 4px 0 0;
}
[role="tabpanel"],.tab-panel{display:none}
[role="tabpanel"].active,.tab-panel.active{display:block}

/* ============ ACCORDION / FAQ ============ */
.accordion{
  margin-bottom:14px;
  border:none;
}
.accordion-item{
  margin-bottom:14px;
  border:1px solid var(--border-c);
  border-radius:var(--r);overflow:hidden;
}
.accordion-group{margin-bottom:32px}
.accordion-trigger,.accordion-title{
  width:100%;display:flex;justify-content:space-between;
  align-items:center;padding:18px 24px;
  background:var(--bg-card);border:none;
  color:var(--text-hi);font-size:.98rem;font-weight:600;
  cursor:pointer;text-align:left;transition:var(--trans);
  font-family:inherit;line-height:1.4;
}
.accordion-trigger:hover,.accordion-title:hover{background:var(--bg-card-h)}
.accordion-trigger:focus-visible,.accordion-title:focus-visible{outline:2px solid var(--cyan);outline-offset:-2px}
.accordion-trigger::after{
  content:'';width:10px;height:10px;
  border-right:2px solid var(--cyan);border-bottom:2px solid var(--cyan);
  transform:rotate(45deg);transition:transform .3s;
  flex-shrink:0;margin-left:16px;
}
.accordion-trigger[aria-expanded="true"]::after{transform:rotate(-135deg)}
.accordion-panel,.accordion-content{max-height:0;overflow:hidden;transition:max-height .35s ease}
.accordion-panel-inner,.accordion-content>div,.accordion-content p{
  padding:18px 24px;color:var(--text-lo);line-height:1.75;
}
.accordion-panel-inner p:last-child{margin-bottom:0}
.accordion-icon{display:none}

/* ============ FILTERS ============ */
.filter-bar{
  display:flex;flex-wrap:wrap;gap:14px;
  margin-bottom:32px;padding:22px;
  background:var(--bg-card);border-radius:var(--rl);
  border:1px solid var(--border-c);
}
.filter-group{display:flex;flex-direction:column;gap:6px;min-width:180px;flex:1}
.filter-group label{font-size:.78rem;color:var(--text-mute);font-weight:700;text-transform:uppercase;letter-spacing:.6px}
.filter-group select{
  padding:10px 14px;background:var(--bg);color:var(--text);
  border:1px solid var(--border);border-radius:6px;
  font-size:.9rem;cursor:pointer;transition:var(--trans);
  font-family:inherit;
  appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238990a6' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 12px center;
}
.filter-group select:focus{border-color:var(--cyan);outline:none;box-shadow:0 0 0 3px var(--cyan-glow)}

/* ============ BREADCRUMB ============ */
.breadcrumb{display:none}
.breadcrumb a{color:var(--text-lo)}
.breadcrumb a:hover{color:var(--cyan)}
.breadcrumb span[aria-current="page"]{color:var(--cyan)}
.breadcrumb .sep{margin:0 2px}

/* ============ PAGE HEADER ============ */
.page-header{padding:44px 0 28px;text-align:center;position:relative}
.page-header p{color:var(--text-lo);max-width:700px;margin:0 auto}

/* ============ CONTENT SECTIONS ============ */
.content-section{margin-bottom:48px}
.content-section h2{padding-bottom:12px;border-bottom:1px solid var(--border);margin-bottom:22px}
/* Content sections that are direct children of main (no container wrapper) */
main>.content-section,
main>.related-content{
  max-width:var(--max-w);margin-left:auto;margin-right:auto;padding-left:24px;padding-right:24px;
}
main>.content-section.alt-bg{
  max-width:none;padding-left:0;padding-right:0;
}
.content-section.alt-bg{
  background:var(--bg-soft);
  padding:40px 0;
  padding-left:24px;padding-right:24px;
  border-radius:var(--rl);
}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:32px}
@media(max-width:768px){.two-col{grid-template-columns:1fr}}

/* Why section (index) */
.why-section{padding:0 24px;max-width:var(--max-w);margin:0 auto 52px}
.why-section .container{padding:0}
.why-content{max-width:none}
.why-text p{color:var(--text-lo);font-size:.95rem}

/* ============ RELATED ============ */
.related,.related-section,.related-content{
  margin-top:48px;padding-top:32px;
  border-top:1px solid var(--border);
}
.related h2,.related-section h2,.related-content h2{
  font-size:1.15rem;margin-bottom:20px;
  color:var(--text-lo);font-weight:600;
}
.related-links{
  display:flex;flex-wrap:wrap;gap:12px;
  list-style:none;padding:0;margin:0;
}
.related-links a{
  display:inline-flex;align-items:center;gap:6px;
  padding:10px 18px;background:var(--bg-card);
  border:1px solid var(--border-c);border-radius:var(--r);
  font-size:.87rem;color:var(--text);transition:var(--trans);
  text-decoration:none;
}
.related-links a:hover{
  border-color:var(--cyan);color:var(--cyan);
  text-decoration:none;background:var(--cyan-glow);
}

/* ============ FOOTER ============ */
.site-footer{
  background:var(--bg-footer);
  border-top:1px solid var(--border);
  padding:48px 0 0;margin-top:auto;
}
.footer-inner{max-width:var(--max-w);margin:0 auto;padding:0 24px}
.footer-grid,
.footer-columns{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
  gap:32px;margin-bottom:40px;
}
.footer-col h4,.footer-column h4{
  color:var(--cyan);font-size:.82rem;
  text-transform:uppercase;letter-spacing:.8px;
  margin-bottom:16px;font-weight:700;
}
.footer-col ul,.footer-column ul{list-style:none;padding:0;margin:0}
.footer-col li,.footer-column li{margin-bottom:8px}
.footer-col a,.footer-column a{color:var(--text-lo);font-size:.88rem}
.footer-col a:hover,.footer-column a:hover{color:var(--cyan)}
.footer-bottom{
  border-top:1px solid var(--border);
  padding:20px 0;text-align:center;
  font-size:.8rem;color:var(--text-mute);
}

/* ============ FORM ============ */
.contact-layout{
  display:grid;grid-template-columns:1fr 1fr;gap:40px;
}
@media(max-width:768px){.contact-layout{grid-template-columns:1fr}}
.contact-form-wrapper{
  max-width:720px;margin:0 auto;
  background:var(--bg-card);
  border:1px solid var(--border-c);
  border-radius:var(--rl);
  padding:36px 40px;
  box-shadow:var(--shadow);
}
.contact-form-wrapper h2{
  text-align:center;margin-bottom:28px;
}
.contact-section{margin-bottom:40px}
.form-group{margin-bottom:20px}
.form-group label{display:block;font-weight:600;margin-bottom:6px;font-size:.9rem;color:var(--text)}
.form-group .required{color:var(--magenta)}
.form-group input,
.form-group textarea,
.form-group select{
  width:100%;padding:12px 16px;
  background:var(--bg);border:1px solid var(--border);
  border-radius:6px;color:var(--text);
  font-size:.93rem;font-family:inherit;transition:var(--trans);
}
.form-group input:focus,
.form-group textarea:focus{
  border-color:var(--cyan);outline:none;
  box-shadow:0 0 0 3px var(--cyan-glow);
}
.form-group textarea{resize:vertical;min-height:140px}
.form-group.form-checkbox,.form-check{display:flex;gap:10px;align-items:flex-start}
.form-group.form-checkbox input[type="checkbox"],
.form-check input[type="checkbox"]{
  margin-top:4px;accent-color:var(--cyan);
  width:18px;height:18px;flex-shrink:0;
}
.form-group.form-checkbox label,
.form-check label{font-weight:400;font-size:.86rem;color:var(--text-lo);cursor:pointer}
.form-message{
  padding:14px 18px;border-radius:var(--r);
  margin-top:16px;font-size:.9rem;display:none;
}
.form-message.success{display:block;background:rgba(0,230,204,.1);color:var(--cyan);border:1px solid rgba(0,230,204,.2)}
.form-message.error{display:block;background:rgba(232,74,160,.1);color:var(--magenta);border:1px solid rgba(232,74,160,.2)}
.honeypot-field{position:absolute;left:-9999px;opacity:0;height:0;width:0;pointer-events:none}

/* Contact info */
.contact-info{margin-top:8px}
.contact-info-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:16px;margin-bottom:40px;
}
.contact-item{
  display:flex;gap:16px;align-items:flex-start;
  padding:22px 20px;background:var(--bg-card);
  border-radius:var(--r);border:1px solid var(--border-c);
  transition:border-color var(--trans),box-shadow var(--trans),transform var(--trans);
}
.contact-item:hover{
  border-color:var(--cyan);
  box-shadow:0 0 18px rgba(0,230,204,.12);
  transform:translateY(-2px);
}
.contact-item-icon{
  width:44px;height:44px;flex-shrink:0;
  color:var(--cyan);
  background:var(--cyan-glow);
  border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  padding:10px;
}
.contact-item-icon svg{width:100%;height:100%}
.contact-item-content{flex:1;min-width:0}
.contact-item-content h3{
  margin-bottom:5px;font-size:.82rem;font-weight:600;
  text-transform:uppercase;letter-spacing:.06em;
  color:var(--text-lo);
}
.contact-item-content a{
  color:var(--text-hi);font-size:.95rem;
  transition:color var(--trans);word-break:break-all;
}
.contact-item-content a:hover{color:var(--cyan)}
.contact-item-content p,
.contact-item-content address{
  color:var(--text);font-size:.95rem;
  font-style:normal;line-height:1.55;
  margin:0;
}

/* ============ IMAGES ============ */
.content-img{display:flex;gap:28px;align-items:flex-start;margin-bottom:32px}
.content-img.reverse{flex-direction:row-reverse}
.content-img figure{flex:0 0 320px;max-width:320px;margin:0;border-radius:var(--rl);overflow:hidden;border:1px solid var(--border-c)}
.content-img figure img{width:100%;height:auto;display:block;object-fit:cover}
.content-img figcaption{font-size:.78rem;color:var(--text-mute);padding:10px 14px;background:var(--bg-card);text-align:center}
.content-img .text-block{flex:1;min-width:0}
@media(max-width:768px){
  .content-img,.content-img.reverse{flex-direction:column}
  .content-img figure{flex:none;max-width:100%;width:100%}
}
.figure-inline{
  float:right;margin:4px 0 22px 28px;
  max-width:300px;border-radius:var(--rl);
  overflow:hidden;border:1px solid var(--border-c);
}
.figure-inline.left{float:left;margin:4px 28px 22px 0}
.figure-inline img{width:100%;height:auto;display:block;object-fit:cover}
.figure-inline figcaption{font-size:.78rem;color:var(--text-mute);padding:10px 14px;background:var(--bg-card);text-align:center}
@media(max-width:600px){
  .figure-inline,.figure-inline.left{float:none;max-width:100%;margin:0 0 22px 0}
}

/* Full-width block figure (for standalone images in sections) */
.figure-block{
  width:100%;max-width:100%;float:none;
  margin:0 auto 32px;border-radius:var(--rl);
  overflow:hidden;border:1px solid var(--border-c);
}
.figure-block img{width:100%;height:auto;display:block;object-fit:cover;max-height:440px}
.figure-block figcaption{font-size:.78rem;color:var(--text-mute);padding:10px 14px;background:var(--bg-card);text-align:center}

/* Intro section centering (sehirler, etc.) */
.intro-section .container>h2,
.city-grid-section .container>h2,
.city-grid-section .container>.section-intro,
.city-culture-section .container>h2{
  text-align:center;
}
.intro-section .container>p{text-align:center;margin-left:auto;margin-right:auto;max-width:700px}

/* Wave decoration */
.wave-decoration{width:100%;height:40px;margin:32px 0;opacity:.35}

/* ============ COOKIE BANNER ============ */
.cookie-banner{
  position:fixed;bottom:0;left:0;right:0;
  background:var(--bg-header);
  border-top:1px solid var(--border-c);
  padding:20px;z-index:9999;
  transform:translateY(100%);
  transition:transform .4s ease;
  box-shadow:0 -6px 40px rgba(0,0,0,.55);
}
.cookie-banner.visible{transform:translateY(0)}
.cookie-inner{
  max-width:var(--max-w);margin:0 auto;
  display:flex;flex-wrap:wrap;gap:16px;
  align-items:center;justify-content:space-between;
}
.cookie-text{flex:1;min-width:260px;font-size:.88rem;color:var(--text-lo);line-height:1.6}
.cookie-text a{color:var(--cyan)}
.cookie-actions{display:flex;gap:10px;flex-wrap:wrap}
.cookie-actions button{
  padding:10px 20px;border-radius:6px;
  font-weight:600;font-size:.86rem;
  cursor:pointer;border:none;transition:var(--trans);
  font-family:inherit;
}
.cookie-accept{background:var(--cyan);color:#0a0c16}
.cookie-accept:hover{background:var(--cyan-dim)}
.cookie-reject{background:transparent;color:var(--text);border:1px solid var(--border)}
.cookie-reject:hover{border-color:var(--text-lo)}
.cookie-settings-btn{background:transparent;color:var(--text-lo);border:1px solid var(--border)}
.cookie-settings-btn:hover{border-color:var(--cyan);color:var(--cyan)}

/* Cookie modal */
.cookie-modal-overlay{
  position:fixed;inset:0;
  background:rgba(0,0,0,.65);
  z-index:10000;display:none;
  align-items:center;justify-content:center;padding:20px;
}
.cookie-modal-overlay.visible{display:flex}
.cookie-modal{
  background:var(--bg-card);border-radius:var(--rl);
  max-width:520px;width:100%;max-height:80vh;
  overflow-y:auto;padding:32px;
  border:1px solid var(--border-c);
  box-shadow:0 10px 50px rgba(0,0,0,.55);
}
.cookie-modal h2,.cookie-modal h3{margin-bottom:20px;color:var(--text-hi)}
.cookie-option{padding:16px 0;border-bottom:1px solid var(--border)}
.cookie-option:last-of-type{border-bottom:none}
.cookie-option-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}
.cookie-option-header strong,.cookie-option-header label{font-size:.92rem;color:var(--text-hi)}
.cookie-option p{font-size:.82rem;color:var(--text-mute);margin:0}
.cookie-always-on{font-size:.78rem;color:var(--cyan);font-weight:600}
.cookie-toggle{position:relative;width:44px;height:24px;flex-shrink:0;display:inline-block}
.cookie-toggle input[type="checkbox"]{opacity:0;width:0;height:0;position:absolute}
.cookie-toggle .slider{
  position:absolute;inset:0;background:var(--border);
  border-radius:12px;cursor:pointer;transition:var(--trans);
}
.cookie-toggle .slider::before{
  content:'';position:absolute;width:18px;height:18px;
  left:3px;top:3px;background:#fff;border-radius:50%;
  transition:var(--trans);
}
.cookie-toggle input:checked+.slider{background:var(--cyan)}
.cookie-toggle input:checked+.slider::before{transform:translateX(20px)}
.cookie-toggle input:disabled+.slider{opacity:.45;cursor:not-allowed}
/* standalone checkbox toggles (alt cookie format) */
input.cookie-toggle[type="checkbox"]{width:44px;height:24px;accent-color:var(--cyan)}
.cookie-modal-actions{display:flex;gap:10px;margin-top:24px;justify-content:flex-end;flex-wrap:wrap}

/* ============ MISC PAGE CLASSES ============ */
.page-content,.content-narrow{max-width:var(--max-w);margin:0 auto;padding:0 24px}
.page-intro,.page-subtitle{color:var(--text-lo);margin-bottom:28px;max-width:720px}
.intro-section{margin-bottom:28px}
.page-intro p,.intro-section p{color:var(--text-lo)}
.faq-section,.city-culture-section{margin-bottom:48px}
.comparison-list{margin-bottom:24px}
.comparison-list li{margin-bottom:8px;padding-left:6px}
.climate-overview{margin-bottom:32px}
.hero-panel{position:relative;margin-top:24px;display:flex;justify-content:center}
.hero-panel svg{max-width:100%;height:auto;color:var(--cyan);opacity:.3}
.motif-wide{width:100%;margin:32px 0}
.motif-wide svg{width:100%;height:auto;opacity:.25}
.ph-label{font-size:.72rem;color:var(--text-mute);text-transform:uppercase;letter-spacing:1px}
.sitemap-list{list-style:none;padding:0}
.sitemap-list li{margin-bottom:10px;padding-left:0}
.sitemap-list a{font-size:.95rem}
.sitemap-list ul{margin-top:8px;padding-left:24px;list-style:disc}

/* ============ UTILITIES ============ */
.text-center{text-align:center}
.text-cyan{color:var(--cyan)}
.mt-0{margin-top:0}.mb-0{margin-bottom:0}
.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}

/* ============ PRINT ============ */
@media print{
  .site-header,.site-footer,.cookie-banner,.cookie-modal-overlay,.skip-link{display:none}
  body{background:#fff;color:#111}
  main{padding:0}
  .card,.ticket-card,.city-card{border-color:#ccc}
}

/* ============ REDUCED MOTION ============ */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.01ms!important;
    animation-iteration-count:1!important;
    transition-duration:.01ms!important;
    scroll-behavior:auto!important;
  }
  .cookie-banner{transition:none}
}

/* ============ RESPONSIVE ============ */
@media(max-width:768px){
  main{padding:28px 0 44px}
  .hero,.page-hero{padding:44px 0 36px}
  .card-grid,.related-grid{grid-template-columns:1fr}
  .contact-info,.contact-info-grid{grid-template-columns:1fr}
  .filter-bar{flex-direction:column}
  .footer-grid,.footer-columns{grid-template-columns:1fr 1fr}
  .container{padding:0 16px}
  .card-grid-section,.city-grid-section,.why-section{padding:0 16px}
  .header-inner,.container.header-inner{padding:0 16px}
  .footer-inner{padding:0 16px}
}
@media(max-width:480px){
  .footer-grid,.footer-columns{grid-template-columns:1fr}
  .cookie-inner{flex-direction:column;text-align:center}
  .cookie-actions{justify-content:center;width:100%}
  .hero-actions,.hero-cta{flex-direction:column;align-items:center}
  .contact-layout{gap:24px}
  .contact-form-wrapper{padding:24px 20px}
}
