/* ============================================================
   NYITIKA HOTEL — Global Stylesheet
   Dark mode default · Blue + Dark Green · Mugumu, Serengeti
   ============================================================ */

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

/* ── COLOR SYSTEM ── */
:root {
  /* Dark mode — DEFAULT */
  --bg:        #0D1117;
  --bg-card:   #161B22;
  --bg-el:     #21262D;
  --border:    rgba(48,54,61,.9);
  --text:      #E6EDF3;
  --muted:     #8B949E;
  --subtle:    #484F58;

  --blue:      #58A6FF;
  --blue-dk:   #1F6FEB;
  --blue-bg:   rgba(31,111,235,.12);

  --green:     #3FB950;
  --green-dk:  #238636;
  --green-bg:  rgba(63,185,80,.1);

  --white: #FFFFFF;
  --gold:  #D4B84A; /* warm accent only where needed */

  --radius-sm: 6px;
  --radius-md: 12px;
  --radius-lg: 20px;
  --radius-xl: 28px;

  --shadow-sm: 0 1px 6px rgba(0,0,0,.4);
  --shadow-md: 0 4px 20px rgba(0,0,0,.5);
  --shadow-lg: 0 8px 40px rgba(0,0,0,.6);

  --font-head: 'Cormorant Garamond', Georgia, serif;
  --font-body: 'Inter', sans-serif;
  --ease: 0.25s ease;
}

/* ── LIGHT MODE ── */
html.light {
  --bg:      #F6F8FA;
  --bg-card: #FFFFFF;
  --bg-el:   #EFF2F5;
  --border:  #D0D7DE;
  --text:    #1F2328;
  --muted:   #636C76;
  --subtle:  #B0B8C1;

  --blue:    #0550AE;
  --blue-dk: #0066CC;
  --blue-bg: rgba(5,80,174,.08);

  --green:    #1A7F37;
  --green-dk: #1B5E3B;
  --green-bg: rgba(26,127,55,.08);

  --shadow-sm: 0 1px 6px rgba(0,0,0,.08);
  --shadow-md: 0 4px 20px rgba(0,0,0,.1);
  --shadow-lg: 0 8px 40px rgba(0,0,0,.14);
}

/* ── RESET ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;transition:background .3s}
body{font-family:var(--font-body);font-size:15px;color:var(--text);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased;transition:background .3s,color .3s}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}
input,select,textarea,button{font-family:inherit}

/* ── CONTAINER ── */
.container{max-width:1180px;margin:0 auto;padding:0 20px}

/* ── TYPOGRAPHY ── */
h1,h2,h3,h4{font-family:var(--font-head);font-weight:600;line-height:1.2;color:var(--text)}
h1{font-size:clamp(2rem,5vw,3.2rem)}
h2{font-size:clamp(1.6rem,3.5vw,2.2rem)}
h3{font-size:clamp(1.1rem,2vw,1.4rem)}
p{color:var(--muted);line-height:1.7}

/* ── NAVBAR ── */
.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;height:64px;display:flex;align-items:center;transition:all .35s}
.navbar.glass{background:rgba(13,17,23,.75);backdrop-filter:blur(16px);border-bottom:1px solid var(--border)}
html.light .navbar.glass{background:rgba(246,248,250,.85);backdrop-filter:blur(16px)}
.nav-inner{max-width:1180px;margin:0 auto;padding:0 14px;display:flex;align-items:center;justify-content:space-between;width:100%;gap:8px}
.nav-logo{display:flex;align-items:center;gap:8px;min-width:0;flex:1;overflow:hidden}
.nav-logo img{height:34px;width:34px;object-fit:contain;border-radius:var(--radius-sm);flex-shrink:0}
.nav-logo>div{min-width:0;overflow:hidden}
.nav-logo .name{font-family:var(--font-head);font-size:1rem;font-weight:700;color:var(--text);letter-spacing:.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}
.nav-logo .loc{font-size:.58rem;color:var(--muted);letter-spacing:.12em;text-transform:uppercase;display:block;margin-top:-2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.nav-links{display:flex;align-items:center;gap:24px}
.nav-links a{font-size:.84rem;font-weight:500;color:var(--muted);transition:color var(--ease)}
.nav-links a:hover,.nav-links a.active{color:var(--text)}
.nav-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}
.mode-btn{width:36px;height:36px;border-radius:50%;background:var(--bg-el);border:1px solid var(--border);color:var(--muted);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.85rem;transition:all var(--ease)}
.mode-btn:hover{border-color:var(--blue);color:var(--blue)}
.nav-book{padding:8px 20px;background:var(--blue-dk);color:#fff;border:none;border-radius:50px;font-size:.8rem;font-weight:600;cursor:pointer;transition:all var(--ease)}
.nav-book:hover{opacity:.88;transform:translateY(-1px)}
.hamburger{display:none;flex-direction:column;gap:4px;cursor:pointer;background:none;border:none;padding:4px}
.hamburger span{display:block;width:22px;height:2px;background:var(--text);border-radius:2px;transition:all .3s}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:8px;padding:11px 26px;border-radius:50px;font-weight:600;font-size:.85rem;cursor:pointer;border:none;transition:all var(--ease);letter-spacing:.01em}
.btn-blue{background:var(--blue-dk);color:#fff}.btn-blue:hover{opacity:.88;transform:translateY(-1px);box-shadow:0 6px 20px rgba(31,111,235,.35)}
.btn-green{background:var(--green-dk);color:#fff}.btn-green:hover{opacity:.88;transform:translateY(-1px);box-shadow:0 6px 20px rgba(35,134,54,.35)}
.btn-outline{background:transparent;color:var(--text);border:1.5px solid var(--border)}.btn-outline:hover{border-color:var(--blue);color:var(--blue)}
.btn-white{background:var(--white);color:#0D1117}.btn-white:hover{opacity:.9;transform:translateY(-1px)}
.btn-wa{background:#25D366;color:#fff}.btn-wa:hover{background:#128C7E;transform:translateY(-1px)}
.btn-lg{padding:14px 34px;font-size:.92rem}
.btn-sm{padding:7px 16px;font-size:.78rem}
.btn-block{width:100%;justify-content:center;border-radius:var(--radius-md)}

/* ── CARDS ── */
.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);transition:all var(--ease)}
.card-hover:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--blue)}

