/* ═══════════════════════════════════════════════════
   LINGUAPHIX · Corporate Stylesheet v2
   De l'expression à l'impression.
═══════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Syne:wght@400;500;600;700;800&family=DM+Sans:ital,wght@0,300;0,400;0,500;0,600;1,400&display=swap');

/* ── TOKENS */
:root {
  --g:        #1a7c3e;
  --g-dark:   #0f5c2c;
  --g-mid:    #2da04a;
  --g-light:  #e8f5ed;
  --g-glow:   rgba(26,124,62,0.10);
  --accent:   #7bff9e;
  --white:    #ffffff;
  --off:      #f7f9f6;
  --black:    #0b1a0e;
  --ink:      #1c2d20;
  --muted:    #5a7a60;
  --light:    #9ab4a0;
  --border:   #dce9e0;
  --card:     #ffffff;
  --nav-h:    70px;
  --r:        10px;
  --rlg:      18px;
  --rxl:      26px;
  --sh-sm:    0 2px 8px rgba(0,0,0,0.06);
  --sh-md:    0 6px 24px rgba(0,0,0,0.09);
  --sh-lg:    0 18px 52px rgba(0,0,0,0.13);
  --sh-g:     0 8px 32px rgba(26,124,62,0.20);
}

/* ── RESET */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'DM Sans',sans-serif;background:var(--off);color:var(--ink);overflow-x:hidden;line-height:1.6}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
button{font-family:inherit;cursor:pointer}
ul{list-style:none}

/* ── TYPOGRAPHY */
h1,h2,h3,h4,.brand{font-family:'Syne',sans-serif}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--g);margin-bottom:14px}
.eyebrow::before{content:'';width:22px;height:2px;background:var(--g);border-radius:1px;flex-shrink:0}
.section-title{font-size:clamp(28px,4vw,50px);font-weight:800;line-height:1.07;color:var(--black)}
.section-title .acc{color:var(--g)}
.section-sub{font-size:16px;color:var(--muted);line-height:1.75;max-width:580px;margin-top:14px}

/* ── FLOATING LOGOS */
.float-logo{position:absolute;border-radius:50%;pointer-events:none;user-select:none;z-index:0;animation:fIn .8s ease forwards,fBob var(--dur,9s) ease-in-out infinite var(--delay,0s)}
.float-logo img{width:100%;height:100%;border-radius:50%;opacity:var(--op,.08);filter:var(--flt,none)}
@keyframes fIn{from{opacity:0;transform:scale(.75) rotate(-8deg)}to{opacity:1;transform:scale(1) rotate(0deg)}}
@keyframes fBob{
  0%,100%{transform:translateY(0) rotate(var(--r0,0deg));opacity:var(--op,.08)}
  40%{transform:translateY(-20px) rotate(var(--r1,5deg));opacity:calc(var(--op,.08)*1.6)}
  70%{transform:translateY(10px) rotate(var(--r2,-4deg));opacity:var(--op,.08)}
}

