/* =========================================================
   NIOK BALI — shared styles for all pages
   Edit colours / fonts here once → applies everywhere.
   ========================================================= */
:root{
  --abyss:#04161a;
  --deep:#062b30;
  --ocean:#0a3d44;
  --teal:#1d7d82;
  --surf:#54b8ac;
  --foam:#cdeae2;
  --sand:#f4ede1;
  --sand-2:#ece2d2;
  --coral:#ef8354;
  --amber:#f2b65a;
  --ink:#06181c;
  --muted:#5f7a78;
  --display:"Fraunces",Georgia,serif;
  --body:"Hanken Grotesk",system-ui,sans-serif;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--body);color:var(--ink);background:var(--sand);
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

body::after{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:.04;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

.wrap{max-width:1200px;margin:0 auto;padding:0 28px}
.eyebrow{font-size:.72rem;letter-spacing:.32em;text-transform:uppercase;font-weight:600;display:inline-flex;align-items:center;gap:.7em}
.eyebrow::before{content:"";width:34px;height:1px;background:currentColor;opacity:.6}

/* ============ NAV ============ */
header{position:fixed;top:0;left:0;right:0;z-index:1000;padding:18px 0;transition:.4s ease}
header.scrolled,header.solid{background:rgba(4,22,26,.82);backdrop-filter:blur(14px);box-shadow:0 1px 0 rgba(255,255,255,.06);padding:12px 0}
.nav{display:flex;align-items:center;justify-content:space-between}
.logo{font-family:var(--display);font-size:1.55rem;font-weight:600;color:var(--sand);letter-spacing:-.01em;display:flex;align-items:center;gap:.5em}
.logo span{color:var(--amber);font-style:italic}
.logo svg{width:26px;height:26px;color:var(--surf)}
.nav-links{display:flex;gap:34px;align-items:center}
.nav-links a{color:var(--foam);font-size:.92rem;font-weight:500;position:relative;opacity:.85;transition:.25s}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:1.5px;background:var(--amber);transition:.3s}
.nav-links a:hover{opacity:1}
.nav-links a:hover::after{width:100%}
.btn{display:inline-flex;align-items:center;gap:.55em;font-weight:600;font-size:.92rem;padding:.78em 1.5em;border-radius:100px;cursor:pointer;transition:.3s;border:1px solid transparent}
.btn-primary{background:var(--coral);color:#2a0f04}
.btn-primary:hover{background:var(--amber);transform:translateY(-2px)}
.btn-ghost{border-color:rgba(205,234,226,.4);color:var(--foam)}
.btn-ghost:hover{background:rgba(205,234,226,.1);border-color:var(--foam)}
.btn-dark{border-color:rgba(6,24,28,.25);color:var(--ink)}
.btn-dark:hover{background:var(--ink);color:var(--sand)}
.btn svg{width:18px;height:18px}
.menu-toggle{display:none;background:none;border:none;color:var(--foam);cursor:pointer}

/* ============ HERO (home) ============ */
.hero{position:relative;min-height:100vh;display:flex;align-items:flex-end;padding-bottom:9vh;color:var(--sand);overflow:hidden;
  background:radial-gradient(120% 90% at 75% -10%, rgba(84,184,172,.30), transparent 55%),radial-gradient(90% 80% at 10% 110%, rgba(29,125,130,.45), transparent 60%),linear-gradient(160deg,#072e34 0%,#04161a 55%,#020c0f 100%)}
.hero::before{content:"";position:absolute;inset:0;opacity:.5;mix-blend-mode:screen;
  background:repeating-linear-gradient(105deg, transparent 0 60px, rgba(120,210,200,.05) 60px 62px),radial-gradient(80% 50% at 70% 0%, rgba(150,230,220,.12), transparent 70%);animation:shimmer 16s ease-in-out infinite alternate}
@keyframes shimmer{from{transform:translateX(-3%)}to{transform:translateX(3%)}}
.bubbles{position:absolute;inset:0;overflow:hidden}
.bubbles i{position:absolute;bottom:-40px;border-radius:50%;background:radial-gradient(circle at 30% 30%, rgba(255,255,255,.5), rgba(140,220,210,.05));border:1px solid rgba(205,234,226,.15);animation:rise linear infinite}
@keyframes rise{to{transform:translateY(-115vh) translateX(30px);opacity:0}}
.hero-inner{position:relative;z-index:3;width:100%}
.hero-loc{font-size:.78rem;letter-spacing:.3em;text-transform:uppercase;color:var(--surf);font-weight:600;margin-bottom:22px}
.hero h1{font-family:var(--display);font-weight:400;line-height:.95;letter-spacing:-.02em;font-size:clamp(3rem,9.5vw,8rem);max-width:14ch}
.hero h1 em{font-style:italic;color:var(--amber)}
.hero p{margin-top:26px;max-width:46ch;font-size:clamp(1rem,1.5vw,1.22rem);line-height:1.6;color:rgba(205,234,226,.85);font-weight:300}
.hero-cta{display:flex;gap:16px;margin-top:38px;flex-wrap:wrap}
.scroll-cue{position:absolute;bottom:34px;right:28px;z-index:3;writing-mode:vertical-rl;font-size:.72rem;letter-spacing:.25em;text-transform:uppercase;color:rgba(205,234,226,.6);display:flex;align-items:center;gap:14px}
.scroll-cue::after{content:"";width:1px;height:50px;background:linear-gradient(var(--surf),transparent);animation:cue 2s ease-in-out infinite}
@keyframes cue{0%,100%{transform:scaleY(.4);opacity:.4}50%{transform:scaleY(1);opacity:1}}

/* ============ PAGE HERO (service pages) ============ */
.page-hero{position:relative;padding:170px 0 80px;color:var(--sand);overflow:hidden;
  background:radial-gradient(110% 90% at 80% -20%, rgba(84,184,172,.32), transparent 55%),linear-gradient(155deg,#0a3d44 0%,#04161a 70%,#020c0f 100%)}
.page-hero::before{content:"";position:absolute;inset:0;opacity:.5;mix-blend-mode:screen;background:repeating-linear-gradient(105deg, transparent 0 60px, rgba(120,210,200,.05) 60px 62px)}
.page-hero-inner{position:relative;z-index:2;max-width:760px}
.breadcrumb{font-size:.82rem;letter-spacing:.06em;color:rgba(205,234,226,.7);margin-bottom:24px;display:flex;gap:.6em;align-items:center;flex-wrap:wrap}
.breadcrumb a{color:var(--surf)}
.breadcrumb a:hover{color:var(--amber)}
.page-hero h1{font-family:var(--display);font-weight:400;font-size:clamp(2.6rem,6.5vw,5rem);line-height:.98;letter-spacing:-.02em}
.page-hero h1 em{font-style:italic;color:var(--amber)}
.page-hero p{margin-top:24px;font-size:clamp(1.05rem,1.6vw,1.25rem);line-height:1.6;color:rgba(205,234,226,.85);font-weight:300;max-width:54ch}

/* reveal */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.hero .reveal,.page-hero .reveal{transition-delay:var(--d,0s)}

/* ============ INTRO / split block ============ */
.section{padding:clamp(72px,11vw,140px) 0}
.bg-sand{background:var(--sand)}
.bg-sand2{background:var(--sand-2)}
.bg-dark{background:var(--abyss);color:var(--sand)}
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,90px);align-items:center}
.split .eyebrow{color:var(--teal)}
.bg-dark .eyebrow{color:var(--surf)}
.h2{font-family:var(--display);font-weight:400;font-size:clamp(2rem,4.4vw,3.4rem);line-height:1.08;letter-spacing:-.02em;margin:22px 0 24px}
.h2 em{font-style:italic;color:var(--coral)}
.bg-dark .h2 em{color:var(--amber)}
.lead-p{font-size:1.06rem;line-height:1.75;color:#37514f;margin-bottom:18px;max-width:56ch}
.bg-dark .lead-p{color:rgba(205,234,226,.78)}
.media{position:relative;border-radius:18px;overflow:hidden;min-height:420px;
  background:radial-gradient(70% 60% at 70% 20%, rgba(84,184,172,.5), transparent 60%),linear-gradient(155deg,#0a3d44,#04161a);
  box-shadow:0 40px 80px -30px rgba(4,22,26,.5);display:flex;align-items:flex-end;padding:30px}
.media::before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(100deg, transparent 0 40px, rgba(180,235,225,.04) 40px 41px);mix-blend-mode:screen}
.media .tag{position:relative;z-index:2;color:var(--foam);font-size:.85rem;background:rgba(4,22,26,.5);backdrop-filter:blur(6px);border:1px solid rgba(205,234,226,.2);padding:.7em 1.1em;border-radius:100px}
.photo-hint{position:absolute;top:16px;left:16px;z-index:2;font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(205,234,226,.45)}

.sec-head{max-width:640px;margin-bottom:56px}
.sec-head .h2{margin-top:20px}

/* ============ FEATURE LIST ============ */
.features{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.feature{display:flex;gap:16px;padding:22px;border-radius:14px;background:rgba(255,255,255,.04);border:1px solid rgba(205,234,226,.1)}
.bg-sand .feature,.bg-sand2 .feature{background:#fff;border-color:rgba(6,24,28,.08);box-shadow:0 14px 30px -22px rgba(4,22,26,.4)}
.feature svg{width:26px;height:26px;color:var(--teal);flex-shrink:0;stroke-width:1.6}
.bg-dark .feature svg{color:var(--surf)}
.feature h4{font-family:var(--display);font-weight:500;font-size:1.15rem;margin-bottom:6px}
.feature p{font-size:.94rem;line-height:1.55;color:var(--muted)}
.bg-dark .feature p{color:rgba(205,234,226,.7)}

/* ============ SERVICE CARDS (home) ============ */
.cards{position:relative;z-index:2;display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.card{display:block;background:linear-gradient(165deg,rgba(255,255,255,.05),rgba(255,255,255,.015));border:1px solid rgba(205,234,226,.1);border-radius:16px;padding:32px 28px;position:relative;overflow:hidden;transition:.4s cubic-bezier(.2,.7,.2,1)}
.card:hover{transform:translateY(-8px);border-color:rgba(242,182,90,.45);background:linear-gradient(165deg,rgba(84,184,172,.12),rgba(255,255,255,.02))}
.card .num{font-family:var(--display);font-size:.95rem;color:var(--amber);opacity:.8}
.card .ic{width:46px;height:46px;color:var(--surf);margin:18px 0 20px;stroke-width:1.4}
.card:hover .ic{color:var(--amber)}
.card h3{font-family:var(--display);font-weight:500;font-size:1.45rem;margin-bottom:12px;letter-spacing:-.01em;color:var(--sand)}
.card p{font-size:.96rem;line-height:1.65;color:rgba(205,234,226,.72);font-weight:300}
.card .more{display:inline-flex;align-items:center;gap:.4em;margin-top:18px;font-size:.85rem;font-weight:600;color:var(--surf);transition:.25s}
.card:hover .more{gap:.8em;color:var(--amber)}

/* ============ PACKAGE / PRICE CARDS ============ */
.packages{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.pkg{background:#fff;border:1px solid rgba(6,24,28,.08);border-radius:18px;padding:34px 30px;display:flex;flex-direction:column;transition:.35s;box-shadow:0 20px 40px -30px rgba(4,22,26,.4)}
.bg-sand2 .pkg{background:var(--sand)}
.pkg:hover{transform:translateY(-6px);box-shadow:0 30px 60px -30px rgba(4,22,26,.45)}
.pkg.featured{background:linear-gradient(165deg,#0a3d44,#04161a);color:var(--sand);border-color:transparent}
.pkg-tag{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;font-weight:700;color:var(--teal)}
.pkg.featured .pkg-tag{color:var(--amber)}
.pkg h3{font-family:var(--display);font-weight:500;font-size:1.5rem;margin:10px 0 6px}
.pkg .price{font-family:var(--display);font-size:2.1rem;line-height:1;margin:10px 0 4px}
.pkg .price small{font-size:.85rem;font-family:var(--body);color:var(--muted);font-weight:400}
.pkg.featured .price small{color:rgba(205,234,226,.65)}
.pkg .desc{font-size:.95rem;color:var(--muted);line-height:1.55;margin:8px 0 18px}
.pkg.featured .desc{color:rgba(205,234,226,.72)}
.pkg ul{list-style:none;margin:0 0 24px;display:flex;flex-direction:column;gap:11px}
.pkg li{display:flex;gap:10px;font-size:.95rem;line-height:1.4}
.pkg li svg{width:18px;height:18px;color:var(--teal);flex-shrink:0;margin-top:2px}
.pkg.featured li svg{color:var(--surf)}
.pkg .btn{margin-top:auto;justify-content:center;width:100%}

/* ============ MENU (restaurant) ============ */
.menu-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(30px,5vw,64px)}
.menu-col h3{font-family:var(--display);font-weight:500;font-size:1.5rem;margin-bottom:18px;color:var(--coral);display:flex;align-items:center;gap:.5em}
.menu-item{display:flex;justify-content:space-between;gap:16px;align-items:baseline;padding:14px 0;border-bottom:1px dashed rgba(6,24,28,.16)}
.menu-item .mi-name{font-weight:600;font-size:1.02rem}
.menu-item .mi-desc{font-size:.86rem;color:var(--muted);font-weight:400;display:block;margin-top:2px}
.menu-item .mi-price{font-family:var(--display);color:var(--teal);white-space:nowrap}

/* ============ GALLERY ============ */
.gal-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:170px;gap:14px}
.gal-grid figure{border-radius:12px;overflow:hidden;position:relative;display:flex;align-items:flex-end;padding:16px;border:1px solid rgba(205,234,226,.12)}
.gal-grid figure span{position:relative;z-index:2;color:rgba(205,234,226,.7);font-size:.78rem;letter-spacing:.12em;text-transform:uppercase}
.g1{grid-column:span 2;grid-row:span 2;background:radial-gradient(80% 80% at 30% 20%,rgba(84,184,172,.4),transparent),linear-gradient(160deg,#0a3d44,#04161a)}
.g2{background:linear-gradient(160deg,#13565c,#072529)}
.g3{background:linear-gradient(160deg,#1d7d82,#0a3d44)}
.g4{grid-column:span 2;background:radial-gradient(70% 90% at 80% 20%,rgba(239,131,84,.35),transparent),linear-gradient(160deg,#0a3d44,#04161a)}
.g5{background:linear-gradient(160deg,#0a3d44,#020c0f)}

/* ============ DIVE SITES ROWS ============ */
.site-row{display:flex;align-items:baseline;justify-content:space-between;gap:24px;padding:26px 0;border-top:1px solid rgba(6,24,28,.14);transition:.3s;flex-wrap:wrap}
.site-row:hover{padding-left:14px;background:linear-gradient(90deg,rgba(29,125,130,.06),transparent)}
.site-row:last-child{border-bottom:1px solid rgba(6,24,28,.14)}
.site-name{font-family:var(--display);font-size:clamp(1.4rem,3vw,2.1rem);font-weight:400;color:var(--ink);flex:1 1 auto}
.site-name .idx{font-size:.85rem;color:var(--teal);font-family:var(--body);font-weight:600;vertical-align:super;margin-right:.5em}
.site-desc{flex:2 1 320px;color:#3c5654;font-size:1rem;line-height:1.6}
.site-depth{font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;font-weight:700;color:#fff;background:var(--teal);padding:.5em 1em;border-radius:100px;white-space:nowrap}

/* ============ STATS ============ */
.stats{display:flex;gap:38px;margin-top:34px;flex-wrap:wrap}
.stat .n{font-family:var(--display);font-size:2.6rem;color:var(--teal);line-height:1}
.bg-dark .stat .n{color:var(--surf)}
.stat .l{font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-top:8px}
.bg-dark .stat .l{color:rgba(205,234,226,.6)}

/* ============ CTA BAND ============ */
.cta{padding:clamp(70px,10vw,130px) 0;color:var(--sand);position:relative;overflow:hidden;text-align:center;
  background:radial-gradient(100% 100% at 80% 0%,rgba(84,184,172,.3),transparent 60%),linear-gradient(150deg,#0a3d44,#04161a)}
.cta h2{font-family:var(--display);font-weight:400;font-size:clamp(2rem,5vw,3.6rem);line-height:1.02;letter-spacing:-.02em;max-width:18ch;margin:0 auto 20px}
.cta h2 em{font-style:italic;color:var(--amber)}
.cta p{color:rgba(205,234,226,.82);font-weight:300;font-size:1.1rem;max-width:48ch;margin:0 auto 32px;line-height:1.6}

/* ============ CONTACT ============ */
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:center;position:relative;z-index:2}
.contact .lead{font-size:1.1rem;line-height:1.65;color:rgba(205,234,226,.82);font-weight:300;max-width:46ch;margin-bottom:34px}
.info-card{background:rgba(4,22,26,.4);backdrop-filter:blur(10px);border:1px solid rgba(205,234,226,.15);border-radius:18px;padding:34px}
.info-row{display:flex;gap:16px;padding:16px 0;border-bottom:1px solid rgba(205,234,226,.1)}
.info-row:last-child{border-bottom:none}
.info-row svg{width:22px;height:22px;color:var(--amber);flex-shrink:0;margin-top:2px}
.info-row .k{font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--surf);margin-bottom:3px}
.info-row .v{font-size:1rem;color:var(--foam)}

/* ============ FOOTER ============ */
footer{background:var(--abyss);color:rgba(205,234,226,.6);padding:54px 0 36px;border-top:1px solid rgba(205,234,226,.08)}
.foot-top{display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap;margin-bottom:30px}
.foot-links{display:flex;gap:26px;flex-wrap:wrap}
.foot-links a{font-size:.9rem;transition:.25s}
.foot-links a:hover{color:var(--amber)}
.foot-bottom{font-size:.82rem;border-top:1px solid rgba(205,234,226,.08);padding-top:24px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap}

/* ============ RESPONSIVE ============ */
@media(max-width:900px){
  .nav-links{display:none;position:absolute;top:100%;right:28px;flex-direction:column;background:rgba(4,22,26,.95);padding:20px 26px;border-radius:14px;gap:18px}
  .menu-toggle{display:block}
  .split,.contact-grid{grid-template-columns:1fr}
  .cards,.packages{grid-template-columns:repeat(2,1fr)}
  .features,.menu-grid{grid-template-columns:1fr}
  .gal-grid{grid-template-columns:repeat(2,1fr)}
  .g1,.g4{grid-column:span 2}
  .scroll-cue{display:none}
}
@media(max-width:560px){
  .cards,.packages{grid-template-columns:1fr}
  .stats{gap:26px}
  .site-row{flex-direction:column;gap:8px}
}