/* ── HORIZONTAL PHOTO STRIP ── */
.photo-strip{display:flex;gap:10px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding-bottom:10px;cursor:grab;user-select:none}
.photo-strip:active{cursor:grabbing}
.photo-strip::-webkit-scrollbar{height:3px}
.photo-strip::-webkit-scrollbar-track{background:var(--bg-el)}
.photo-strip::-webkit-scrollbar-thumb{background:var(--blue-dk);border-radius:2px}
.photo-item{flex:0 0 auto;scroll-snap-align:start;border-radius:var(--radius-md);overflow:hidden;position:relative;cursor:pointer}
.photo-item img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.photo-item:hover img{transform:scale(1.05)}
.photo-item .pi-overlay{position:absolute;inset:0;background:rgba(0,0,0,0);transition:background .3s;display:flex;align-items:center;justify-content:center}
.photo-item:hover .pi-overlay{background:rgba(0,0,0,.2)}
.pi-zoom{color:#fff;font-size:1.1rem;opacity:0;transition:opacity .3s}
.photo-item:hover .pi-zoom{opacity:1}

/* ── LIGHTBOX ── */
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.96);z-index:3000;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s;padding:12px}
.lightbox.open{opacity:1;pointer-events:all}
.lb-img{max-width:90vw;max-height:85vh;object-fit:contain;border-radius:var(--radius-md);transform:scale(.94);transition:transform .3s;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.lightbox.open .lb-img{transform:scale(1)}
.lb-btn{position:absolute;width:42px;height:42px;background:rgba(255,255,255,.1);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.9rem;cursor:pointer;border:none;transition:background .2s}
.lb-btn:hover{background:rgba(255,255,255,.22)}
.lb-close{top:14px;right:14px}
.lb-prev{left:10px;top:50%;transform:translateY(-50%)}
.lb-next{right:10px;top:50%;transform:translateY(-50%)}
.lb-info{position:absolute;bottom:14px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.45);font-size:.72rem;white-space:nowrap}

