/* ============================================================
   Acik Hava Festival Alani — styles.css
   Sunset Open-Air / Warm Lights / Map Lines Theme
   ============================================================ */

/* --- Reset & Base --- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:hidden}
body{font-family:"Segoe UI",Tahoma,Geneva,Verdana,sans-serif;line-height:1.7;color:#2b1d0e;background:#fdfaf6;min-height:100vh;display:flex;flex-direction:column}

/* --- Skip Link (A11y) --- */
.skip-link{position:absolute;top:-100%;left:16px;background:#e85d26;color:#fff;padding:8px 18px;z-index:10000;border-radius:0 0 6px 6px;font-weight:600;text-decoration:none;transition:top .2s}
.skip-link:focus{top:0}

/* --- CSS Custom Properties --- */
:root{
  --sunset-dark:#1a0a00;
  --sunset-deep:#7b2d0e;
  --sunset-warm:#d4641a;
  --sunset-orange:#e8873c;
  --sunset-gold:#f2b254;
  --sunset-light:#fce5c3;
  --sunset-cream:#fdf5eb;
  --sunset-sky:#3a1c5e;
  --sunset-violet:#5c2d82;
  --text-primary:#2b1d0e;
  --text-secondary:#5a432a;
  --text-muted:#8c7a66;
  --surface:#fff;
  --surface-alt:#fdf8f2;
  --border:#e8ddd0;
  --border-light:#f0e8dc;
  --radius:8px;
  --radius-lg:14px;
  --shadow-sm:0 1px 3px rgba(42,20,0,.08);
  --shadow-md:0 4px 16px rgba(42,20,0,.1);
  --shadow-lg:0 8px 32px rgba(42,20,0,.12);
  --transition:0.25s ease;
  --max-width:1140px;
  --header-h:72px;
}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:0.01ms!important;animation-iteration-count:1!important;transition-duration:0.01ms!important;scroll-behavior:auto!important}
}

/* --- Typography --- */
h1,h2,h3,h4{color:var(--sunset-deep);line-height:1.25;font-weight:700}
h1{font-size:clamp(1.75rem,4vw,2.6rem);margin-bottom:1rem}
h2{font-size:clamp(1.35rem,3vw,2rem);margin-bottom:.75rem}
h3{font-size:clamp(1.1rem,2.5vw,1.5rem);margin-bottom:.5rem}
h4{font-size:1.1rem;margin-bottom:.4rem}
p{margin-bottom:1rem;color:var(--text-secondary);font-size:.95rem;line-height:1.75}
a{color:var(--sunset-warm);text-decoration:none;transition:color var(--transition)}
a:hover,a:focus-visible{color:var(--sunset-deep)}
ul,ol{margin:0 0 1.2rem 1.5rem}
li{margin-bottom:.45rem;line-height:1.7;color:var(--text-secondary);font-size:.95rem}
strong{color:var(--text-primary)}
img{max-width:100%;height:auto;display:block}

/* --- Content sections (inner pages) --- */
section>.container>h2{margin-top:.5rem;margin-bottom:1.2rem}
section>.container>h3{margin-top:2.5rem;margin-bottom:.8rem}
section>.container>p{max-width:780px}
section>.container>ul,section>.container>ol{max-width:780px}

/* Highlight / callout */
.content-highlight{background:var(--sunset-cream);border-radius:var(--radius-lg);padding:24px 28px;margin:2rem 0}
.content-highlight p{color:var(--text-secondary)}
.content-highlight p:last-child{margin-bottom:0}

/* --- Info List --- */
.info-list{max-width:780px;margin:1.5rem 0 2rem}
.info-list-item{display:flex;gap:16px;align-items:baseline;padding:18px 0;border-bottom:1px solid var(--border-light)}
.info-list-item:first-child{padding-top:0}
.info-list-item:last-child{border-bottom:none;padding-bottom:0}
.info-list-marker{flex-shrink:0;width:7px;height:7px;border-radius:50%;background:var(--sunset-warm);margin-top:6px}
.info-list-item strong{display:block;color:var(--sunset-deep);margin-bottom:4px}
.info-list-item p{margin-bottom:0}

/* --- Scenario Box --- */
.scenario-box{background:var(--sunset-cream);border-radius:var(--radius-lg);padding:32px 36px;margin:1.5rem 0}
.scenario-box p{max-width:none}
.scenario-box p:last-child{margin-bottom:0}

