@charset "UTF-8";
/* ============================================================
   Bodrum Daily Boat Trip — Premium Design System
   Brand: Güneş Tekne · Tone: poetic, refined, Aegean luxury
   Palette: deep navy + gold + cream
   ============================================================ */

/* ===== 1. RESET ============================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent;scroll-behavior:smooth;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
body{font-family:var(--font-body);font-size:var(--text-base);line-height:1.65;color:var(--color-text);background:var(--color-bg);overflow-x:hidden;min-height:100dvh;font-weight:400;width:100%;max-width:100vw}
img,picture,video,svg{display:block;max-width:100%;height:auto}
a{color:var(--color-primary);text-decoration:none;transition:color .2s ease}
a:hover{color:var(--color-gold)}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}
ul,ol{list-style:none}
:focus-visible{outline:2px solid var(--color-gold);outline-offset:3px;border-radius:2px}
::selection{background:var(--color-gold);color:var(--color-primary-dark)}

/* ===== 2. TOKENS — premium palette ========================= */
:root{
  --color-primary:        #0a2540;   /* deep navy */
  --color-primary-dark:   #051529;
  --color-primary-mid:    #163a5f;
  --color-primary-light:  #2c5478;
  --color-gold:           #c9a961;   /* refined gold */
  --color-gold-dark:      #a8893f;
  --color-gold-light:     #e0c989;
  --color-cream:          #faf7f2;   /* warm off-white */
  --color-cream-dark:     #f0ebe0;
  --color-aegean:         #2a8aa6;   /* Aegean turquoise accent */
  --color-whatsapp:       #25D366;

  --color-text:           #1a2332;
  --color-text-soft:      #3d4a5c;
  --color-text-light:     #6b7280;
  --color-text-muted:     #9ca3af;
  --color-bg:             #FFFFFF;
  --color-bg-alt:         var(--color-cream);
  --color-bg-dim:         #f5f1e8;
  --color-border:         #e5e0d3;
  --color-border-strong:  #d4cdb8;

  --font-body:    'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  --font-heading: 'Playfair Display', 'Cormorant Garamond', Georgia, serif;

  --text-xs:    clamp(.75rem,  .72rem + .12vw, .8rem);
  --text-sm:    clamp(.875rem, .84rem + .15vw, .95rem);
  --text-base:  clamp(1rem,    .95rem + .2vw,  1.075rem);
  --text-lg:    clamp(1.125rem,1.05rem + .3vw, 1.25rem);
  --text-xl:    clamp(1.25rem, 1.15rem + .4vw, 1.5rem);
  --text-2xl:   clamp(1.5rem,  1.35rem + .6vw, 1.875rem);
  --text-3xl:   clamp(1.875rem,1.65rem + .9vw, 2.5rem);
  --text-4xl:   clamp(2.25rem, 1.9rem + 1.4vw, 3.5rem);
  --text-5xl:   clamp(2.75rem, 2.1rem + 2.6vw, 5rem);
  --text-6xl:   clamp(3.25rem, 2.4rem + 3.4vw, 6.5rem);

  --space-1:.25rem; --space-2:.5rem; --space-3:.75rem; --space-4:1rem;
  --space-5:1.25rem; --space-6:1.5rem; --space-8:2rem; --space-10:2.5rem;
  --space-12:3rem; --space-16:4rem; --space-20:5rem; --space-24:6rem; --space-32:8rem;

  --container:    1280px;
  --container-narrow: 920px;
  --container-prose:  720px;
  --header-h:        72px;
  --header-h-mob:    64px;

  --radius-xs:2px; --radius-sm:4px; --radius:8px; --radius-md:12px;
  --radius-lg:20px; --radius-xl:32px; --radius-full:9999px;

  --shadow-sm:  0 1px 3px rgba(10, 37, 64, .06);
  --shadow:     0 4px 16px rgba(10, 37, 64, .08);
  --shadow-md:  0 10px 30px rgba(10, 37, 64, .10);
  --shadow-lg:  0 20px 50px rgba(10, 37, 64, .14);
  --shadow-xl:  0 30px 80px rgba(10, 37, 64, .18);
  --shadow-gold: 0 8px 30px rgba(201, 169, 97, .25);

  --t-fast: 180ms cubic-bezier(.4,0,.2,1);
  --t:      280ms cubic-bezier(.4,0,.2,1);
  --t-slow: 480ms cubic-bezier(.16,1,.3,1);
  --ease:   cubic-bezier(.16,1,.3,1);

  --z-base:1; --z-sticky:100; --z-header:200; --z-modal:500; --z-toast:1000;
}

/* ===== 3. UTILITIES ======================================== */
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:var(--space-5)}
@media(min-width:768px){.container{padding-inline:var(--space-8)}}
.container-narrow{width:100%;max-width:var(--container-narrow);margin-inline:auto;padding-inline:var(--space-5)}
.container-prose{width:100%;max-width:var(--container-prose);margin-inline:auto;padding-inline:var(--space-5)}