/* ── BUTTONS */
.btn{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:14px;padding:13px 26px;border-radius:50px;border:2px solid transparent;transition:all .22s;white-space:nowrap;cursor:pointer}
.btn-g{background:var(--g);color:#fff;border-color:var(--g);box-shadow:var(--sh-g)}
.btn-g:hover{background:var(--g-dark);border-color:var(--g-dark);transform:translateY(-2px);box-shadow:0 14px 36px rgba(26,124,62,.30)}
.btn-ol{background:transparent;border-color:var(--g);color:var(--g)}
.btn-ol:hover{background:var(--g-light)}
.btn-white{background:#fff;color:var(--g);border-color:#fff;box-shadow:var(--sh-md)}
.btn-white:hover{box-shadow:var(--sh-lg);transform:translateY(-2px)}
.btn-ghost-w{background:transparent;border-color:rgba(255,255,255,.45);color:#fff}
.btn-ghost-w:hover{background:rgba(255,255,255,.12);border-color:#fff}
.btn-sm{font-size:12px;padding:8px 18px}
.btn-lg{font-size:16px;padding:16px 34px}

/* ── NAV */
#nav{position:fixed;top:0;left:0;right:0;z-index:900;height:var(--nav-h);display:flex;align-items:center;justify-content:space-between;padding:0 5vw;background:rgba(255,255,255,.96);backdrop-filter:blur(18px);border-bottom:1px solid var(--border);transition:box-shadow .3s}
#nav.scrolled{box-shadow:var(--sh-md)}
.nav-brand{display:flex;align-items:center;gap:10px}
.nav-logo-img{width:36px;height:36px;border-radius:50%;overflow:hidden;flex-shrink:0}
.nav-logo-img img{width:100%;height:100%;object-fit:cover}
.nav-name{font-family:'Syne',sans-serif;font-size:18px;font-weight:800;color:var(--g);letter-spacing:.5px}
.nav-links{display:flex;gap:26px}
.nav-links a{font-size:13.5px;font-weight:500;color:var(--muted);transition:color .2s}
.nav-links a:hover{color:var(--g)}
.nav-right{display:flex;align-items:center;gap:10px}

/* Language switcher */
.lang-sw{display:flex;gap:2px;background:var(--off);border-radius:50px;padding:3px;border:1px solid var(--border)}
.lang-btn{display:inline-flex;align-items:center;gap:5px;padding:5px 11px;border-radius:50px;border:none;background:transparent;font-size:12px;font-weight:600;color:var(--muted);transition:all .2s;cursor:pointer;line-height:1}
.lang-btn .flag{font-size:15px;line-height:1}
.lang-btn.on{background:var(--g);color:#fff;box-shadow:0 2px 8px rgba(26,124,62,.3)}
.lang-btn:not(.on):hover{color:var(--g);background:var(--g-light)}
.admin-key{width:30px;height:30px;border-radius:50%;border:1px solid var(--border);background:transparent;color:var(--light);font-size:14px;display:flex;align-items:center;justify-content:center;transition:border-color .2s}
.admin-key:hover{border-color:var(--g);color:var(--g)}

/* Hamburger */
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:4px}
.hamburger span{width:22px;height:2px;background:var(--ink);border-radius:2px;transition:all .3s;display:block}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* Mobile menu */
#mob-menu{display:none;position:fixed;top:var(--nav-h);left:0;right:0;background:#fff;z-index:800;border-bottom:1px solid var(--border);padding:20px 5vw 28px;flex-direction:column;gap:4px;box-shadow:var(--sh-lg)}
#mob-menu a{display:block;padding:12px 0;font-size:16px;font-weight:500;border-bottom:1px solid var(--border);color:var(--ink)}
#mob-menu a:last-of-type{border:none}
#mob-menu .mob-bottom{display:flex;align-items:center;justify-content:space-between;margin-top:16px;flex-wrap:wrap;gap:10px}

/* ── TICKER */
.ticker-wrap{background:var(--g);padding:12px 0;overflow:hidden}
.ticker-track{display:flex;width:max-content;animation:ticker 38s linear infinite}
.ticker-track:hover{animation-play-state:paused}
.ticker-item{display:inline-flex;align-items:center;gap:10px;padding:0 28px;font-size:11.5px;font-weight:500;letter-spacing:1.2px;text-transform:uppercase;color:rgba(255,255,255,.82);white-space:nowrap}
.ticker-dot{width:5px;height:5px;border-radius:50%;background:rgba(255,255,255,.35);flex-shrink:0}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ── SECTION FRAMEWORK */
section{position:relative;overflow:hidden}
.container{max-width:1200px;margin:0 auto;padding:0 5vw}
.pad{padding:96px 0}
.pad-lg{padding:116px 0}
.text-center{text-align:center}
.mx-auto{margin-left:auto;margin-right:auto}

/* ── HERO */
#hero{min-height:100vh;display:flex;align-items:center;background:linear-gradient(148deg,#031a09 0%,#0f5c2c 50%,#2da04a 100%);padding:calc(var(--nav-h) + 48px) 5vw 64px}
.hero-grid{max-width:1200px;margin:0 auto;width:100%;display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.hero-pill{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);color:rgba(255,255,255,.9);padding:6px 16px;border-radius:50px;font-size:11px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:26px}
.hero-pill-dot{width:6px;height:6px;border-radius:50%;background:#7bff9e;animation:blink 1.5s infinite;flex-shrink:0}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.25}}
.hero-h1{font-size:clamp(40px,6vw,76px);font-weight:900;line-height:1.04;color:#fff;margin-bottom:22px;letter-spacing:-.5px}
.hero-h1 em{font-style:normal;color:#7bff9e}
.hero-sub{font-size:16.5px;color:rgba(255,255,255,.70);line-height:1.78;margin-bottom:36px;max-width:500px}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:50px}
.hero-stats{display:flex;gap:36px;flex-wrap:wrap;padding-top:30px;border-top:1px solid rgba(255,255,255,.12)}
.stat-n{font-family:'Syne',sans-serif;font-size:34px;font-weight:900;color:#7bff9e;line-height:1}
.stat-l{font-size:12px;color:rgba(255,255,255,.55);letter-spacing:.5px;margin-top:3px}
/* Hero visual cards */
.hero-visual{display:flex;flex-direction:column;gap:18px}
.h-card{background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.18);border-radius:var(--rlg);padding:22px 26px;backdrop-filter:blur(10px);color:#fff}
.h-card:nth-child(1){animation:hFloat 5s ease-in-out infinite 0s}
.h-card:nth-child(2){margin-left:32px;animation:hFloat 5s ease-in-out infinite 2.5s}
@keyframes hFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
.h-card-tag{font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:#7bff9e;margin-bottom:7px}
.h-card-title{font-family:'Syne',sans-serif;font-size:17px;font-weight:700}
.h-card-sub{font-size:12px;color:rgba(255,255,255,.58);margin-top:4px}

/* ── SERVICES */
#services{background:#fff}
.s-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:32px}
.stab{padding:10px 22px;border-radius:50px;border:1.5px solid var(--border);background:#fff;color:var(--muted);font-size:14px;font-weight:600;transition:all .2s;cursor:pointer}
.stab.on{background:var(--g);color:#fff;border-color:var(--g);box-shadow:var(--sh-g)}
.stab:hover:not(.on){border-color:var(--g);color:var(--g)}
.s-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:20px}
.s-card{background:var(--off);border:1px solid var(--border);border-radius:var(--rlg);padding:26px;transition:all .28s;position:relative;overflow:hidden}
.s-card::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(26,124,62,.04),transparent);opacity:0;transition:opacity .28s;pointer-events:none}
.s-card:hover{transform:translateY(-4px);box-shadow:var(--sh-g);border-color:var(--g)}
.s-card:hover::before{opacity:1}
.s-icon{font-size:30px;margin-bottom:14px}
.s-name{font-family:'Syne',sans-serif;font-size:16px;font-weight:700;margin-bottom:8px}
.s-desc{font-size:13px;color:var(--muted);line-height:1.65}
.s-badge{display:inline-block;margin-top:10px;font-size:10.5px;font-weight:700;padding:3px 11px;border-radius:50px;background:var(--g-light);color:var(--g-dark)}
.s-link{display:inline-flex;align-items:center;gap:5px;margin-top:13px;font-size:12px;font-weight:700;color:var(--g);transition:gap .2s}
.s-link:hover{gap:10px}

/* ── ABOUT */
#about{background:var(--off)}
.about-grid{display:grid;grid-template-columns:360px 1fr;gap:72px;align-items:start}
.about-photo{aspect-ratio:3/4;border-radius:var(--rxl);background:linear-gradient(145deg,var(--g-dark),var(--g-mid));border:2px dashed rgba(26,124,62,.28);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;text-align:center;padding:24px;position:relative}
.about-photo p{font-size:12.5px;color:rgba(255,255,255,.65);line-height:1.65}
.about-photo small{font-size:10px;opacity:.45}
.ac{position:absolute;width:22px;height:22px}
.ac.tl{top:-7px;left:-7px;border-top:3px solid var(--g);border-left:3px solid var(--g);border-radius:3px 0 0 0}
.ac.tr{top:-7px;right:-7px;border-top:3px solid var(--g);border-right:3px solid var(--g);border-radius:0 3px 0 0}
.ac.bl{bottom:-7px;left:-7px;border-bottom:3px solid var(--g);border-left:3px solid var(--g);border-radius:0 0 0 3px}
.ac.br{bottom:-7px;right:-7px;border-bottom:3px solid var(--g);border-right:3px solid var(--g);border-radius:0 0 3px 0}
.who-card{background:#fff;border:1px solid var(--border);border-radius:var(--r);padding:18px 20px;box-shadow:var(--sh-sm);margin-top:18px;display:flex;align-items:flex-start;gap:13px}
.who-av{width:40px;height:40px;border-radius:50%;background:var(--g);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.who-name{font-family:'Syne',sans-serif;font-size:14px;font-weight:800}
.who-role{font-size:11px;color:var(--g);font-weight:600;margin-bottom:5px}
.who-bio{font-size:12px;color:var(--muted);line-height:1.65}
.exp-rows{margin:26px 0;display:flex;flex-direction:column}
.exp-row{display:flex;align-items:flex-start;gap:16px;padding:15px 0;border-bottom:1px solid var(--border)}
.exp-row:last-child{border:none}
.exp-n{font-family:'Syne',sans-serif;font-size:28px;font-weight:900;color:var(--g);min-width:58px;line-height:1}
.exp-t strong{display:block;font-size:14px;font-weight:600;color:var(--black);margin-bottom:2px}
.exp-t span{font-size:12px;color:var(--muted)}

/* ── TESTIMONIALS */
#testimonials{background:#fff}
.t-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}
.t-card{background:var(--off);border:1px solid var(--border);border-radius:var(--rlg);padding:26px;position:relative;overflow:hidden}
.t-card::before{content:'"';position:absolute;top:-14px;left:14px;font-family:'Syne',sans-serif;font-size:96px;color:var(--g-light);line-height:1;pointer-events:none}
.t-stars{color:#f5a623;font-size:15px;margin-bottom:10px}
.t-badge{display:inline-block;font-size:10px;font-weight:700;padding:2px 9px;border-radius:50px;background:var(--g-light);color:var(--g-dark);margin-bottom:12px}
.t-text{font-size:13px;color:var(--ink);line-height:1.72;margin-bottom:18px;position:relative;z-index:1}
.t-author{display:flex;align-items:center;gap:11px}
.t-av{width:36px;height:36px;border-radius:50%;background:var(--g);display:flex;align-items:center;justify-content:center;font-family:'Syne',sans-serif;font-size:11.5px;font-weight:700;color:#fff;flex-shrink:0}
.t-name{font-size:13px;font-weight:700}
.t-role{font-size:11px;color:var(--muted)}
/* Testi form */
.testi-form-box{background:var(--off);border:1px solid var(--border);border-radius:var(--rlg);padding:34px;max-width:680px;margin:48px auto 0}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.fg{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}
.fg label{font-size:12px;font-weight:600;color:var(--ink)}
.fg input,.fg select,.fg textarea{padding:11px 14px;border:1.5px solid var(--border);border-radius:var(--r);background:#fff;font-family:'DM Sans',sans-serif;font-size:14px;color:var(--ink);outline:none;transition:border-color .2s;width:100%}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--g)}
.fg textarea{min-height:100px;resize:vertical}
.star-row{display:flex;gap:7px;font-size:28px;cursor:pointer}
.sp{color:#ddd;transition:color .15s;line-height:1}
.form-success{background:#e8f5ed;border:1px solid rgba(26,124,62,.3);border-radius:var(--r);padding:14px 18px;margin-bottom:16px;color:var(--g);font-size:14px;font-weight:500;display:none}
.form-err{color:#c0392b;font-size:12.5px;font-weight:500;display:none;margin-bottom:10px}

/* ── PORTFOLIO */
#portfolio{background:var(--off)}
.port-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:28px;flex-wrap:wrap;gap:14px}
.port-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(185px,1fr));gap:16px}
.port-tile{aspect-ratio:4/3;border-radius:var(--rlg);border:2px dashed var(--border);background:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;font-size:12.5px;color:var(--muted);cursor:pointer;transition:all .25s}
.port-tile:hover{border-color:var(--g);color:var(--g);transform:translateY(-3px);box-shadow:var(--sh-g)}
.port-icon{font-size:30px}
.port-note{text-align:center;font-size:11.5px;color:var(--light);margin-top:14px}

/* ── BOOKING */
#booking{background:linear-gradient(145deg,#031a09 0%,#0f5c2c 58%,#2da04a 100%);color:#fff}
.booking-grid{display:grid;grid-template-columns:1fr 1fr;gap:58px;align-items:start;margin-top:44px}
.b-opts{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px}
.b-opt{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);border-radius:var(--r);padding:15px;display:flex;gap:12px;align-items:flex-start;transition:background .2s}
.b-opt:hover{background:rgba(255,255,255,.14)}
.b-opt-i{font-size:20px;flex-shrink:0;margin-top:2px}
.b-opt-t{font-family:'Syne',sans-serif;font-size:13px;font-weight:700;color:#fff;margin-bottom:3px}
.b-opt-s{font-size:11px;color:rgba(255,255,255,.55);line-height:1.5}
.fee-box{display:flex;align-items:center;gap:10px;padding:12px 16px;background:rgba(255,209,0,.08);border:1px solid rgba(255,209,0,.28);border-radius:var(--r);font-size:12px;color:rgba(255,209,0,.9);margin:16px 0 20px}
/* Mixx */
.mixx-card{border-radius:var(--r);overflow:hidden;box-shadow:0 6px 24px rgba(0,0,0,.3)}
.mixx-head{background:#00377d;padding:14px 17px;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.mixx-logo{width:44px;height:44px;border-radius:10px;overflow:hidden;flex-shrink:0;box-shadow:0 2px 8px rgba(0,0,0,.3)}
.mixx-logo img{width:100%;height:100%;object-fit:cover;background:#00377d}
.mixx-bname{font-family:'Syne',sans-serif;font-size:15px;font-weight:800;line-height:1.1}
.mixx-bname .y{color:#ffd100}
.mixx-bname .w{color:#fff}
.mixx-bsub{font-size:10px;color:rgba(255,255,255,.5);margin-top:1px}
.mixx-pill{background:#ffd100;border-radius:8px;padding:7px 13px;text-align:center;flex-shrink:0}
.mixx-pill-l{font-size:9px;font-weight:700;color:#00377d;letter-spacing:.5px;text-transform:uppercase;margin-bottom:2px}
.mixx-pill-n{font-family:'Syne',sans-serif;font-size:16px;font-weight:900;color:#00377d;letter-spacing:1.5px}
.mixx-body{background:rgba(255,249,200,.04);border:1px solid rgba(255,209,0,.16);border-top:none;padding:10px 16px;font-size:11px;color:rgba(255,249,150,.7)}
.pay-methods{display:flex;flex-direction:column;gap:8px;margin-top:10px}
.pay-row{display:flex;align-items:center;gap:10px;padding:9px 12px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:7px}
.pay-stripe{width:4px;height:32px;border-radius:2px;flex-shrink:0}
.pay-row strong{font-size:12px;color:#fff}
.pay-row span{font-size:11px;color:rgba(255,255,255,.5)}
.confirm-note{margin-top:12px;padding:11px 14px;background:rgba(26,124,62,.2);border-left:3px solid var(--accent);border-radius:0 7px 7px 0;font-size:11.5px;color:rgba(255,255,255,.8);line-height:1.65}
/* Contact col */
.c-btns{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}
.c-btn{display:inline-flex;align-items:center;gap:7px;padding:9px 16px;border-radius:50px;font-size:12px;font-weight:600;border:1.5px solid rgba(255,255,255,.22);color:rgba(255,255,255,.82);background:transparent;transition:all .2s;cursor:pointer;text-decoration:none}
.c-btn:hover{background:rgba(255,255,255,.11);border-color:#fff;color:#fff}
.c-btn.wa{border-color:#25d366;color:#25d366}
.c-btn.wa:hover{background:rgba(37,211,102,.12)}
.c-btn.li{border-color:#5a9fd4;color:#8ec5f5}
.c-btn.li:hover{background:rgba(10,102,194,.18)}
.c-btn.cat{border-color:#ffd100;color:#ffd100}
.c-btn.cat:hover{background:rgba(255,209,0,.1)}
.c-form{display:flex;flex-direction:column;gap:10px}
.c-form input,.c-form select,.c-form textarea{background:rgba(255,255,255,.1);border:1.5px solid rgba(255,255,255,.18);border-radius:var(--r);padding:11px 14px;color:#fff;font-family:'DM Sans',sans-serif;font-size:14px;outline:none;transition:border-color .2s}
.c-form input::placeholder,.c-form textarea::placeholder{color:rgba(255,255,255,.36)}
.c-form input:focus,.c-form select:focus,.c-form textarea:focus{border-color:var(--accent)}
.c-form select option{background:#0f3d1e}
.c-form textarea{min-height:90px;resize:vertical}
/* Admin pay panel */
.pay-edit-panel{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.14);border-radius:var(--r);padding:16px;margin-top:12px;display:none}
.pay-edit-panel .pe-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.pay-edit-panel label{font-size:10px;color:rgba(255,255,255,.45);text-transform:uppercase;letter-spacing:.4px;display:block;margin-bottom:3px}
.pay-edit-panel input{width:100%;padding:8px 10px;border-radius:6px;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.1);color:#fff;font-size:13px;font-family:'DM Sans',sans-serif;outline:none}
.pay-edit-panel input:focus{border-color:var(--accent)}
.pe-hint{font-size:10px;color:rgba(255,255,255,.3);margin-top:8px;font-style:italic}

/* ── FOOTER */
footer{background:#060f09;padding:64px 5vw 0;color:rgba(255,255,255,.55)}
.footer-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;padding-bottom:48px}
.f-logo-img{width:42px;height:42px;border-radius:50%;overflow:hidden;margin-bottom:12px}
.f-logo-img img{width:100%;height:100%;object-fit:cover}
.f-brand-name{font-family:'Syne',sans-serif;font-size:20px;font-weight:800;color:#fff;margin-bottom:6px}
.f-motto{font-size:10.5px;letter-spacing:2px;text-transform:uppercase;color:var(--accent);margin-bottom:12px}
.f-desc{font-size:13px;line-height:1.7}
.f-socials{display:flex;gap:8px;margin-top:16px}
.f-social{width:32px;height:32px;border-radius:7px;border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;transition:border-color .2s;text-decoration:none}
.f-social:hover{border-color:var(--accent)}
.f-col h4{font-family:'Syne',sans-serif;font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:#fff;margin-bottom:16px}
.f-col ul{display:flex;flex-direction:column;gap:10px}
.f-col ul li a{font-size:13px;color:rgba(255,255,255,.48);transition:color .2s}
.f-col ul li a:hover{color:var(--accent)}
.f-bottom{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;border-top:1px solid rgba(255,255,255,.07);padding:20px 0;font-size:12px;flex-wrap:wrap;gap:10px}
.f-bottom a{color:var(--accent)}

/* ── GALAXY MODAL */
#galaxy-modal{position:fixed;inset:0;z-index:9999;display:none;align-items:center;justify-content:center;background:rgba(0,0,0,.85);backdrop-filter:blur(6px)}
#galaxy-modal.open{display:flex}
.galaxy-modal-inner{position:relative;width:94vw;max-width:1100px;height:86vh;border-radius:var(--rlg);overflow:hidden;border:1px solid rgba(255,255,255,.15);box-shadow:0 32px 80px rgba(0,0,0,.6)}
.galaxy-modal-inner iframe{width:100%;height:100%;border:none}
.galaxy-close{position:absolute;top:12px;right:14px;width:34px;height:34px;border-radius:50%;background:rgba(0,0,0,.6);border:1px solid rgba(255,255,255,.2);color:#fff;font-size:18px;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:2;transition:background .2s}
.galaxy-close:hover{background:rgba(255,0,0,.4)}
/* Galaxy toggle button */
.galaxy-toggle{position:fixed;bottom:90px;right:20px;z-index:800;width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#031a09,#1a7c3e);border:2px solid var(--accent);color:var(--accent);font-size:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 20px rgba(0,255,136,.3);transition:all .25s;animation:galaxyPulse 3s ease-in-out infinite}
.galaxy-toggle:hover{transform:scale(1.1);box-shadow:0 6px 28px rgba(0,255,136,.5)}
@keyframes galaxyPulse{0%,100%{box-shadow:0 4px 20px rgba(0,255,136,.3)}50%{box-shadow:0 4px 30px rgba(0,255,136,.6)}}

/* ── REVEAL */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}

/* ── RESPONSIVE */
@media(max-width:1060px){
  .hero-grid{grid-template-columns:1fr}
  .hero-visual{display:none}
  .about-grid{grid-template-columns:1fr}
  .about-photo{max-width:320px}
  .booking-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .nav-links{display:none}
  .hamburger{display:flex}
  .b-opts{grid-template-columns:1fr}
  .frow{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .pad{padding:64px 0}
}
@media(max-width:520px){
  .hero-stats{gap:22px}
  .hero-btns{flex-direction:column}
  .s-grid,.t-grid{grid-template-columns:1fr}
}

/* ── ADMIN MODAL */
.admin-modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.52);z-index:9998;display:flex;align-items:center;justify-content:center}
.admin-modal-box{background:#fff;border-radius:var(--rlg);padding:32px;width:340px;box-shadow:var(--sh-lg);position:relative}
.admin-modal-box h3{font-family:'Syne',sans-serif;font-size:18px;font-weight:800;margin-bottom:4px}
.admin-modal-box p{font-size:12px;color:var(--muted);margin-bottom:20px}
.admin-modal-box input{width:100%;padding:11px 14px;border-radius:8px;border:1.5px solid var(--border);font-size:14px;outline:none;font-family:'DM Sans',sans-serif;margin-bottom:10px}
.admin-modal-box input:focus{border-color:var(--g)}
.admin-modal-close{position:absolute;top:14px;right:16px;background:none;border:none;font-size:20px;cursor:pointer;color:var(--muted)}