/* ── FORMS ── */
.form-group{margin-bottom:16px}
.form-label{display:block;font-size:.75rem;font-weight:600;color:var(--muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.06em}
.form-control{width:100%;padding:10px 13px;background:var(--bg-el);border:1.5px solid var(--border);border-radius:var(--radius-md);font-family:var(--font-body);font-size:.88rem;color:var(--text);outline:none;transition:border-color var(--ease)}
.form-control:focus{border-color:var(--blue)}
select.form-control{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%238B949E' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}

/* ── RADIO PILLS ── */
.radio-pills{display:flex;gap:6px;flex-wrap:wrap}
.radio-pill input{display:none}
.radio-pill label{display:flex;align-items:center;gap:6px;padding:8px 14px;background:var(--bg-el);border:1.5px solid var(--border);border-radius:50px;font-size:.82rem;font-weight:500;cursor:pointer;transition:all var(--ease);color:var(--muted)}
.radio-pill input:checked+label{background:var(--blue-dk);border-color:var(--blue-dk);color:#fff}
html.light .radio-pill input:checked+label{background:var(--blue-dk);color:#fff}

/* ── STATUS PILL ── */
.pill{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:50px;font-size:.7rem;font-weight:700}
.pill-blue{background:var(--blue-bg);color:var(--blue)}
.pill-green{background:var(--green-bg);color:var(--green)}
.pill-yellow{background:rgba(212,184,74,.15);color:var(--gold)}
.pill-red{background:rgba(248,81,73,.12);color:#F85149}

/* ── LOADER ── */
.loader{position:fixed;inset:0;background:var(--bg);display:flex;align-items:center;justify-content:center;z-index:9999;transition:opacity .4s}
.loader.gone{opacity:0;pointer-events:none}
.loader-brand{text-align:center}
.loader-brand img{width:60px;height:60px;object-fit:contain;margin:0 auto 12px;border-radius:var(--radius-sm)}
.loader-brand .name{font-family:var(--font-head);font-size:1.2rem;color:var(--text)}
.loader-brand .sub{font-size:.65rem;color:var(--muted);letter-spacing:.2em;text-transform:uppercase;margin-top:3px}
.loader-bar{width:80px;height:2px;background:var(--border);border-radius:2px;margin:14px auto 0;overflow:hidden}
.loader-bar::after{content:'';display:block;width:40%;height:100%;background:var(--blue);border-radius:2px;animation:lbar 1.1s ease infinite}
@keyframes lbar{0%{transform:translateX(-150%)}100%{transform:translateX(450%)}}

/* ── TOAST ── */
.toast{position:fixed;bottom:20px;right:20px;background:var(--bg-card);border:1px solid var(--border);color:var(--text);padding:11px 16px;border-radius:var(--radius-md);font-size:.82rem;box-shadow:var(--shadow-lg);z-index:9998;display:flex;align-items:center;gap:9px;transform:translateY(70px);opacity:0;transition:all .3s;max-width:300px}
.toast.show{transform:translateY(0);opacity:1}
.toast.success{border-left:3px solid var(--green)}
.toast.error{border-left:3px solid #F85149}

/* ── SPINNER ── */
.spinner{width:18px;height:18px;border:2.5px solid rgba(255,255,255,.25);border-top-color:#fff;border-radius:50%;animation:spin .65s linear infinite;flex-shrink:0}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── SECTION ── */
.section{padding:64px 0}
.section-header{text-align:center;margin-bottom:44px}
.section-label{display:inline-block;font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--blue);margin-bottom:10px}
.divider{width:40px;height:2px;background:var(--blue-dk);margin:14px auto 0;border-radius:2px}

/* ── FOOTER ── */
.footer{background:var(--bg-card);border-top:1px solid var(--border);padding:40px 0 24px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:36px;margin-bottom:32px}
.footer .fname{font-family:var(--font-head);font-size:1.1rem;color:var(--text);margin-bottom:3px}
.footer .floc{font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--blue);margin-bottom:10px;display:block}
.footer p{font-size:.82rem;color:var(--muted);line-height:1.6}
.footer h5{font-family:var(--font-head);font-size:.9rem;color:var(--text);margin-bottom:14px;font-weight:600}
.footer ul{display:flex;flex-direction:column;gap:8px}
.footer ul a{font-size:.82rem;color:var(--muted);transition:color var(--ease)}
.footer ul a:hover{color:var(--blue)}
.footer-bottom{border-top:1px solid var(--border);padding-top:20px;display:flex;justify-content:space-between;font-size:.75rem;color:var(--subtle);flex-wrap:wrap;gap:8px}
.socials{display:flex;gap:8px}
.socials a{width:32px;height:32px;border-radius:50%;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:.8rem;transition:all var(--ease)}
.socials a:hover{border-color:var(--blue);color:var(--blue)}

/* ── REVEAL ANIMATION ── */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .6s ease,transform .6s ease}
.reveal.shown{opacity:1;transform:translateY(0)}

/* ── RESPONSIVE ── */
@media(max-width:860px){
  .nav-links{display:none}.hamburger{display:flex}
  .nav-links.open{display:flex;flex-direction:column;position:fixed;top:0;left:0;right:0;bottom:0;width:100%;height:100%;background:#0D1117;-webkit-backdrop-filter:none;backdrop-filter:none;align-items:center;justify-content:center;gap:28px;z-index:9999}
html.light .nav-links.open{background:#F6F8FA}
  .nav-links.open a{font-size:1.2rem;color:var(--text);font-weight:600}
/* Hamburger X stays ABOVE the open menu overlay */
.nav-links.open ~ .nav-actions{position:relative;z-index:10000}
  .footer-grid{grid-template-columns:1fr 1fr;gap:24px}
}
@media(max-width:500px){
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;text-align:center}
}