.skip-link{position:absolute;top:-100px;left:var(--space-4);background:var(--color-primary);color:#fff;padding:var(--space-3) var(--space-5);border-radius:var(--radius-sm);z-index:var(--z-toast);font-weight:600}
.skip-link:focus{top:var(--space-4);color:#fff}
.sr-only{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ===== 4. TYPOGRAPHY ======================================= */
h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:700;line-height:1.12;color:var(--color-primary);letter-spacing:-.015em}
h1{font-size:var(--text-5xl);font-weight:600}
h2{font-size:var(--text-4xl);font-weight:600}
h3{font-size:var(--text-2xl);font-weight:600}
h4{font-size:var(--text-xl);font-weight:600}
em{font-style:italic;color:var(--color-gold-dark)}

.eyebrow{display:inline-flex;align-items:center;gap:var(--space-2);font-family:var(--font-body);font-size:var(--text-xs);font-weight:500;text-transform:uppercase;letter-spacing:.18em;color:var(--color-gold-dark);margin-bottom:var(--space-4)}
.eyebrow::before{content:'';width:24px;height:1px;background:currentColor}

.section-title{text-align:center;margin-bottom:var(--space-3)}
.section-subtitle{text-align:center;color:var(--color-text-light);max-width:640px;margin:0 auto var(--space-12);font-size:var(--text-lg);font-weight:300}
.section-eyebrow{display:block;text-align:center}

p{margin-bottom:var(--space-4)}
p:last-child{margin-bottom:0}

.lead{font-size:var(--text-lg);font-weight:300;line-height:1.7;color:var(--color-text-soft)}

/* Decorative divider */
.divider-gold{display:flex;align-items:center;justify-content:center;gap:var(--space-3);margin:var(--space-4) 0}
.divider-gold::before,.divider-gold::after{content:'';width:40px;height:1px;background:var(--color-gold)}
.divider-gold-icon{width:8px;height:8px;background:var(--color-gold);border-radius:50%;transform:rotate(45deg)}

/* ===== 5. BUTTONS ========================================== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-4) var(--space-6);min-height:48px;font-weight:500;font-size:var(--text-sm);letter-spacing:.04em;text-transform:uppercase;border-radius:var(--radius-xs);transition:all var(--t);text-align:center;position:relative;overflow:hidden;-webkit-tap-highlight-color:transparent;user-select:none;cursor:pointer;max-width:100%}
.btn:active{transform:translateY(1px)}

.btn-primary{background:var(--color-primary);color:#fff;box-shadow:var(--shadow-sm)}
.btn-primary:hover{background:var(--color-primary-dark);color:#fff;box-shadow:var(--shadow-md);transform:translateY(-2px)}

.btn-gold{background:var(--color-gold);color:var(--color-primary);box-shadow:var(--shadow-gold)}
.btn-gold:hover{background:var(--color-gold-dark);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow-lg)}

.btn-secondary{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.4);backdrop-filter:blur(8px)}
.btn-secondary:hover{background:rgba(255,255,255,.12);color:#fff;border-color:#fff;transform:translateY(-2px)}

.btn-whatsapp{background:var(--color-whatsapp);color:#fff;box-shadow:0 4px 16px rgba(37,211,102,.3)}
.btn-whatsapp:hover{background:#1ebe57;color:#fff;transform:translateY(-2px);box-shadow:0 8px 24px rgba(37,211,102,.4)}

.btn-outline{background:transparent;color:var(--color-primary);border:1px solid var(--color-primary)}
.btn-outline:hover{background:var(--color-primary);color:#fff}

.btn-ghost{background:transparent;color:var(--color-primary);text-transform:none;letter-spacing:0;font-weight:500;padding:var(--space-3) var(--space-4);font-size:var(--text-base)}
.btn-ghost:hover{color:var(--color-gold-dark)}
.btn-ghost::after{content:'\2192';margin-left:var(--space-2);transition:transform var(--t)}
.btn-ghost:hover::after{transform:translateX(4px)}

.btn-large{padding:var(--space-5) var(--space-8);min-height:56px;font-size:var(--text-base)}
.btn-block{width:100%}
.btn svg,.btn .icon{flex-shrink:0;width:18px;height:18px;stroke-width:1.5}

/* ===== 6. ICONS (line, premium) ============================ */
.icon{flex-shrink:0;width:24px;height:24px;stroke-width:1.5;stroke:currentColor;fill:none;stroke-linecap:round;stroke-linejoin:round}
.icon-sm{width:18px;height:18px}
.icon-lg{width:32px;height:32px}
.icon-xl{width:48px;height:48px;stroke-width:1.25}

/* ===== 7. HEADER =========================================== */
.header{position:fixed;top:0;inset-inline:0;z-index:var(--z-header);background:rgba(255,255,255,.92);backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);border-bottom:1px solid transparent;transition:border-color var(--t),background var(--t),box-shadow var(--t)}
.header.scrolled{border-bottom-color:var(--color-border);background:rgba(255,255,255,.96);box-shadow:var(--shadow-sm)}

.header-inner{display:flex;align-items:center;justify-content:space-between;height:var(--header-h-mob);gap:var(--space-4)}
@media(min-width:1024px){.header-inner{height:var(--header-h)}}

.logo{font-family:var(--font-heading);font-weight:600;font-size:var(--text-lg);color:var(--color-primary);display:flex;align-items:center;gap:var(--space-3);flex-shrink:0;letter-spacing:-.01em;line-height:1.1}
.logo:hover{color:var(--color-primary)}
.logo-mark{width:38px;height:38px;flex-shrink:0;color:var(--color-gold-dark)}
.logo-text{display:flex;flex-direction:column;line-height:1.05}
.logo-text small{display:block;font-family:var(--font-body);font-weight:400;font-size:10px;color:var(--color-text-muted);letter-spacing:.16em;text-transform:uppercase;margin-top:2px}
@media(max-width:380px){.logo-text small{font-size:9px}.logo{font-size:.95rem;gap:.5rem}.logo-mark{width:30px;height:30px}}

.nav-desktop{display:none;align-items:center;gap:var(--space-6);margin-inline-start:auto;margin-inline-end:var(--space-4)}
@media(min-width:1024px){.nav-desktop{display:flex}}
.nav-desktop a{color:var(--color-text-soft);font-weight:500;font-size:var(--text-sm);position:relative;padding:var(--space-2) 0;letter-spacing:.02em}
.nav-desktop a::after{content:'';position:absolute;inset-inline:0;bottom:0;height:1px;background:var(--color-gold);transform:scaleX(0);transform-origin:left;transition:transform var(--t)}
.nav-desktop a:hover{color:var(--color-primary)}
.nav-desktop a:hover::after,.nav-desktop a[aria-current="page"]::after{transform:scaleX(1)}
.nav-desktop a[aria-current="page"]{color:var(--color-primary)}

.header-actions{display:flex;align-items:center;gap:var(--space-3);flex-shrink:0}

.lang-switcher{display:none;align-items:center;gap:0;font-size:var(--text-xs);font-weight:500;letter-spacing:.1em}
@media(min-width:768px){.lang-switcher{display:inline-flex}}
.lang-switcher a{padding:6px 10px;color:var(--color-text-light);text-transform:uppercase;border-right:1px solid var(--color-border)}
.lang-switcher a:last-child{border-right:0}
.lang-switcher a.active,.lang-switcher a:hover{color:var(--color-primary)}
.lang-switcher a.active{font-weight:700}

.header-cta{display:none}
@media(min-width:768px){.header-cta{display:inline-flex;padding:var(--space-2) var(--space-5);min-height:40px;font-size:var(--text-xs);letter-spacing:.08em}}

.menu-toggle{display:inline-grid;place-items:center;width:44px;height:44px;border-radius:var(--radius-sm);color:var(--color-primary);transition:background var(--t)}
@media(min-width:1024px){.menu-toggle{display:none}}
.menu-toggle:hover{background:var(--color-bg-alt)}

/* ===== 8. MOBILE NAV ======================================= */
.nav-mobile{position:fixed;inset-block-start:0;inset-inline-end:0;height:100dvh;width:min(85%,340px);background:var(--color-cream);z-index:calc(var(--z-header) + 10);transform:translateX(100%);transition:transform var(--t-slow);display:flex;flex-direction:column;box-shadow:-10px 0 50px rgba(0,0,0,.1);overflow-y:auto;overflow-x:hidden}
.nav-mobile.open{transform:translateX(0)}
.nav-mobile-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border);flex-shrink:0}
.nav-mobile-close{width:40px;height:40px;display:grid;place-items:center;border-radius:var(--radius-sm);color:var(--color-primary)}
.nav-mobile-close:hover{background:rgba(10,37,64,.05)}
.nav-mobile ul{padding:var(--space-3);display:flex;flex-direction:column;gap:2px;list-style:none;margin:0}
.nav-mobile a{display:flex;align-items:center;padding:.7rem .85rem;font-size:1rem;font-weight:500;color:var(--color-primary);border-radius:var(--radius-sm);font-family:var(--font-heading);line-height:1.3}
.nav-mobile a:hover,.nav-mobile a[aria-current="page"]{background:rgba(201,169,97,.12);color:var(--color-gold-dark)}
.nav-mobile-cta{padding:var(--space-3) var(--space-4);border-top:1px solid var(--color-border);display:flex;flex-direction:column;gap:.5rem;margin-top:auto;flex-shrink:0}
.nav-mobile-cta .btn{min-height:44px;font-size:.85rem;padding:.65rem .85rem;letter-spacing:.04em;width:100%}
.nav-mobile-lang{display:flex;flex-wrap:wrap;gap:.4rem;justify-content:center;padding:var(--space-3) var(--space-4) var(--space-4);border-top:1px solid var(--color-border);flex-shrink:0}
.nav-mobile-lang a{padding:.4rem .85rem;border-radius:var(--radius-full);background:#fff;font-size:.82rem;font-weight:600;color:var(--color-text-soft);font-family:var(--font-body);border:1px solid var(--color-border);min-width:44px;text-align:center}
.nav-mobile-lang a.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}

