/* ===== CUSTOM PROPERTIES ===== */
:root{
  --clr-earth:#a0522d;
  --clr-earth-deep:#7a3b1e;
  --clr-earth-light:#c97a50;
  --clr-gold:#c7963e;
  --clr-gold-light:#e8c87a;
  --clr-sand:#faf4eb;
  --clr-sand-dark:#f0e6d6;
  --clr-indigo:#2b3a5e;
  --clr-indigo-deep:#1c2840;
  --clr-teal:#1a6b6a;
  --clr-teal-light:#2a8f8e;
  --clr-cream:#fffdf8;
  --clr-text:#3a2e24;
  --clr-text-soft:#6b5d52;
  --clr-border:rgba(167,130,90,.15);
  --clr-spring:#5a9e6f;
  --clr-summer:#d4853a;
  --clr-autumn:#b85c38;
  --clr-winter:#4a6fa5;
  --radius:14px;
  --shadow-soft:0 4px 24px rgba(90,60,30,.08);
  --shadow-hover:0 12px 40px rgba(90,60,30,.14);
  --font-main:'Segoe UI',Tahoma,Geneva,Verdana,sans-serif;
  --font-display:Georgia,'Times New Roman',serif;
}

/* ===== RESET & BASE ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px;-webkit-text-size-adjust:100%;overflow-x:hidden}
body{font-family:var(--font-main);line-height:1.7;color:var(--clr-text);background:var(--clr-cream);overflow-x:hidden;position:relative;padding-top:68px}
img,svg{display:block;max-width:100%}
a{color:var(--clr-earth);text-decoration:none;transition:color .25s}
a:hover{color:var(--clr-earth-deep)}
ul,ol{list-style:none}

/* ===== SKIP LINK ===== */
.skip-link{position:absolute;top:-100%;left:16px;background:var(--clr-indigo);color:#fff;padding:8px 18px;border-radius:0 0 8px 8px;z-index:10000;font-size:.9rem;transition:top .2s}
.skip-link:focus{top:0}

/* ===== LAYOUT ===== */
.container{max-width:1140px;margin:0 auto;padding:0 24px}
.section{padding:90px 0;position:relative}
.section--alt{background:var(--clr-sand)}

/* ===== SECTION DIVIDER ===== */
.section::before{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:60px;height:3px;background:linear-gradient(90deg,transparent,var(--clr-gold),transparent);border-radius:2px}
.section:first-child::before,.hero+.section::before{display:none}

/* ===== HEADER ===== */
.header{position:fixed;top:0;left:0;right:0;z-index:900;background:rgba(255,253,248,.88);backdrop-filter:blur(14px);border-bottom:1px solid var(--clr-border);transition:box-shadow .4s,background .4s}
.header--scrolled{box-shadow:0 2px 28px rgba(90,60,30,.1);background:rgba(255,253,248,.96)}
.header__inner{display:flex;align-items:center;justify-content:space-between;height:68px}
.header__logo{font-family:var(--font-display);font-size:1.3rem;font-weight:700;color:var(--clr-earth);letter-spacing:-.3px;transition:transform .3s,opacity .3s}
.header__logo:hover{transform:scale(1.06);opacity:.85}
.header__logo span{color:var(--clr-gold);transition:color .3s}
.header__logo:hover span{color:var(--clr-earth-light)}
.header__nav{display:flex;gap:24px;align-items:center}
.header__nav a{font-size:.84rem;font-weight:500;color:var(--clr-text-soft);transition:color .25s;white-space:nowrap;position:relative;padding:4px 0}
.header__nav a::after{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--clr-gold);border-radius:1px;transition:width .3s ease}
.header__nav a:hover{color:var(--clr-earth)}
.header__nav a:hover::after,.header__nav a.active::after{width:100%}
.header__nav a.active{color:var(--clr-earth);font-weight:600}

/* Hamburger */
.header__burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}
.header__burger span{display:block;width:24px;height:2px;background:var(--clr-text);border-radius:2px;transition:transform .35s,opacity .25s}
.header__burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.header__burger.open span:nth-child(2){opacity:0}
.header__burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Mobile nav backdrop */
.header__backdrop{display:none}