/* --- Timeline Cards --- */
.timeline-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin:2rem 0}
.timeline-card{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:28px 24px;text-align:center}
.timeline-badge{display:inline-block;background:var(--sunset-warm);color:#fff;font-weight:700;font-size:.85rem;padding:6px 18px;border-radius:var(--radius);margin-bottom:14px}
.timeline-card strong{display:block;color:var(--text-primary);margin-bottom:8px;font-size:.95rem}
.timeline-card p{margin-bottom:0;font-size:.9rem;color:var(--text-muted)}
@media(max-width:768px){.timeline-cards{grid-template-columns:1fr}}

/* --- Focus Styles (A11y) --- */
:focus-visible{outline:3px solid var(--sunset-warm);outline-offset:2px;border-radius:3px}

/* --- Layout --- */
.container{width:100%;max-width:var(--max-width);margin:0 auto;padding:0 24px}
main{flex:1;overflow:hidden}
section{padding:64px 0;overflow:hidden}
section+section{border-top:1px solid var(--border-light)}
section:nth-child(even){background:var(--surface-alt)}

/* --- Map Lines Decorative --- */
.map-lines{position:relative;overflow:hidden}
.map-lines::before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:
  repeating-linear-gradient(90deg,transparent,transparent 60px,rgba(232,135,60,.04) 60px,rgba(232,135,60,.04) 61px),
  repeating-linear-gradient(0deg,transparent,transparent 60px,rgba(232,135,60,.04) 60px,rgba(232,135,60,.04) 61px);
  pointer-events:none;z-index:0}
.map-lines>*{position:relative;z-index:1}