.nav-overlay{position:fixed;inset:0;background:rgba(10,37,64,.6);backdrop-filter:blur(4px);z-index:calc(var(--z-header) + 5);opacity:0;visibility:hidden;transition:opacity var(--t),visibility var(--t)}
.nav-overlay.open{opacity:1;visibility:visible}

/* ===== 9. HERO ============================================= */
.hero{position:relative;min-height:100dvh;display:grid;place-items:center;overflow:hidden;isolation:isolate;padding-top:var(--header-h-mob);color:#fff}
@media(min-width:1024px){.hero{padding-top:var(--header-h)}}
.hero-media{position:absolute;inset:0;z-index:-2;overflow:hidden}
.hero-media picture{display:block;width:100%;height:100%}
.hero-media img,.hero-media video{width:100%;height:100%;object-fit:cover;object-position:center center}
.hero::before{background:linear-gradient(180deg,rgba(5,21,41,.2) 0%,rgba(5,21,41,.35) 50%,rgba(5,21,41,.6) 100%)}
.hero::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(5,21,41,.35) 0%,rgba(5,21,41,.5) 50%,rgba(5,21,41,.85) 100%);z-index:-1}

.hero-content{text-align:center;padding:var(--space-12) var(--space-5);max-width:1100px;width:100%;animation:heroIn 1.2s var(--ease) backwards}
@keyframes heroIn{from{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}

.hero-eyebrow{display:inline-flex;align-items:center;gap:var(--space-3);color:var(--color-gold-light);font-size:10px;font-weight:500;text-transform:uppercase;letter-spacing:.2em;margin-bottom:var(--space-6);max-width:100%;flex-wrap:wrap;justify-content:center;padding-inline:var(--space-4)}
@media(min-width:600px){.hero-eyebrow{font-size:var(--text-xs);letter-spacing:.24em}}
.hero-eyebrow::before,.hero-eyebrow::after{content:'';width:24px;height:1px;background:var(--color-gold-light);opacity:.7}
@media(min-width:600px){.hero-eyebrow::before,.hero-eyebrow::after{width:32px}}

.hero h1{color:#fff;font-size:clamp(2.5rem, 5vw + 1rem, 5.5rem);margin-bottom:var(--space-4);font-weight:500;line-height:1.05;letter-spacing:-.02em;hyphens:auto;-webkit-hyphens:auto;word-break:break-word}
.hero h1 em{font-style:italic;color:var(--color-gold-light);font-weight:400;display:inline-block}

.hero-tagline{color:rgba(255,255,255,.85);font-family:var(--font-heading);font-style:italic;font-size:clamp(1rem, 1.5vw + .5rem, 1.5rem);font-weight:400;margin-bottom:var(--space-8);max-width:600px;margin-inline:auto;padding-inline:var(--space-4)}

.hero-meta{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:var(--space-3) var(--space-6);margin-bottom:var(--space-10);font-size:var(--text-xs);color:rgba(255,255,255,.85);font-weight:400;letter-spacing:.04em;padding-inline:var(--space-4)}
@media(min-width:600px){.hero-meta{font-size:var(--text-sm)}}
.hero-meta-item{display:inline-flex;align-items:center;gap:var(--space-2)}
.hero-meta-divider{width:1px;height:14px;background:rgba(255,255,255,.3);display:none}
@media(min-width:600px){.hero-meta-divider{display:block}}

.hero-ctas{display:flex;flex-direction:column;gap:var(--space-3);align-items:stretch;justify-content:center;padding-inline:var(--space-4);max-width:540px;margin-inline:auto}
@media(min-width:600px){.hero-ctas{flex-direction:row;align-items:center;max-width:none}}
.hero-ctas .btn{min-width:0;width:100%}
@media(min-width:600px){.hero-ctas .btn{min-width:200px;width:auto}}

.hero-scroll{position:absolute;bottom:var(--space-8);left:50%;transform:translateX(-50%);color:rgba(255,255,255,.7);font-size:10px;text-transform:uppercase;letter-spacing:.3em;display:none;flex-direction:column;align-items:center;gap:var(--space-3);font-weight:500}
@media(min-width:1024px) and (min-height:700px){.hero-scroll{display:flex}}
.hero-scroll::after{content:'';width:1px;height:48px;background:linear-gradient(180deg,var(--color-gold-light),transparent);animation:scrollLine 2s ease-in-out infinite}
@keyframes scrollLine{0%,100%{transform:scaleY(.3);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}}

/* ===== 10. SECTIONS ======================================== */
section{padding:var(--space-20) 0}
@media(min-width:1024px){section{padding:var(--space-24) 0}}
section.alt{background:var(--color-cream)}
section.dark{background:var(--color-primary);color:#fff}
section.dark h1,section.dark h2,section.dark h3,section.dark h4{color:#fff}
section.dark .eyebrow{color:var(--color-gold-light)}
section.dark .section-subtitle{color:rgba(255,255,255,.75)}

/* ===== 11. TOUR CARDS (homepage main feature) ============== */
.tours-intro{text-align:center;margin-bottom:var(--space-16)}
.tour-cards{display:grid;grid-template-columns:1fr;gap:var(--space-6)}
@media(min-width:900px){.tour-cards{grid-template-columns:1fr 1fr;gap:var(--space-8)}}

.tour-card{position:relative;display:flex;flex-direction:column;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:transform var(--t),box-shadow var(--t);text-decoration:none;color:inherit;border:1px solid var(--color-border);isolation:isolate}
.tour-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);color:inherit}
.tour-card-media{position:relative;aspect-ratio:4/3;overflow:hidden;background:var(--color-bg-dim)}
.tour-card-media img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}
.tour-card:hover .tour-card-media img{transform:scale(1.04)}
.tour-card-badge{position:absolute;top:var(--space-4);left:var(--space-4);padding:var(--space-2) var(--space-4);background:rgba(255,255,255,.95);color:var(--color-primary);font-size:11px;font-weight:600;letter-spacing:.15em;text-transform:uppercase;border-radius:var(--radius-xs);backdrop-filter:blur(8px)}
.tour-card-body{padding:var(--space-8) var(--space-6) var(--space-6);flex:1;display:flex;flex-direction:column}
@media(min-width:768px){.tour-card-body{padding:var(--space-10) var(--space-8) var(--space-8)}}
.tour-card-eyebrow{font-family:var(--font-body);font-size:var(--text-xs);font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--color-gold-dark);margin-bottom:var(--space-3)}
.tour-card h3{font-size:var(--text-3xl);margin-bottom:var(--space-3);line-height:1.1}
.tour-card h3 em{display:block;font-size:.7em;color:var(--color-text-light);margin-top:var(--space-1);font-weight:400}
.tour-card-desc{color:var(--color-text-soft);margin-bottom:var(--space-6);font-size:var(--text-base);line-height:1.7;flex:1}
.tour-card-meta{display:flex;flex-wrap:wrap;gap:var(--space-2) var(--space-5);font-size:var(--text-sm);color:var(--color-text-light);margin-bottom:var(--space-6);padding-block:var(--space-4);border-block:1px solid var(--color-border)}
.tour-card-meta-item{display:inline-flex;align-items:center;gap:var(--space-2)}
.tour-card-meta-item .icon{width:16px;height:16px;color:var(--color-gold-dark)}
.tour-card-cta{display:inline-flex;align-items:center;gap:var(--space-2);font-weight:500;color:var(--color-primary);font-size:var(--text-sm);text-transform:uppercase;letter-spacing:.1em;margin-top:auto}
.tour-card-cta::after{content:'\2192';transition:transform var(--t)}
.tour-card:hover .tour-card-cta::after{transform:translateX(6px)}