@media(max-width:768px){
  .header__nav{position:fixed;top:68px;left:0;right:0;height:calc(100vh - 68px);height:calc(100dvh - 68px);width:100%;flex-direction:column;justify-content:flex-start;align-items:stretch;background:var(--clr-cream);padding:0;gap:0;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility 0s .3s;z-index:950;overflow-y:auto;overscroll-behavior:contain}
  .header__nav.open{opacity:1;visibility:visible;transition:opacity .3s ease,visibility 0s 0s}
  .header__nav a{padding:16px 28px;font-size:1.1rem;border-bottom:1px solid var(--clr-border);text-align:center;flex-shrink:0}
  .header__nav a:last-child{border-bottom:none}
  .header__nav a::after{display:none}
  .header__burger{display:flex;z-index:960;position:relative}
  html.menu-open,body.menu-open{overflow:hidden!important;height:100%!important}
  body.menu-open{position:fixed;width:100%;touch-action:none}
  body.menu-open .header{z-index:970}
}

/* ===== HERO ===== */
.hero{position:relative;min-height:580px;display:flex;align-items:center;overflow:hidden}
.hero__bg{position:absolute;inset:0;z-index:0}
.hero__bg--spring{background:linear-gradient(135deg,#e8f0d4 0%,#d4e8c2 30%,#f5ebd0 60%,#e0d8c4 100%)}
.hero__bg--summer{background:linear-gradient(135deg,#f5e0c0 0%,#ecc88a 30%,#f0d0a0 60%,#e8c890 100%)}
.hero__bg--autumn{background:linear-gradient(135deg,#e8d0b0 0%,#d4a878 30%,#c89060 60%,#dab890 100%)}
.hero__bg--winter{background:linear-gradient(135deg,#d0dce8 0%,#b8c8d8 30%,#c0c8d0 60%,#d8dce0 100%)}
.hero__bg--default{background:linear-gradient(135deg,#f0e6d6 0%,#e8d8c0 30%,#dcc8a8 60%,#e8dcc8 100%)}
.hero__overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(135deg,rgba(43,58,94,.12) 0%,rgba(160,82,45,.06) 100%)}
.hero__particles{position:absolute;inset:0;z-index:1;overflow:hidden;pointer-events:none}
.hero__route{position:absolute;inset:0;z-index:2;opacity:.08;overflow:hidden}
.hero__content{position:relative;z-index:3;max-width:640px}
.hero__title{font-family:var(--font-display);font-size:clamp(2.2rem,5.5vw,3.6rem);font-weight:700;line-height:1.12;color:var(--clr-indigo-deep);margin-bottom:20px;letter-spacing:-.5px}
.hero__subtitle{font-size:1.1rem;color:var(--clr-text-soft);margin-bottom:36px;max-width:520px;line-height:1.75}
.hero__cta{display:inline-flex;align-items:center;gap:10px;background:linear-gradient(135deg,var(--clr-earth),var(--clr-earth-deep));color:#fff;padding:15px 34px;border-radius:10px;font-weight:600;font-size:.95rem;transition:transform .2s,box-shadow .3s;box-shadow:0 4px 16px rgba(160,82,45,.25)}
.hero__cta:hover{color:#fff;transform:translateY(-2px);box-shadow:0 8px 28px rgba(160,82,45,.35)}

/* ===== SEASON CARDS ===== */
.seasons{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:28px;margin-top:48px}
.season-card{border-radius:var(--radius);padding:36px 28px;position:relative;overflow:hidden;transition:transform .4s cubic-bezier(.4,0,.2,1),box-shadow .4s;border:1px solid transparent}
.season-card::before{content:'';position:absolute;top:0;right:0;width:120px;height:120px;border-radius:50%;opacity:.08;transition:transform .6s,opacity .4s}
.season-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-hover)}
.season-card:hover::before{transform:scale(1.8);opacity:.12}
.season-card--spring{background:linear-gradient(160deg,#eef5e0 0%,#dae8c8 100%);border-color:rgba(90,158,111,.15)}
.season-card--spring::before{background:var(--clr-spring);top:-20px;right:-20px}
.season-card--summer{background:linear-gradient(160deg,#fdf0dc 0%,#f5dbb8 100%);border-color:rgba(212,133,58,.15)}
.season-card--summer::before{background:var(--clr-summer);top:-20px;right:-20px}
.season-card--autumn{background:linear-gradient(160deg,#f5e0cc 0%,#e8c8a8 100%);border-color:rgba(184,92,56,.15)}
.season-card--autumn::before{background:var(--clr-autumn);top:-20px;right:-20px}
.season-card--winter{background:linear-gradient(160deg,#dce4f0 0%,#c8d4e4 100%);border-color:rgba(74,111,165,.15)}
.season-card--winter::before{background:var(--clr-winter);top:-20px;right:-20px}
.season-card__icon{width:48px;height:48px;margin-bottom:18px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}
.season-card__title{font-family:var(--font-display);font-size:1.2rem;font-weight:700;margin-bottom:10px;color:var(--clr-indigo-deep)}
.season-card__text{font-size:.9rem;color:var(--clr-text-soft);line-height:1.7}

/* ===== PLACEHOLDER PANELS ===== */
.visual-panel{border-radius:var(--radius);overflow:hidden;position:relative;min-height:200px;box-shadow:var(--shadow-soft)}
.visual-panel--gradient-spring{background:linear-gradient(135deg,#8fbc8f,#a8c89a,#d4c890,#c8b878)}
.visual-panel--gradient-summer{background:linear-gradient(135deg,#d4a050,#c89060,#e8a850,#d4b870)}
.visual-panel--gradient-autumn{background:linear-gradient(135deg,#b85c38,#c87850,#a86030,#d4a070)}
.visual-panel--gradient-winter{background:linear-gradient(135deg,#6888a8,#8098b0,#5878a0,#90a8c0)}
.visual-panel__wind{position:absolute;inset:0;overflow:hidden}
.visual-panel__wave{position:absolute;bottom:0;left:0;right:0;height:60px}

/* ===== MEVSIM SECICI ===== */
.selector{background:var(--clr-cream);border-radius:var(--radius);padding:40px;box-shadow:var(--shadow-soft);border:1px solid var(--clr-border);position:relative;overflow:hidden}
.selector::before{content:'';position:absolute;top:-60px;right:-60px;width:180px;height:180px;border-radius:50%;background:linear-gradient(135deg,rgba(199,150,62,.08),rgba(160,82,45,.04));pointer-events:none}
.selector__row{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:28px}
.selector__btn{padding:11px 24px;border-radius:8px;border:2px solid var(--clr-border);background:var(--clr-cream);font-size:.88rem;font-weight:600;cursor:pointer;transition:all .25s;color:var(--clr-text-soft)}
.selector__btn:hover{border-color:var(--clr-earth-light);color:var(--clr-earth);background:rgba(160,82,45,.04)}
.selector__btn.active{background:linear-gradient(135deg,var(--clr-earth),var(--clr-earth-deep));color:#fff;border-color:var(--clr-earth);box-shadow:0 4px 12px rgba(160,82,45,.2)}
.selector__label{font-family:var(--font-display);font-weight:700;font-size:.95rem;margin-bottom:12px;color:var(--clr-indigo-deep);display:block}
.selector__result{margin-top:28px;padding:28px;border-radius:12px;background:var(--clr-sand);border:1px solid var(--clr-border);min-height:100px}
.selector__result h4{font-family:var(--font-display);font-size:1.08rem;margin-bottom:12px;color:var(--clr-earth)}
.selector__result p{font-size:.9rem;color:var(--clr-text-soft);line-height:1.75}

/* ===== COMFORT SECTION ===== */
.comfort-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px}
.comfort-item{background:var(--clr-cream);border-radius:var(--radius);padding:32px 26px;border:1px solid var(--clr-border);transition:transform .3s,box-shadow .4s;position:relative;overflow:hidden}
.comfort-item::after{content:'';position:absolute;top:0;left:0;width:4px;height:0;background:linear-gradient(180deg,var(--clr-gold),var(--clr-earth-light));border-radius:0 2px 2px 0;transition:height .4s}
.comfort-item:hover{transform:translateY(-3px);box-shadow:var(--shadow-hover)}
.comfort-item:hover::after{height:100%}
.comfort-item__title{font-family:var(--font-display);font-size:1.05rem;font-weight:700;margin-bottom:10px;color:var(--clr-indigo-deep)}
.comfort-item__text{font-size:.9rem;color:var(--clr-text-soft);line-height:1.7}

/* ===== FAQ ===== */
.faq-item{border-bottom:1px solid var(--clr-border);padding:22px 0}
.faq-item:last-child{border-bottom:none}
.faq-question{width:100%;display:flex;justify-content:space-between;align-items:center;background:none;border:none;cursor:pointer;text-align:left;font-size:1rem;font-weight:600;color:var(--clr-text);padding:4px 0;gap:16px;transition:color .25s}
.faq-question:hover{color:var(--clr-earth)}
.faq-question:focus-visible{outline:2px solid var(--clr-gold);outline-offset:2px;border-radius:4px}
.faq-question__icon{flex-shrink:0;width:28px;height:28px;transition:transform .35s;background:var(--clr-sand);border-radius:50%;padding:4px}
.faq-question__icon line{stroke:var(--clr-earth);stroke-width:2}
.faq-item.open .faq-question__icon{transform:rotate(45deg);background:var(--clr-earth)}
.faq-item.open .faq-question__icon line{stroke:#fff}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .45s ease,padding .35s;padding:0 0}
.faq-item.open .faq-answer{max-height:600px;padding:14px 0 4px}
.faq-answer p{font-size:.92rem;color:var(--clr-text-soft);line-height:1.75}

/* ===== FOOTER ===== */
.footer{background:var(--clr-indigo-deep);color:#c0b8a8;padding:64px 0 28px;position:relative;overflow:hidden}
.footer::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--clr-earth),var(--clr-gold),var(--clr-teal),var(--clr-winter))}
.footer__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:40px;margin-bottom:40px}
.footer__col h4{color:var(--clr-gold-light);font-family:var(--font-display);font-size:.95rem;margin-bottom:16px}
.footer__col a{display:block;color:#a09888;font-size:.88rem;margin-bottom:8px;transition:color .25s}
.footer__col a:hover{color:var(--clr-gold-light)}
.footer__col p{font-size:.88rem;line-height:1.6}
.footer__bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:24px;display:flex;flex-wrap:wrap;justify-content:space-between;gap:12px;font-size:.82rem;color:#80786c}

/* ===== INNER PAGES ===== */
.page-header{padding:48px 0 44px;background:linear-gradient(135deg,var(--clr-sand) 0%,var(--clr-sand-dark) 50%,#e0d0b8 100%);position:relative;overflow:hidden}
.page-header::after{content:'';position:absolute;bottom:0;left:0;right:0;height:60px;background:linear-gradient(180deg,transparent,var(--clr-cream))}
.page-header h1{font-family:var(--font-display);font-size:clamp(1.6rem,4vw,2.4rem);font-weight:700;color:var(--clr-indigo-deep);position:relative;z-index:1}
.page-content{padding:48px 0 80px}
.page-content h2{font-family:var(--font-display);font-size:1.3rem;font-weight:700;margin:36px 0 14px;color:var(--clr-indigo-deep)}
.page-content h3{font-size:1.05rem;font-weight:600;margin:24px 0 8px;color:var(--clr-earth)}
.page-content p{font-size:.93rem;color:var(--clr-text-soft);margin-bottom:16px;line-height:1.78}
.page-content ul{margin:0 0 16px 20px;list-style:disc}
.page-content ul li{font-size:.93rem;color:var(--clr-text-soft);margin-bottom:6px;line-height:1.7}
.page-content a{text-decoration:underline;text-decoration-color:var(--clr-gold-light);text-underline-offset:3px}

/* ===== CONTACT CARDS ===== */
.contact-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px}
.contact-card{display:flex;align-items:center;gap:18px;background:var(--clr-cream);border:1px solid var(--clr-border);border-radius:var(--radius);padding:22px 24px;transition:transform .3s,box-shadow .3s}
.contact-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-hover)}
.contact-card__icon{flex-shrink:0;width:44px;height:44px;border-radius:10px;background:linear-gradient(135deg,var(--clr-earth),var(--clr-earth-deep));color:#fff;display:flex;align-items:center;justify-content:center;padding:10px}
.contact-card__icon svg{width:100%;height:100%}
.contact-card__body{display:flex;flex-direction:column;gap:2px}
.contact-card__body strong{font-family:var(--font-display);font-size:.88rem;color:var(--clr-indigo-deep)}
.contact-card__body span{font-size:.9rem;color:var(--clr-text-soft)}

/* ===== CONTACT FORM ===== */

.form-group{margin-bottom:22px}
.form-group label{display:block;font-size:.88rem;font-weight:600;margin-bottom:6px;color:var(--clr-text)}
.form-group label .req{color:#b44;font-weight:700}
.form-group input,.form-group textarea{width:100%;padding:13px 16px;border:1px solid var(--clr-border);border-radius:10px;font-size:.93rem;font-family:inherit;transition:border-color .3s,box-shadow .3s;background:var(--clr-cream)}
.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--clr-earth-light);box-shadow:0 0 0 3px rgba(160,82,45,.1)}
.form-group textarea{min-height:120px;resize:vertical}
.form-checkbox{display:flex;gap:10px;align-items:flex-start;margin-bottom:22px}
.form-checkbox input[type="checkbox"]{margin-top:4px;accent-color:var(--clr-earth)}
.form-checkbox label{font-size:.84rem;color:var(--clr-text-soft);line-height:1.5}
.form-submit{background:linear-gradient(135deg,var(--clr-earth),var(--clr-earth-deep));color:#fff;border:none;padding:14px 38px;border-radius:10px;font-size:.95rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .3s;box-shadow:0 4px 14px rgba(160,82,45,.2)}
.form-submit:hover{transform:translateY(-2px);box-shadow:0 6px 22px rgba(160,82,45,.3)}
.form-submit:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}
.form-message{margin-top:16px;padding:14px 18px;border-radius:10px;font-size:.9rem;display:none}
.form-message--success{display:block;background:#ecf5e0;color:#3a6b22;border:1px solid #b8d8a0}
.form-message--error{display:block;background:#fdf0e8;color:#9a3a22;border:1px solid #e0b0a0}

/* Honeypot */
.form-hp{position:absolute;left:-9999px;top:-9999px;opacity:0;height:0;width:0;overflow:hidden}

/* ===== CONTENT WITH IMAGE ===== */
.content-media{display:flex;gap:32px;align-items:flex-start;margin:36px 0}
.content-media--reverse{flex-direction:row-reverse}
.content-media img{width:280px;max-width:100%;border-radius:var(--radius);flex-shrink:0;height:auto;object-fit:cover;box-shadow:var(--shadow-soft);border:3px solid rgba(199,150,62,.12)}
.content-media__text{flex:1;min-width:220px}
.content-media__text p{font-size:.93rem;color:var(--clr-text-soft);line-height:1.78;margin-bottom:12px}
.content-media__text h3{font-family:var(--font-display);font-size:1.1rem;font-weight:700;margin-bottom:12px;color:var(--clr-indigo-deep)}
@media(max-width:640px){.content-media,.content-media--reverse{flex-direction:column}.content-media img{width:100%;max-height:220px}}

/* ===== FORM STANDALONE ===== */
.form-standalone{background:var(--clr-cream);border-radius:var(--radius);padding:44px 40px;box-shadow:var(--shadow-soft);border:1px solid var(--clr-border);max-width:640px;margin:0 auto;position:relative;overflow:hidden}
.form-standalone::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--clr-earth),var(--clr-gold))}
.form-standalone__title{font-family:var(--font-display);font-size:1.25rem;font-weight:700;margin-bottom:8px;color:var(--clr-indigo-deep)}
.form-standalone__desc{font-size:.9rem;color:var(--clr-text-soft);margin-bottom:28px;line-height:1.6}

/* ===== SITEMAP PAGE ===== */
.sitemap-list{list-style:none;margin:0;padding:0}
.sitemap-list li{margin-bottom:12px;padding-left:18px;position:relative}
.sitemap-list li::before{content:'';position:absolute;left:0;top:10px;width:6px;height:6px;border-radius:50%;background:var(--clr-gold)}
.sitemap-list a{font-size:.95rem}

/* ===== COOKIE BANNER ===== */
.cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:9999;background:var(--clr-indigo-deep);color:#d8d0c0;padding:22px 24px;transform:translateY(100%);transition:transform .45s cubic-bezier(.4,0,.2,1);box-shadow:0 -4px 30px rgba(28,40,64,.3)}
.cookie-banner.visible{transform:translateY(0)}
.cookie-banner__inner{max-width:1140px;margin:0 auto}
.cookie-banner__text{font-size:.88rem;line-height:1.65;margin-bottom:16px}
.cookie-banner__text a{color:var(--clr-gold-light);text-decoration:underline}
.cookie-banner__actions{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:12px}
.cookie-banner__btn{padding:10px 22px;border-radius:8px;font-size:.85rem;font-weight:600;border:none;cursor:pointer;transition:all .25s}
.cookie-banner__btn--accept{background:linear-gradient(135deg,var(--clr-earth),var(--clr-earth-deep));color:#fff;box-shadow:0 2px 10px rgba(160,82,45,.25)}
.cookie-banner__btn--accept:hover{transform:translateY(-1px);box-shadow:0 4px 16px rgba(160,82,45,.35)}
.cookie-banner__btn--reject{background:rgba(255,255,255,.1);color:#d0c8b8}
.cookie-banner__btn--reject:hover{background:rgba(255,255,255,.18)}
.cookie-banner__btn--settings{background:transparent;color:#a09888;border:1px solid rgba(255,255,255,.15)}
.cookie-banner__btn--settings:hover{border-color:rgba(255,255,255,.3);color:#d0c8b8}
.cookie-settings{display:none;margin-top:14px;padding:18px;background:rgba(255,255,255,.05);border-radius:10px;border:1px solid rgba(255,255,255,.06)}
.cookie-settings.visible{display:block}
.cookie-settings__item{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid rgba(255,255,255,.06)}
.cookie-settings__item:last-child{border-bottom:none}
.cookie-settings__item label{font-size:.85rem;color:#c0b8a8}
.cookie-settings__item input[type="checkbox"]{accent-color:var(--clr-gold)}
.cookie-settings__save{margin-top:14px;padding:9px 22px;background:var(--clr-earth);color:#fff;border:none;border-radius:8px;font-size:.84rem;cursor:pointer;transition:background .2s}
.cookie-settings__save:hover{background:var(--clr-earth-deep)}

/* ===== ANIMATIONS ===== */
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes driftBg{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
@keyframes floatParticle{0%{transform:translateY(0) translateX(0);opacity:0}10%{opacity:.6}90%{opacity:.6}100%{transform:translateY(-500px) translateX(80px);opacity:0}}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
@keyframes pulseGlow{0%,100%{opacity:.4}50%{opacity:.8}}

.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s cubic-bezier(.4,0,.2,1),transform .8s cubic-bezier(.4,0,.2,1)}
.reveal.visible{opacity:1;transform:translateY(0)}

.hero__bg{background-size:200% 200%;animation:driftBg 25s ease infinite}

/* Hero particles */
.particle{position:absolute;width:4px;height:4px;border-radius:50%;background:var(--clr-gold);opacity:0;animation:floatParticle linear infinite;pointer-events:none}

/* ===== REDUCED MOTION ===== */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:0s!important;animation-delay:0s!important;transition-duration:0s!important;scroll-behavior:auto!important}
  .hero__bg{animation:none}
  .reveal{opacity:1;transform:none}
  .particle{display:none}
}

/* ===== SECTION HEADINGS ===== */
.section__title{font-family:var(--font-display);font-size:clamp(1.5rem,3.5vw,2.1rem);font-weight:700;margin-bottom:14px;color:var(--clr-indigo-deep);position:relative;display:inline-block}
.section__title::after{content:'';display:block;width:40px;height:3px;background:linear-gradient(90deg,var(--clr-gold),var(--clr-earth-light));border-radius:2px;margin-top:10px}
.section__subtitle{font-size:1rem;color:var(--clr-text-soft);margin-bottom:44px;max-width:580px;line-height:1.75}

/* ===== INLINE SVG ICONS ===== */
.icon-svg{display:inline-block;vertical-align:middle}

/* ===== ROUTE LINES ===== */
.route-line{position:absolute;stroke:var(--clr-earth);stroke-width:1.5;fill:none;opacity:.1}

/* ===== 404 ===== */
.error-page{min-height:60vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:80px 24px}
.error-page h1{font-family:var(--font-display);font-size:clamp(4rem,10vw,8rem);font-weight:700;color:var(--clr-earth);line-height:1;text-shadow:0 4px 20px rgba(160,82,45,.15)}
.error-page p{font-size:1.1rem;color:var(--clr-text-soft);margin:16px 0 32px}
.error-page a{background:linear-gradient(135deg,var(--clr-earth),var(--clr-earth-deep));color:#fff;padding:13px 30px;border-radius:10px;font-weight:600;transition:transform .2s,box-shadow .3s;box-shadow:0 4px 14px rgba(160,82,45,.2)}
.error-page a:hover{color:#fff;transform:translateY(-2px);box-shadow:0 6px 22px rgba(160,82,45,.3)}

/* ===== FOCUS STYLES ===== */
:focus-visible{outline:2px solid var(--clr-gold);outline-offset:3px;border-radius:4px}
button:focus-visible{outline:2px solid var(--clr-gold);outline-offset:3px}

/* ===== SEASONAL TEXT ACCENTS ===== */
.clr-spring{color:var(--clr-spring)!important}
.clr-summer{color:var(--clr-summer)!important}
.clr-autumn{color:var(--clr-autumn)!important}
.clr-winter{color:var(--clr-winter)!important}