/* --- Header --- */
.site-header{background:linear-gradient(135deg,var(--sunset-dark) 0%,var(--sunset-deep) 50%,var(--sunset-sky) 100%);color:#fff;height:var(--header-h);position:fixed;top:0;left:0;right:0;z-index:100;box-shadow:0 2px 16px rgba(0,0,0,.3);border-bottom:1px solid rgba(242,178,84,.12)}
body{padding-top:var(--header-h)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:100%;max-width:var(--max-width);margin:0 auto;padding:0 24px}
.site-logo{font-size:1.25rem;font-weight:700;color:#fff;text-decoration:none;letter-spacing:.4px;position:relative;padding-left:14px}
.site-logo::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:22px;background:linear-gradient(180deg,var(--sunset-gold),var(--sunset-warm));border-radius:2px}
.site-logo:hover,.site-logo:focus-visible{color:var(--sunset-gold)}

/* --- Navigation --- */
.main-nav{display:flex;align-items:center}
.nav-list{list-style:none;display:flex;gap:2px;margin:0;padding:0}
.nav-list li{margin:0}
.nav-list a{color:rgba(255,255,255,.75);padding:9px 16px;border-radius:6px;font-size:.88rem;font-weight:500;transition:color .2s ease,background .2s ease;text-decoration:none;white-space:nowrap;position:relative}
.nav-list a:hover,.nav-list a:focus-visible{color:#fff;background:rgba(255,255,255,.1)}
.nav-list a.active{color:#fff;background:rgba(255,255,255,.08)}
.nav-list a.active::after{content:"";position:absolute;bottom:2px;left:50%;transform:translateX(-50%);width:20px;height:2px;background:var(--sunset-gold);border-radius:1px}

/* Mobile toggle — animated bars */
.nav-toggle{display:none;background:none;border:none;color:#fff;cursor:pointer;padding:8px;width:40px;height:40px;position:relative;border-radius:6px;transition:background .2s ease}
.nav-toggle:hover{background:rgba(255,255,255,.1)}
.nav-toggle .bar{display:block;width:22px;height:2px;background:#fff;border-radius:2px;position:absolute;left:9px;transition:transform .35s cubic-bezier(.22,.61,.36,1),opacity .25s ease}
.nav-toggle .bar:nth-child(1){top:12px}
.nav-toggle .bar:nth-child(2){top:19px}
.nav-toggle .bar:nth-child(3){top:26px}
.nav-toggle[aria-expanded="true"] .bar:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] .bar:nth-child(2){opacity:0;transform:translateX(-6px)}
.nav-toggle[aria-expanded="true"] .bar:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Mobile overlay */
.nav-overlay{position:fixed;inset:0;top:var(--header-h);background:rgba(0,0,0,.55);z-index:98;opacity:0;visibility:hidden;transition:opacity .4s ease,visibility .4s ease}
.nav-overlay.visible{opacity:1;visibility:visible}

@media(max-width:900px){
  .nav-toggle{display:block}
  .nav-list{position:fixed;top:var(--header-h);right:0;width:280px;height:calc(100vh - var(--header-h));background:linear-gradient(180deg,var(--sunset-dark) 0%,#0f0600 100%);flex-direction:column;padding:0;gap:0;box-shadow:-8px 0 32px rgba(0,0,0,.35);display:flex;transform:translateX(100%);transition:transform .4s cubic-bezier(.22,.61,.36,1);overflow-y:auto;z-index:99}
  .nav-list.open{transform:translateX(0)}
  .nav-list li{border-bottom:1px solid rgba(255,255,255,.06);opacity:0;transform:translateX(20px);transition:opacity .3s ease,transform .3s ease}
  .nav-list.open li{opacity:1;transform:translateX(0)}
  .nav-list.open li:nth-child(1){transition-delay:.05s}
  .nav-list.open li:nth-child(2){transition-delay:.08s}
  .nav-list.open li:nth-child(3){transition-delay:.11s}
  .nav-list.open li:nth-child(4){transition-delay:.14s}
  .nav-list.open li:nth-child(5){transition-delay:.17s}
  .nav-list.open li:nth-child(6){transition-delay:.20s}
  .nav-list.open li:nth-child(7){transition-delay:.23s}
  .nav-list.open li:nth-child(8){transition-delay:.26s}
  .nav-list a{padding:16px 24px;font-size:.95rem;border-radius:0;display:block}
  .nav-list a:hover,.nav-list a:focus-visible{background:rgba(255,255,255,.07)}
  .nav-list a.active{background:rgba(242,178,84,.1);border-left:3px solid var(--sunset-gold);padding-left:21px}
  .nav-list a.active::after{display:none}
}
@media(min-width:901px) and (max-width:1060px){
  .nav-list a{padding:8px 10px;font-size:.82rem}
}

/* --- Hero --- */
.hero{background:linear-gradient(160deg,var(--sunset-dark) 0%,var(--sunset-deep) 30%,var(--sunset-warm) 65%,var(--sunset-gold) 100%);color:#fff;padding:100px 0 80px;position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background:
  radial-gradient(ellipse 600px 400px at 20% 80%,rgba(242,178,84,.2),transparent),
  radial-gradient(ellipse 400px 300px at 80% 20%,rgba(92,45,130,.15),transparent);
  pointer-events:none}
.hero::after{content:"";position:absolute;bottom:0;left:0;right:0;height:80px;background:linear-gradient(to top,var(--sunset-cream),transparent);pointer-events:none}
.hero .container{position:relative;z-index:1}
.hero h1{color:#fff;font-size:clamp(2rem,5vw,3.2rem);margin-bottom:.75rem}
.hero p{color:rgba(255,255,255,.88);font-size:clamp(1rem,2vw,1.2rem);max-width:640px;margin-bottom:1.5rem}
.hero-subtitle{font-size:clamp(.9rem,1.5vw,1.05rem);color:rgba(255,255,255,.65);margin-bottom:2rem;max-width:500px}

/* --- Buttons --- */
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 28px;border-radius:var(--radius);font-size:.95rem;font-weight:600;cursor:pointer;border:none;transition:all var(--transition);text-decoration:none;line-height:1.4}
.btn-primary{background:linear-gradient(135deg,var(--sunset-warm),var(--sunset-orange));color:#fff;box-shadow:0 3px 12px rgba(232,93,38,.25)}
.btn-primary:hover,.btn-primary:focus-visible{background:linear-gradient(135deg,var(--sunset-deep),var(--sunset-warm));color:#fff;box-shadow:0 5px 20px rgba(232,93,38,.35);transform:translateY(-1px)}
.btn-secondary{background:transparent;color:var(--sunset-warm);border:2px solid var(--sunset-warm)}
.btn-secondary:hover,.btn-secondary:focus-visible{background:var(--sunset-warm);color:#fff}
.btn-hero{background:rgba(255,255,255,.15);color:#fff;border:2px solid rgba(255,255,255,.4);backdrop-filter:blur(4px)}
.btn-hero:hover,.btn-hero:focus-visible{background:rgba(255,255,255,.25);color:#fff}

/* --- Cards --- */
.card{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:32px 28px;box-shadow:var(--shadow-sm);transition:box-shadow .2s ease,transform .2s ease,border-color .2s ease}
.card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px);border-color:var(--sunset-gold)}
.card h3{color:var(--sunset-deep);padding-bottom:10px;margin-bottom:12px;border-bottom:2px solid var(--sunset-cream)}
.card p{font-size:.93rem}
.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:28px;margin-top:2rem}

/* --- Section Titles --- */
.section-title{text-align:center;margin-bottom:3rem}
.section-title h2{position:relative;display:inline-block;padding-bottom:14px}
.section-title h2::after{content:"";position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:50px;height:3px;background:linear-gradient(90deg,var(--sunset-warm),var(--sunset-gold));border-radius:2px}
.section-title p{color:var(--text-muted);max-width:580px;margin:1.1rem auto 0;font-size:.95rem;line-height:1.7}

/* --- Pricing Table --- */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:2rem 0;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:1px solid var(--border-light)}
.price-table{width:100%;min-width:600px;border-collapse:separate;border-spacing:0}
.price-table thead{background:linear-gradient(135deg,var(--sunset-deep),var(--sunset-warm))}
.price-table th{color:#fff;padding:18px 24px;text-align:left;font-weight:600;font-size:.93rem;letter-spacing:.2px}
.price-table td{padding:16px 24px;border-bottom:1px solid var(--border-light);font-size:.93rem}
.price-table tbody tr:last-child td{border-bottom:none}
.price-table tbody tr:nth-child(even){background:var(--surface-alt)}
.price-table tbody tr{transition:background .15s ease}
.price-table tbody tr:hover{background:var(--sunset-light)}
.price-range{font-weight:700;color:var(--sunset-deep);white-space:nowrap;font-size:1rem}
.price-disclaimer{background:linear-gradient(135deg,var(--sunset-cream),#fff);border-left:4px solid var(--sunset-gold);padding:20px 24px;border-radius:0 var(--radius) var(--radius) 0;margin:2rem 0;font-size:.92rem;color:var(--text-secondary);box-shadow:var(--shadow-sm)}

/* --- Kisi Sayisi Selector (Interactive) --- */
.guest-selector{background:linear-gradient(135deg,var(--sunset-cream),#fff);border:2px solid var(--sunset-gold);border-radius:var(--radius-lg);padding:40px 36px;margin:2.5rem 0;text-align:center;box-shadow:0 6px 24px rgba(242,178,84,.1)}
.guest-selector h3{color:var(--sunset-deep);margin-bottom:.6rem;font-size:1.3rem}
.guest-slider-wrap{max-width:500px;margin:0 auto 1.5rem}
.guest-slider-wrap label{display:block;font-weight:600;margin-bottom:.75rem;color:var(--text-primary)}
.guest-slider{-webkit-appearance:none;appearance:none;width:100%;height:8px;border-radius:4px;background:linear-gradient(90deg,var(--sunset-gold),var(--sunset-warm),var(--sunset-deep));outline:none;cursor:pointer}
.guest-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:26px;height:26px;border-radius:50%;background:#fff;border:3px solid var(--sunset-warm);box-shadow:var(--shadow-sm);cursor:pointer;transition:transform var(--transition)}
.guest-slider::-webkit-slider-thumb:hover{transform:scale(1.15)}
.guest-slider::-moz-range-thumb{width:26px;height:26px;border-radius:50%;background:#fff;border:3px solid var(--sunset-warm);box-shadow:var(--shadow-sm);cursor:pointer}
.guest-output{display:flex;justify-content:center;gap:20px;flex-wrap:wrap;margin-top:1.5rem}
.guest-output-item{text-align:center;background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius);padding:16px 24px;min-width:180px;box-shadow:var(--shadow-sm)}
.guest-output-item .label{display:block;font-size:.82rem;color:var(--text-muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.4px}
.guest-output-item .value{font-size:1.2rem;font-weight:700;color:var(--sunset-deep)}

/* --- FAQ / SSS --- */
.faq-list{max-width:800px;margin:0 auto}
.faq-item{border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:14px;background:var(--surface);overflow:hidden;box-shadow:var(--shadow-sm);transition:border-color .2s ease,box-shadow .2s ease}
.faq-item:hover{border-color:var(--sunset-gold)}
.faq-item[open]{border-color:var(--sunset-warm);box-shadow:0 4px 18px rgba(212,100,26,.08)}
.faq-item summary{padding:20px 24px;font-weight:600;cursor:pointer;list-style:none;display:flex;align-items:center;justify-content:space-between;gap:12px;color:var(--text-primary);transition:background .15s ease;font-size:.97rem}
.faq-item summary:hover{background:var(--sunset-cream)}
.faq-item summary::after{content:"+";font-size:1.3rem;color:var(--sunset-warm);font-weight:700;flex-shrink:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--sunset-cream);transition:transform .2s ease,background .2s ease}
.faq-item[open] summary::after{content:"\2212";background:var(--sunset-warm);color:#fff}
.faq-item summary::-webkit-details-marker{display:none}
.faq-answer{overflow:hidden;color:var(--text-secondary);line-height:1.75}
.faq-answer-inner{padding:0 24px 22px;border-top:1px solid var(--border-light);padding-top:16px}
.faq-answer-inner p{font-size:.93rem}
.faq-answer-inner a{text-decoration:underline;text-underline-offset:2px}

/* --- Process Steps --- */
.process-steps{counter-reset:step-counter}
.process-step{display:flex;gap:28px;margin-bottom:0;align-items:flex-start;padding:28px 0;border-bottom:1px solid var(--border-light)}
.process-step:last-child{border-bottom:none}
.step-number{counter-increment:step-counter;flex-shrink:0;width:54px;height:54px;border-radius:14px;background:linear-gradient(135deg,var(--sunset-warm),var(--sunset-gold));display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.2rem;color:var(--sunset-dark);box-shadow:0 4px 14px rgba(232,93,38,.18)}
.step-number::before{content:counter(step-counter)}
.step-content{flex:1}
.step-content h3{margin-bottom:.5rem;font-size:1.15rem}
.step-content p{font-size:.93rem}

/* --- Related Pages / Ilgili Sayfalar --- */
.related-pages{background:linear-gradient(135deg,var(--sunset-cream),#fff);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:28px 32px;margin-top:3rem}
.related-pages h3{color:var(--sunset-deep);margin-bottom:1rem;font-size:1.05rem;padding-bottom:.6rem;border-bottom:2px solid var(--sunset-gold);display:inline-block}
.related-links{display:flex;flex-wrap:wrap;gap:10px;list-style:none;margin:0;padding:0}
.related-links a{display:inline-block;padding:9px 20px;background:var(--surface);border:1px solid var(--border);border-radius:20px;font-size:.88rem;color:var(--sunset-warm);font-weight:500;transition:all .2s ease}
.related-links a:hover,.related-links a:focus-visible{background:var(--sunset-warm);color:#fff;border-color:var(--sunset-warm);transform:translateY(-1px);box-shadow:0 3px 10px rgba(232,93,38,.2)}

/* --- Contact Form --- */
.contact-form{max-width:600px}
.form-group{margin-bottom:1.25rem}
.form-group label{display:block;font-weight:600;margin-bottom:6px;color:var(--text-primary);font-size:.95rem}
.form-group label .required{color:#c0392b;margin-left:2px}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:12px 16px;border:1px solid var(--border);border-radius:var(--radius);font-size:.95rem;font-family:inherit;color:var(--text-primary);background:var(--surface);transition:border-color var(--transition),box-shadow var(--transition)}
.form-group input:focus,.form-group textarea:focus{border-color:var(--sunset-warm);box-shadow:0 0 0 3px rgba(232,93,38,.12);outline:none}
.form-group textarea{resize:vertical;min-height:120px}
.form-group .field-hint{font-size:.82rem;color:var(--text-muted);margin-top:4px}
.form-check{display:flex;align-items:flex-start;gap:10px;margin-bottom:1.25rem}
.form-check input[type="checkbox"]{margin-top:4px;accent-color:var(--sunset-warm);width:18px;height:18px;flex-shrink:0}
.form-check label{font-size:.9rem;color:var(--text-secondary);line-height:1.5}
.form-message{padding:14px 20px;border-radius:var(--radius);margin-top:1rem;font-size:.95rem;display:none}
.form-message.success{display:block;background:#e8f5e9;color:#2e7d32;border:1px solid #a5d6a7}
.form-message.error{display:block;background:#fce4ec;color:#c62828;border:1px solid #ef9a9a}
.hp-field{position:absolute;left:-9999px;opacity:0;height:0;width:0;overflow:hidden}

/* --- Contact Page --- */
.contact-section{padding:60px 0}
.contact-layout{display:grid;grid-template-columns:1.1fr .9fr;gap:56px;align-items:start}
.contact-form-wrap{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:40px;box-shadow:var(--shadow-md)}
.contact-form-wrap h2{margin-bottom:.5rem}
.contact-form-wrap>p{color:var(--text-muted);font-size:.92rem;margin-bottom:2rem}
.contact-sidebar{display:flex;flex-direction:column;gap:24px}
.contact-info-card{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:28px 24px;box-shadow:var(--shadow-sm)}
.contact-info-card h3{font-size:1.05rem;margin-bottom:1.2rem;color:var(--sunset-deep)}
.contact-info{display:grid;gap:20px}
.contact-info-item{display:flex;align-items:flex-start;gap:16px}
.contact-icon{width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg,var(--sunset-cream),#fff);border:1px solid var(--border-light);display:flex;align-items:center;justify-content:center;color:var(--sunset-warm);font-weight:700;font-size:1.1rem;flex-shrink:0}
.contact-info-item strong{display:block;font-size:.9rem;color:var(--text-primary);margin-bottom:2px}
.contact-info-item p{margin:0;font-size:.92rem;color:var(--text-secondary)}
.contact-cta-card{background:linear-gradient(135deg,var(--sunset-deep),var(--sunset-warm));border-radius:var(--radius-lg);padding:28px 24px;color:#fff}
.contact-cta-card h3{color:#fff;margin-bottom:.75rem;font-size:1.05rem}
.contact-cta-card p{color:rgba(255,255,255,.8);font-size:.92rem;margin-bottom:1.2rem}
.contact-cta-card .btn{background:rgba(255,255,255,.18);color:#fff;border:1px solid rgba(255,255,255,.35)}
.contact-cta-card .btn:hover{background:rgba(255,255,255,.3)}
@media(max-width:768px){
  .contact-layout{grid-template-columns:1fr;gap:32px}
  .contact-form-wrap{padding:24px 20px}
}

/* --- Footer --- */
.site-footer{background:linear-gradient(180deg,var(--sunset-dark),#0a0400);color:rgba(255,255,255,.7);padding:56px 0 0;border-top:3px solid var(--sunset-deep)}
.footer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:36px;margin-bottom:44px}
.footer-col h4{color:var(--sunset-gold);font-size:.9rem;margin-bottom:1.1rem;text-transform:uppercase;letter-spacing:.8px;padding-bottom:.6rem;border-bottom:1px solid rgba(255,255,255,.08)}
.footer-col p{font-size:.88rem;line-height:1.7;color:rgba(255,255,255,.55)}
.footer-col ul{list-style:none;padding:0;margin:0}
.footer-col li{margin-bottom:6px}
.footer-col a{color:rgba(255,255,255,.55);font-size:.88rem;transition:color .15s ease,padding-left .15s ease}
.footer-col a:hover,.footer-col a:focus-visible{color:var(--sunset-gold);padding-left:4px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:20px 0;text-align:center;font-size:.85rem;color:rgba(255,255,255,.4)}
.footer-bottom a{color:rgba(255,255,255,.5)}
.footer-bottom a:hover{color:var(--sunset-gold)}

/* --- Cookie Banner --- */
.cookie-banner{position:fixed;bottom:0;left:0;right:0;background:var(--sunset-dark);color:rgba(255,255,255,.9);padding:20px 24px;z-index:9999;box-shadow:0 -4px 20px rgba(0,0,0,.3);transform:translateY(100%);transition:transform .4s ease;display:none}
.cookie-banner.visible{display:block;transform:translateY(0)}
.cookie-banner-inner{max-width:var(--max-width);margin:0 auto;display:flex;flex-wrap:wrap;align-items:center;gap:16px}
.cookie-banner p{margin:0;font-size:.9rem;flex:1;min-width:200px}
.cookie-banner a{color:var(--sunset-gold)}
.cookie-buttons{display:flex;gap:10px;flex-wrap:wrap}
.cookie-btn{padding:10px 20px;border-radius:var(--radius);font-size:.9rem;font-weight:600;cursor:pointer;border:none;transition:all var(--transition)}
.cookie-btn-accept{background:var(--sunset-warm);color:#fff}
.cookie-btn-accept:hover{background:var(--sunset-deep)}
.cookie-btn-reject{background:rgba(255,255,255,.15);color:#fff;border:1px solid rgba(255,255,255,.3)}
.cookie-btn-reject:hover{background:rgba(255,255,255,.25)}
.cookie-btn-settings{background:transparent;color:rgba(255,255,255,.7);text-decoration:underline;padding:10px 12px}
.cookie-btn-settings:hover{color:#fff}

/* --- Cookie Settings Modal --- */
.cookie-settings-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:10000;display:none;align-items:center;justify-content:center;padding:24px}
.cookie-settings-overlay.visible{display:flex}
.cookie-settings-panel{background:var(--surface);border-radius:var(--radius-lg);max-width:520px;width:100%;max-height:80vh;overflow-y:auto;padding:32px;box-shadow:var(--shadow-lg)}
.cookie-settings-panel h3{color:var(--sunset-deep);margin-bottom:1.5rem}
.cookie-category{display:flex;align-items:center;justify-content:space-between;padding:14px 0;border-bottom:1px solid var(--border-light)}
.cookie-category:last-child{border-bottom:none}
.cookie-category-info{flex:1}
.cookie-category-info strong{display:block;margin-bottom:2px}
.cookie-category-info span{font-size:.85rem;color:var(--text-muted)}
.cookie-toggle{position:relative;width:48px;height:26px;flex-shrink:0;margin-left:12px}
.cookie-toggle input{opacity:0;width:0;height:0;position:absolute}
.cookie-toggle .slider{position:absolute;inset:0;background:#ccc;border-radius:13px;cursor:pointer;transition:background var(--transition)}
.cookie-toggle .slider::before{content:"";position:absolute;left:3px;top:3px;width:20px;height:20px;border-radius:50%;background:#fff;transition:transform var(--transition)}
.cookie-toggle input:checked+.slider{background:var(--sunset-warm)}
.cookie-toggle input:checked+.slider::before{transform:translateX(22px)}
.cookie-toggle input:disabled+.slider{opacity:.6;cursor:not-allowed}
.cookie-settings-actions{display:flex;gap:10px;margin-top:1.5rem;justify-content:flex-end}

/* --- Page Header (inner pages) --- */
.page-header{background:linear-gradient(135deg,var(--sunset-dark) 0%,var(--sunset-deep) 55%,var(--sunset-warm) 100%);color:#fff;padding:60px 0 52px;position:relative;overflow:hidden}
.page-header::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 500px 300px at 85% 60%,rgba(242,178,84,.12),transparent);pointer-events:none}
.page-header::after{content:"";position:absolute;bottom:0;left:0;right:0;height:60px;background:linear-gradient(to top,var(--sunset-cream),transparent);pointer-events:none}
.page-header .container{position:relative;z-index:1}
.page-header h1{color:#fff;margin-bottom:.6rem;font-size:clamp(1.6rem,4vw,2.4rem)}
.page-header p{color:rgba(255,255,255,.8);max-width:620px;font-size:clamp(.92rem,1.5vw,1.05rem);line-height:1.6}
.breadcrumb{list-style:none;display:flex;gap:8px;margin:0 0 1.2rem;padding:0;font-size:.84rem}
.breadcrumb li+li::before{content:"/";margin-right:8px;color:rgba(255,255,255,.3)}
.breadcrumb a{color:rgba(255,255,255,.55);transition:color .15s ease}
.breadcrumb a:hover{color:#fff}

/* --- Legal Pages --- */
.legal-content{max-width:800px;background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:40px 44px;box-shadow:var(--shadow-sm)}
.legal-content h2{margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid var(--border-light);position:relative;padding-left:16px}
.legal-content h2::before{content:"";position:absolute;left:0;top:calc(1.5rem + 4px);bottom:4px;width:3px;background:linear-gradient(180deg,var(--sunset-warm),var(--sunset-gold));border-radius:2px}
.legal-content h2:first-child{border-top:none;margin-top:0;padding-top:0}
.legal-content h2:first-child::before{top:4px}
.legal-content p,.legal-content li{font-size:.93rem;line-height:1.75}
.legal-content ul{padding-left:1.2rem}
.legal-content ul li{padding:4px 0}
@media(max-width:768px){.legal-content{padding:24px 20px}}

/* --- Sitemap Page --- */
.sitemap-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:32px}
.sitemap-col{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:28px 24px;box-shadow:var(--shadow-sm)}
.sitemap-col h3{color:var(--sunset-deep);margin-bottom:1rem;padding-bottom:.6rem;border-bottom:2px solid var(--sunset-gold)}
.sitemap-col ul{list-style:none;padding:0;margin:0}
.sitemap-col li{margin-bottom:8px}
.sitemap-col a{font-size:.93rem;display:inline-block;padding:4px 0;transition:padding-left .15s ease,color .15s ease}
.sitemap-col a:hover{padding-left:6px}

/* --- 404 Page --- */
.error-page{text-align:center;padding:100px 0}
.error-code{font-size:clamp(5rem,15vw,9rem);font-weight:800;background:linear-gradient(135deg,var(--sunset-warm),var(--sunset-gold));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;margin-bottom:.5rem}
.error-page h1{margin-bottom:.75rem}
.error-page p{max-width:440px;margin:0 auto 1.5rem;font-size:1rem}

/* --- Two Column Layout --- */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.two-col h3{position:relative;padding-left:16px}
.two-col h3::before{content:"";position:absolute;left:0;top:4px;width:3px;height:calc(100% - 8px);background:linear-gradient(180deg,var(--sunset-warm),var(--sunset-gold));border-radius:2px}
@media(max-width:768px){.two-col{grid-template-columns:1fr;gap:32px}}

/* --- Responsive --- */
@media(max-width:768px){
  section{padding:40px 0}
  .hero{padding:72px 0 56px}
  .card-grid{grid-template-columns:1fr}
  .process-step{flex-direction:column;align-items:center;text-align:center}
  .price-table{font-size:.85rem}
  .price-table th,.price-table td{padding:10px 14px}
  .footer-grid{grid-template-columns:1fr}
  .guest-output{flex-direction:column;gap:16px}
  .cookie-banner-inner{flex-direction:column;text-align:center}
  .related-pages{padding:20px 20px}
}

/* --- Utility --- */
.text-center{text-align:center}
.mt-1{margin-top:1rem}
.mt-2{margin-top:2rem}
.mb-1{margin-bottom:1rem}
.mb-2{margin-bottom:2rem}
.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}

/* --- Content Images --- */
.content-img{border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);width:100%;height:auto;display:block}
.img-text-row{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;margin:2.5rem 0}
.img-text-row.reverse{direction:rtl}
.img-text-row.reverse>*{direction:ltr}
.img-text-row .img-col{overflow:hidden;border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}
.img-text-row .img-col img{width:100%;height:auto;display:block;border-radius:var(--radius-lg);object-fit:cover;aspect-ratio:4/3;transition:transform .3s ease}
.img-text-row .img-col:hover img{transform:scale(1.03)}
.img-text-row .text-col h2{margin-top:0}
.img-text-row .text-col h3{margin-top:0}
.img-text-row .text-col p{font-size:.94rem}
@media(max-width:768px){
  .img-text-row{grid-template-columns:1fr;gap:24px}
  .img-text-row.reverse{direction:ltr}
  .img-text-row .img-col{max-width:480px}
}

/* ===========================================================
   SKY FALL ANIMATION — letters fall from far above the screen
   =========================================================== */

/* Hide all animatable text via CSS until JS splits & drops them.
   This prevents the flash of unstyled text before animation starts. */
.hero h1,
.hero p,
.hero .hero-subtitle,
.page-header h1,
.page-header p,
main section h2,
main section h3,
main section > .container > p,
.text-col p,
.text-col h2,
.step-content p,
.step-content h3,
.scenario-box p,
.two-col > div > p,
.two-col > div > h3,
.card,
.process-step,
.info-list-item,
.timeline-card,
.guest-selector,
.table-wrap,
.related-pages,
.faq-item,
.contact-form-wrap,
.contact-info-card,
.contact-cta-card,
.scenario-box,
.content-highlight,
.legal-content,
.sitemap-col,
.img-text-row{
  opacity:0;
}

/* Letter spans */
.sky-letter{display:inline-block;opacity:0;will-change:transform,opacity}
.sky-landed{opacity:1!important;transform:none!important;will-change:auto}

/* Animated block done — ensure visible */
.sky-block-done{opacity:1!important;transform:none!important}

/* prefers-reduced-motion or no-JS: show everything */
.no-skyfall *{opacity:1!important;transform:none!important}
noscript ~ main *{opacity:1!important;transform:none!important}