/* ===== 12. EXPERIENCE STOPS (timeline cards) =============== */
.experience-grid{display:grid;grid-template-columns:1fr;gap:var(--space-6)}
@media(min-width:600px){.experience-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.experience-grid{grid-template-columns:repeat(4,1fr);gap:var(--space-5)}}

.experience{position:relative;background:#fff;border:1px solid var(--color-border);transition:all var(--t);overflow:hidden;display:flex;flex-direction:column}
.experience:hover{border-color:var(--color-gold);transform:translateY(-3px);box-shadow:var(--shadow-md)}
.experience-image{aspect-ratio:4/3;overflow:hidden;background:var(--color-bg-dim)}
.experience-image img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}
.experience:hover .experience-image img{transform:scale(1.06)}
.experience-body{padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-3);flex:1}
.experience-time{font-family:var(--font-heading);font-style:italic;font-size:var(--text-sm);color:var(--color-gold-dark);letter-spacing:.05em}
.experience h4{font-size:var(--text-xl);font-weight:600;margin-bottom:0;line-height:1.2}
.experience h4 em{display:block;font-size:.7em;font-weight:400;color:var(--color-text-light);margin-top:var(--space-1)}
.experience p{color:var(--color-text-soft);font-size:var(--text-sm);line-height:1.65;margin:0}

/* ===== 12.b TIMELINE (saatlik program) ===================== */
.timeline{position:relative;max-width:820px;margin:var(--space-10) auto 0;padding:var(--space-2) 0}
.timeline::before{content:'';position:absolute;left:96px;top:18px;bottom:18px;width:1px;background:linear-gradient(180deg,transparent,var(--color-gold-light) 6%,var(--color-gold) 50%,var(--color-gold-light) 94%,transparent)}
.timeline-item{position:relative;display:grid;grid-template-columns:96px 1fr;column-gap:var(--space-8);padding:var(--space-5) 0;align-items:start}
.timeline-item + .timeline-item .timeline-content{border-top:1px solid var(--color-border);padding-top:var(--space-5)}
.timeline-time{position:relative;font-family:var(--font-heading);font-style:italic;font-size:var(--text-lg);color:var(--color-gold-dark);font-weight:600;letter-spacing:.02em;text-align:right;line-height:1.2;padding-top:var(--space-1)}
.timeline-time::after{content:'';position:absolute;right:-32px;top:14px;width:13px;height:13px;border-radius:50%;background:var(--color-cream);border:2px solid var(--color-gold);box-shadow:0 0 0 4px var(--color-cream),0 0 0 5px rgba(201,169,97,.25);transition:all var(--t);z-index:1}
.timeline-content{padding-top:var(--space-1)}
.timeline-content h4{font-family:var(--font-heading);font-size:var(--text-xl);font-weight:600;color:var(--color-primary);margin-bottom:var(--space-2);line-height:1.3}
.timeline-content p{color:var(--color-text-soft);font-size:var(--text-base);line-height:1.7;margin:0;font-weight:400}
.timeline-content p strong{color:var(--color-gold-dark);font-weight:600}
.timeline-item:hover .timeline-time::after{transform:scale(1.25);background:var(--color-gold);box-shadow:0 0 0 4px var(--color-cream),0 0 0 6px rgba(201,169,97,.4)}
.timeline-item:hover .timeline-content h4{color:var(--color-gold-dark)}
@media(max-width:640px){
  .timeline{margin-top:var(--space-8)}
  .timeline::before{left:14px}
  .timeline-item{grid-template-columns:1fr;column-gap:0;padding:var(--space-4) 0 var(--space-4) var(--space-10);row-gap:var(--space-2)}
  .timeline-item + .timeline-item .timeline-content{border-top:0;padding-top:0}
  .timeline-item + .timeline-item{border-top:1px solid var(--color-border);margin-top:var(--space-2)}
  .timeline-time{text-align:left;font-size:var(--text-base);padding-top:0}
  .timeline-time::after{right:auto;left:-31px;top:6px;width:11px;height:11px}
}

/* ===== 13. INCLUDES (premium list) ========================= */
.includes{display:grid;grid-template-columns:1fr;gap:var(--space-1);max-width:1080px;margin:0 auto;border-block:1px solid var(--color-border)}
@media(min-width:600px){.includes{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.includes{grid-template-columns:repeat(3,1fr)}}
.include{padding:var(--space-6) var(--space-4);display:flex;align-items:flex-start;gap:var(--space-4);border-bottom:1px solid var(--color-border);transition:background var(--t)}
.include:hover{background:rgba(201,169,97,.04)}
@media(min-width:600px){.include:nth-last-child(-n+2):nth-child(2n+1),.include:nth-last-child(-n+1):nth-child(2n){border-bottom:0}}
@media(min-width:1024px){.include{border-right:1px solid var(--color-border)}.include:nth-child(3n){border-right:0}.include:nth-last-child(-n+3){border-bottom:0}.include:nth-last-child(-n+2):nth-child(2n+1):not(:nth-child(3n+1)){border-bottom:1px solid var(--color-border)}}
.include-icon{width:28px;height:28px;flex-shrink:0;color:var(--color-gold-dark);stroke-width:1.25}
.include-text strong{display:block;font-family:var(--font-heading);font-size:var(--text-lg);font-weight:600;margin-bottom:var(--space-1);color:var(--color-primary)}
.include-text span{font-size:var(--text-sm);color:var(--color-text-light);line-height:1.5}

/* ===== 14. STATS (premium numbers) ========================= */
.stats{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-6);text-align:center}
@media(min-width:768px){.stats{grid-template-columns:repeat(4,1fr);gap:var(--space-8)}}
.stat-number{font-family:var(--font-heading);font-size:var(--text-5xl);font-weight:600;color:var(--color-gold);line-height:1;margin-bottom:var(--space-3);display:block}
.stat-label{font-size:var(--text-sm);color:var(--color-text-light);letter-spacing:.08em;text-transform:uppercase;font-weight:500}
section.dark .stat-label{color:rgba(255,255,255,.7)}

/* ===== 15. SPLIT (image + content) ========================= */
.split{display:grid;grid-template-columns:1fr;gap:var(--space-8);align-items:center}
@media(min-width:900px){.split{grid-template-columns:1fr 1fr;gap:var(--space-16)}}
.split.reverse > *:first-child{order:2}
@media(max-width:899px){.split.reverse > *:first-child{order:0}}
.split-image{aspect-ratio:4/5;overflow:hidden;border-radius:var(--radius)}
.split-image img{width:100%;height:100%;object-fit:cover}
.split-content h2{margin-bottom:var(--space-5)}
.split-content p{font-size:var(--text-lg);line-height:1.75;color:var(--color-text-soft);font-weight:300}
.split-content .btn{margin-top:var(--space-6)}

/* ===== 16. GALLERY ========================================= */
.gallery-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-2)}
@media(min-width:600px){.gallery-grid{grid-template-columns:repeat(3,1fr);gap:var(--space-3)}}
@media(min-width:1024px){.gallery-grid{grid-template-columns:repeat(4,1fr);gap:var(--space-4)}}
.gallery-item{aspect-ratio:1;overflow:hidden;background:var(--color-bg-dim);position:relative;cursor:zoom-in;border-radius:var(--radius-sm)}
.gallery-item:nth-child(7n+1){grid-row:span 2;aspect-ratio:1/2}
@media(max-width:599px){.gallery-item:nth-child(7n+1){grid-row:auto;aspect-ratio:1}}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease)}
.gallery-item:hover img{transform:scale(1.08)}
/* Compact homepage gallery: equal squares, 4-column */
.gallery-grid--compact{grid-template-columns:repeat(2,1fr);gap:var(--space-2)}
@media(min-width:600px){.gallery-grid--compact{grid-template-columns:repeat(4,1fr);gap:var(--space-3)}}
.gallery-grid--compact .gallery-item:nth-child(7n+1){grid-row:auto;aspect-ratio:1}

/* ===== 17. TESTIMONIALS ==================================== */
.testimonials{display:grid;grid-template-columns:1fr;gap:var(--space-5)}
@media(min-width:768px){.testimonials{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.testimonials{grid-template-columns:repeat(3,1fr);gap:var(--space-6)}}
.testimonial{padding:var(--space-8) var(--space-6);background:#fff;border:1px solid var(--color-border);display:flex;flex-direction:column;gap:var(--space-5);position:relative}
.testimonial-quote{position:absolute;top:var(--space-4);right:var(--space-5);font-family:var(--font-heading);font-size:80px;line-height:1;color:var(--color-gold);opacity:.3;font-style:italic}
.testimonial-stars{color:var(--color-gold);font-size:var(--text-base);letter-spacing:.1em}
.testimonial-text{color:var(--color-text-soft);font-style:italic;flex:1;font-size:var(--text-base);line-height:1.7;font-family:var(--font-heading);font-weight:400}
.testimonial-author{display:flex;align-items:center;gap:var(--space-3);padding-top:var(--space-4);border-top:1px solid var(--color-border)}
.testimonial-info strong{display:block;color:var(--color-primary);font-weight:600;font-size:var(--text-sm)}
.testimonial-info span{font-size:var(--text-xs);color:var(--color-text-light);letter-spacing:.05em}

/* ===== 18. FAQ ============================================= */
.faq-list{max-width:820px;margin:0 auto;display:flex;flex-direction:column}
.faq-item{border-bottom:1px solid var(--color-border);overflow:hidden;transition:all var(--t)}
.faq-item summary{padding:var(--space-6) 0;cursor:pointer;font-family:var(--font-heading);font-weight:600;font-size:var(--text-xl);color:var(--color-primary);display:flex;justify-content:space-between;align-items:center;gap:var(--space-4);list-style:none;-webkit-tap-highlight-color:transparent;transition:color var(--t)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary:hover{color:var(--color-gold-dark)}
.faq-item summary::after{content:'';width:14px;height:14px;background:linear-gradient(currentColor,currentColor),linear-gradient(currentColor,currentColor);background-size:100% 1.5px,1.5px 100%;background-position:center;background-repeat:no-repeat;flex-shrink:0;transition:transform var(--t)}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item-content{padding:0 0 var(--space-6);color:var(--color-text-soft);line-height:1.75;font-size:var(--text-base);max-width:90%}

/* ===== 19. CTA BANNER ====================================== */
.cta-banner{position:relative;color:#fff;text-align:center;padding:var(--space-24) 0;background:var(--color-primary);overflow:hidden;isolation:isolate}
.cta-banner-bg{position:absolute;inset:0;z-index:-2;opacity:.18}
.cta-banner-bg img{width:100%;height:100%;object-fit:cover}
.cta-banner::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,37,64,.85),rgba(5,21,41,.95));z-index:-1}
.cta-banner h2{color:#fff;margin-bottom:var(--space-4)}
.cta-banner p{color:rgba(255,255,255,.85);max-width:580px;margin:0 auto var(--space-8);font-size:var(--text-lg);font-weight:300}
.cta-banner-actions{display:flex;flex-direction:column;gap:var(--space-3);align-items:center;justify-content:center}
@media(min-width:600px){.cta-banner-actions{flex-direction:row}}

/* ===== 20. FOOTER ========================================== */
.footer{background:var(--color-primary-dark);color:rgba(255,255,255,.75);padding:var(--space-20) 0 var(--space-8)}
.footer-grid{display:grid;grid-template-columns:1fr;gap:var(--space-10)}
@media(min-width:600px){.footer-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.footer-grid{grid-template-columns:1.5fr 1fr 1fr 1fr;gap:var(--space-12)}}
.footer h3{color:#fff;font-family:var(--font-body);font-weight:500;font-size:var(--text-xs);margin-bottom:var(--space-5);text-transform:uppercase;letter-spacing:.18em;color:var(--color-gold-light)}
.footer ul{display:flex;flex-direction:column;gap:var(--space-3)}
.footer a{color:rgba(255,255,255,.65);font-size:var(--text-sm);transition:color var(--t)}
.footer a:hover{color:var(--color-gold-light)}
.footer-brand .logo{color:#fff;margin-bottom:var(--space-4)}
.footer-brand p{color:rgba(255,255,255,.65);font-size:var(--text-sm);line-height:1.7;max-width:340px;margin-bottom:var(--space-5)}
.footer-contact-item{display:flex;align-items:center;gap:var(--space-3);font-size:var(--text-sm)}
.footer-contact-item .icon{width:16px;height:16px;color:var(--color-gold);flex-shrink:0}
.footer-social{display:flex;gap:var(--space-2)}
.footer-social a{width:40px;height:40px;display:grid;place-items:center;border:1px solid rgba(255,255,255,.15);transition:all var(--t)}
.footer-social a:hover{background:var(--color-gold);border-color:var(--color-gold);color:var(--color-primary);transform:translateY(-2px)}
.footer-social svg{width:16px;height:16px}
.footer-bottom{margin-top:var(--space-12);padding-top:var(--space-6);border-top:1px solid rgba(255,255,255,.1);display:flex;flex-wrap:wrap;gap:var(--space-4);justify-content:space-between;font-size:var(--text-xs);color:rgba(255,255,255,.45);letter-spacing:.05em}
.footer-bottom a{color:rgba(255,255,255,.45);font-size:var(--text-xs)}

/* ===== 21. STICKY MOBILE CTA =============================== */
.mobile-cta-bar{position:fixed;inset:auto 0 0 0;z-index:var(--z-sticky);background:#fff;border-top:1px solid var(--color-border);padding:var(--space-3);padding-bottom:calc(var(--space-3) + env(safe-area-inset-bottom));display:grid;grid-template-columns:1fr 1fr;gap:var(--space-2);box-shadow:0 -4px 24px rgba(10,37,64,.08);transform:translateY(100%);transition:transform var(--t-slow)}
.mobile-cta-bar.visible{transform:translateY(0)}
@media(min-width:1024px){.mobile-cta-bar{display:none}}
.mobile-cta-bar .btn{min-height:48px;font-size:var(--text-xs);padding:var(--space-3)}
@media(max-width:1023px){body.has-mobile-cta{padding-bottom:80px}}

/* ===== 22. PAGE HERO (inner) =============================== */
.page-hero{position:relative;color:#fff;padding:calc(var(--header-h-mob) + var(--space-16)) 0 var(--space-16);overflow:hidden;isolation:isolate;background:var(--color-primary)}
@media(min-width:1024px){.page-hero{padding:calc(var(--header-h) + var(--space-20)) 0 var(--space-20)}}
.page-hero-image{position:absolute;inset:0;z-index:-2}
.page-hero-image img{width:100%;height:100%;object-fit:cover}
.page-hero::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(5,21,41,.85),rgba(10,37,64,.7));z-index:-1}
.page-hero h1{color:#fff;margin-bottom:var(--space-4)}
.page-hero h1 em{color:var(--color-gold-light)}
.page-hero p{color:rgba(255,255,255,.85);font-size:var(--text-lg);max-width:640px;font-weight:300}

/* ===== 23. BREADCRUMBS ===================================== */
.breadcrumbs{padding:var(--space-4) 0;font-size:var(--text-xs);color:var(--color-text-light);letter-spacing:.05em;text-transform:uppercase;font-weight:500}
.breadcrumbs ol{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-2)}
.breadcrumbs li:not(:last-child)::after{content:'/';margin-inline-start:var(--space-2);color:var(--color-text-muted);font-weight:400}
.breadcrumbs a{color:var(--color-text-light)}
.breadcrumbs a:hover{color:var(--color-primary)}
.breadcrumbs li:last-child{color:var(--color-primary);font-weight:600}
.page-hero .breadcrumbs{color:rgba(255,255,255,.7);padding:0 0 var(--space-4)}
.page-hero .breadcrumbs a{color:rgba(255,255,255,.7)}
.page-hero .breadcrumbs a:hover{color:#fff}
.page-hero .breadcrumbs li:last-child{color:#fff}

/* ===== 24. PRICING ========================================= */
.price-grid{display:grid;grid-template-columns:1fr;gap:var(--space-6);align-items:stretch;max-width:1080px;margin:0 auto}
@media(min-width:768px){.price-grid{grid-template-columns:repeat(3,1fr)}}
.price-card{background:#fff;border:1px solid var(--color-border);padding:var(--space-10) var(--space-6) var(--space-8);display:flex;flex-direction:column;gap:var(--space-4);position:relative;transition:all var(--t)}
.price-card:hover{border-color:var(--color-gold);transform:translateY(-4px);box-shadow:var(--shadow-md)}
.price-card.featured{border-color:var(--color-gold);background:linear-gradient(180deg,rgba(201,169,97,.04),#fff)}
.price-card.featured::before{content:attr(data-badge);position:absolute;top:-1px;left:-1px;right:-1px;background:var(--color-gold);color:var(--color-primary);padding:var(--space-2);font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;text-align:center}
.price-card h3{font-size:var(--text-xl);font-weight:600;font-family:var(--font-heading)}
.price-card-tagline{color:var(--color-text-light);font-size:var(--text-sm);margin-top:calc(-1 * var(--space-2));margin-bottom:var(--space-3)}
.price-amount{display:flex;align-items:baseline;gap:var(--space-1);font-family:var(--font-heading);margin-bottom:var(--space-4);padding-bottom:var(--space-4);border-bottom:1px solid var(--color-border)}
.price-amount-value{font-size:var(--text-4xl);font-weight:600;color:var(--color-primary);line-height:1}
.price-amount-currency{font-size:var(--text-lg);color:var(--color-primary);font-weight:500}
.price-amount-unit{font-size:var(--text-sm);color:var(--color-text-light);font-family:var(--font-body);margin-inline-start:var(--space-2)}
.price-features{display:flex;flex-direction:column;gap:var(--space-3);flex:1;margin-bottom:var(--space-6)}
.price-features li{display:flex;align-items:flex-start;gap:var(--space-3);font-size:var(--text-sm);color:var(--color-text-soft)}
.price-features li::before{content:'';width:16px;height:16px;flex-shrink:0;margin-top:2px;background:var(--color-gold);mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='black'><path d='M6 11.4 2.6 8 4 6.6l2 2 6-6L13.4 4 6 11.4z'/></svg>") center/contain no-repeat;-webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='black'><path d='M6 11.4 2.6 8 4 6.6l2 2 6-6L13.4 4 6 11.4z'/></svg>") center/contain no-repeat}

/* ===== 25. FORMS =========================================== */
.form-group{display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:var(--space-5)}
.form-label{font-weight:500;font-size:var(--text-sm);color:var(--color-primary);letter-spacing:.02em}
.form-control{width:100%;padding:var(--space-4);min-height:48px;font:inherit;border:1px solid var(--color-border);border-radius:var(--radius-xs);background:#fff;color:var(--color-text);transition:all var(--t)}
.form-control:focus{outline:none;border-color:var(--color-gold);box-shadow:0 0 0 3px rgba(201,169,97,.15)}
textarea.form-control{min-height:140px;resize:vertical;font-family:inherit}

/* ===== 26. ARTICLE / BLOG ================================== */
.article{max-width:760px;margin:0 auto}
.article h2{margin-top:var(--space-12);margin-bottom:var(--space-4);font-size:var(--text-3xl)}
.article h3{margin-top:var(--space-10);margin-bottom:var(--space-3);font-size:var(--text-2xl)}
.article p{font-size:var(--text-lg);line-height:1.85;color:var(--color-text-soft);font-weight:300}
.article ul,.article ol{margin:var(--space-5) 0;padding-inline-start:var(--space-6)}
.article ul li{list-style:disc;margin-bottom:var(--space-2);color:var(--color-text-soft)}
.article ol li{list-style:decimal;margin-bottom:var(--space-2);color:var(--color-text-soft)}
.article img{margin:var(--space-10) 0;border-radius:var(--radius-sm);box-shadow:var(--shadow)}
.article blockquote{margin:var(--space-10) 0;padding:var(--space-8);background:var(--color-cream);border-inline-start:3px solid var(--color-gold);font-size:var(--text-xl);font-style:italic;color:var(--color-text-soft);font-family:var(--font-heading);font-weight:400}
.article blockquote p{font-size:inherit;line-height:1.5}

.article-meta{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-3) var(--space-5);font-size:var(--text-sm);color:var(--color-text-light);margin-bottom:var(--space-6);padding-bottom:var(--space-6);border-bottom:1px solid var(--color-border)}

/* ===== 27. BLOG GRID ======================================= */
.blog-grid{display:grid;grid-template-columns:1fr;gap:var(--space-8)}
@media(min-width:700px){.blog-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.blog-grid{grid-template-columns:repeat(3,1fr);gap:var(--space-10)}}
.blog-card{display:flex;flex-direction:column;gap:var(--space-4);transition:transform var(--t)}
.blog-card:hover{transform:translateY(-4px)}
.blog-card-image{aspect-ratio:4/3;overflow:hidden;background:var(--color-bg-dim);border-radius:var(--radius-sm)}
.blog-card-image img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}
.blog-card:hover .blog-card-image img{transform:scale(1.05)}
.blog-card-meta{font-size:var(--text-xs);color:var(--color-text-light);text-transform:uppercase;letter-spacing:.1em;font-weight:500}
.blog-card-meta .dot{margin-inline:var(--space-2);color:var(--color-gold)}
.blog-card h3{font-size:var(--text-xl);font-weight:600;line-height:1.25;color:var(--color-primary);transition:color var(--t)}
.blog-card:hover h3{color:var(--color-gold-dark)}
.blog-card p{color:var(--color-text-soft);font-size:var(--text-sm);line-height:1.6}
.blog-card-link{display:inline-flex;align-items:center;gap:var(--space-2);color:var(--color-primary);font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.12em;margin-top:auto}
.blog-card-link::after{content:'\2192';transition:transform var(--t)}
.blog-card:hover .blog-card-link::after{transform:translateX(4px)}

/* ===== 28. ANIMATIONS ====================================== */
.fade-in{opacity:0;transform:translateY(20px);transition:opacity .9s ease,transform .9s ease}
.fade-in.visible{opacity:1;transform:translateY(0)}

/* ===== 29. BOOKING FORM ==================================== */
.booking-form{margin-top:var(--space-8);background:#fff;padding:clamp(1.5rem,4vw,2.5rem);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}
.booking-form .form-row{display:grid;grid-template-columns:1fr;gap:var(--space-4);margin-bottom:var(--space-4)}
@media(min-width:600px){.booking-form .form-row{grid-template-columns:1fr 1fr}}
.booking-form .form-group{display:flex;flex-direction:column;gap:.4rem}
.booking-form label{font-size:var(--text-sm);font-weight:600;color:var(--color-primary);letter-spacing:.01em}
.booking-form input,.booking-form select,.booking-form textarea{font:inherit;width:100%;padding:.85rem 1rem;background:#fff;border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);color:var(--color-text);transition:border-color var(--t-fast),box-shadow var(--t-fast);min-height:48px}
.booking-form textarea{min-height:96px;resize:vertical;line-height:1.5}
.booking-form input:focus,.booking-form select:focus,.booking-form textarea:focus{outline:none;border-color:var(--color-gold);box-shadow:0 0 0 3px rgba(201,169,97,.18)}
.booking-form input:invalid:not(:placeholder-shown){border-color:#c44}
.booking-form button[type="submit"]{margin-top:var(--space-4);width:100%}
.booking-form .form-hint{font-size:var(--text-xs);color:var(--color-text-light);margin-top:var(--space-3);text-align:center}

/* ===== 30. FLOATING ACTION BAR (lang/wa/call) =============== */
.fab{position:fixed;right:1rem;bottom:1rem;z-index:300;display:flex;flex-direction:column;align-items:flex-end;gap:.65rem;pointer-events:none}
@media(min-width:768px){.fab{right:1.5rem;bottom:1.5rem;gap:.75rem}}
.fab-btn{pointer-events:auto;width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#fff;color:var(--color-primary);border:1px solid var(--color-border);box-shadow:0 6px 18px rgba(10,37,64,.18);cursor:pointer;transition:transform var(--t-fast),box-shadow var(--t-fast),background var(--t-fast);position:relative;text-decoration:none}
.fab-btn:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(10,37,64,.25);color:var(--color-primary)}
.fab-btn svg{width:22px;height:22px}
.fab-wa{background:#25D366;color:#fff;border-color:#25D366}
.fab-wa:hover{background:#1fb955;color:#fff}
.fab-call{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}
.fab-call:hover{background:var(--color-primary-dark);color:#fff}
.fab-lang-toggle{background:var(--color-gold);color:var(--color-primary);border-color:var(--color-gold);font-weight:600}
.fab-lang-toggle:hover{background:var(--color-gold-light)}
.fab-tag{position:absolute;bottom:-2px;right:-2px;background:var(--color-primary);color:#fff;font-size:.62rem;padding:.1rem .35rem;border-radius:8px;font-weight:600;letter-spacing:.04em;line-height:1.4;border:1px solid #fff}
.fab-lang-menu{pointer-events:auto;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:0 14px 32px rgba(10,37,64,.18);padding:.4rem;display:flex;flex-direction:column;min-width:130px;animation:fab-in .2s ease-out both}
.fab-lang-menu[hidden]{display:none}
.fab-lang-item{display:flex;align-items:center;gap:.6rem;padding:.55rem .75rem;font-size:.92rem;color:var(--color-primary);border-radius:var(--radius-sm);font-weight:500;text-decoration:none;transition:background var(--t-fast)}
.fab-lang-item:hover{background:var(--color-cream)}
.fab-lang-item.active{background:var(--color-cream);color:var(--color-gold-dark);font-weight:600}
.fab-flag{font-size:1.1rem;line-height:1}
@keyframes fab-in{from{opacity:0;transform:translateY(6px) scale(.97)}to{opacity:1;transform:none}}

/* Hide bottom mobile CTA when FAB is active */
body.has-fab .mobile-cta-bar{display:none!important}
body.has-fab.has-mobile-cta{padding-bottom:0!important}

/* ===== 31. GOOGLE REVIEWS BADGE ============================ */
.gbadge{display:inline-flex;align-items:center;gap:.75rem;background:#0a2540;color:#fff;padding:.6rem 1rem .6rem .75rem;border-radius:var(--radius);box-shadow:var(--shadow-sm);text-decoration:none;border:1px solid rgba(201,169,97,.2)}
.gbadge:hover{color:#fff;background:#163a5f}
.gbadge-icon{width:32px;height:32px;flex-shrink:0;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.95rem;font-family:Arial,sans-serif;background:conic-gradient(from 0deg,#4285F4 0deg 90deg,#34A853 90deg 180deg,#FBBC05 180deg 270deg,#EA4335 270deg 360deg);position:relative}
.gbadge-icon::after{content:'G';position:absolute;color:#fff;font-size:1.05rem;font-weight:800}
.gbadge-content{display:flex;flex-direction:column;gap:.05rem}
.gbadge-rating{display:flex;align-items:center;gap:.4rem;font-weight:600;font-size:.95rem}
.gbadge-stars{color:#FBBC05;font-size:.95rem;letter-spacing:.05em}
.gbadge-meta{font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.7)}

/* ===== 32. DISCOUNT TOAST ================================== */
.discount-toast{position:fixed;left:1rem;bottom:1rem;max-width:340px;background:linear-gradient(135deg,var(--color-gold) 0%,var(--color-gold-dark) 100%);color:var(--color-primary);padding:1rem 1.1rem;border-radius:var(--radius-md);box-shadow:0 12px 32px rgba(10,37,64,.25);display:flex;flex-direction:column;gap:.4rem;z-index:301;animation:toast-in .4s ease-out;border:1px solid rgba(255,255,255,.4)}
@media(min-width:768px){.discount-toast{left:1.5rem;bottom:1.5rem}}
.discount-toast.closing{animation:toast-out .25s ease-in both}
.discount-toast strong{font-family:var(--font-heading);font-weight:600;font-size:1.05rem}
.discount-toast p{font-size:.85rem;line-height:1.45;margin:0}
.discount-toast .discount-code{display:inline-block;font-family:'Courier New',monospace;background:rgba(10,37,64,.92);color:var(--color-gold-light);padding:.25rem .55rem;border-radius:var(--radius-xs);font-weight:600;letter-spacing:.06em;font-size:.85rem;margin:.2rem 0}
.discount-toast .discount-actions{display:flex;gap:.5rem;margin-top:.4rem}
.discount-toast .discount-actions a,.discount-toast .discount-actions button{font-size:.78rem;padding:.4rem .65rem;border-radius:var(--radius-sm);font-weight:600;text-decoration:none;border:0;cursor:pointer}
.discount-toast .discount-actions a{background:var(--color-primary);color:#fff}
.discount-toast .discount-actions button{background:transparent;color:var(--color-primary);text-decoration:underline}
@keyframes toast-in{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
@keyframes toast-out{from{opacity:1}to{opacity:0;transform:translateY(20px)}}

/* ===== 33. PRINT & VIEW TRANSITIONS ======================== */
@media print{.header,.footer,.mobile-cta-bar,.nav-mobile,.nav-overlay,.hero-scroll,.fab,.discount-toast,.booking-form{display:none!important}body{color:#000;background:#fff}a{color:#000;text-decoration:underline}}
@view-transition{navigation:auto}
::view-transition-old(root),::view-transition-new(root){animation-duration:.3s}
