:root{
  --ink:#081514; --deep:#0b2725; --emerald:#0f4941; --cream:#f5efe3; --sand:#d9b678; --coral:#e67955; --muted:#81908a; --line:rgba(255,255,255,.15);
  --shadow:0 30px 80px rgba(4,18,17,.28); --radius:28px;
}
*{box-sizing:border-box} html{scroll-behavior:smooth} body{margin:0;background:var(--cream);color:var(--ink);font-family:Inter, ui-sans-serif, system-ui, -apple-system, Segoe UI, sans-serif;line-height:1.55} a{text-decoration:none;color:inherit} img{max-width:100%;display:block}.wrap{width:min(1180px,calc(100% - 40px));margin:auto}.serif{font-family:Georgia, 'Times New Roman', serif}.eyebrow{letter-spacing:.18em;text-transform:uppercase;font-size:.72rem;font-weight:800;color:var(--coral)}
.nav{position:fixed;z-index:50;top:18px;left:50%;transform:translateX(-50%);width:min(1180px,calc(100% - 32px));border:1px solid rgba(255,255,255,.22);background:rgba(255, 255, 255, 0.45);backdrop-filter:blur(20px);border-radius:999px;padding:10px 12px;display:flex;align-items:center;justify-content:space-between;color:#fff;box-shadow:0 20px 70px rgba(0,0,0,.25)}.logo{display:flex;align-items:center;gap:12px}.logo img{width:156px;height:auto}.navlinks{display:flex;gap:22px;font-size:.78rem;text-transform:uppercase;letter-spacing:.08em}.cta{display:inline-flex;align-items:center;gap:10px;border:0;background:linear-gradient(135deg,var(--sand),var(--coral));color:#24120d;padding:13px 18px;border-radius:999px;font-weight:900;box-shadow:0 16px 35px rgba(230,121,85,.28)}.ghost{display:inline-flex;align-items:center;gap:10px;border:1px solid rgba(255,255,255,.28);color:#fff;padding:13px 18px;border-radius:999px;font-weight:800}.hero{position:relative;min-height:100vh;display:grid;align-items:end;overflow:hidden;background:#061414;color:#fff}.hero:before{content:"";position:absolute;inset:0;background:url('../img/hero-coast.jpg') center/cover no-repeat;transform:scale(1.04);filter:saturate(1.05) contrast(1.04)}.hero:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 72% 34%,rgba(217,182,120,.16),transparent 28%),linear-gradient(90deg,rgba(4,18,18,.94),rgba(4,18,18,.48) 42%,rgba(4,18,18,.15)),linear-gradient(0deg,rgba(8,21,20,1),rgba(8,21,20,0) 45%)}.hero-inner{position:relative;z-index:2;padding:140px 0 58px}.hero-grid{display:grid;grid-template-columns:1.05fr .65fr;gap:42px;align-items:end}.hero h1{font-size:clamp(3.5rem,8vw,8.6rem);line-height:.88;margin:20px 0 26px;letter-spacing:-.07em}.hero h1 span{display:block;color:var(--sand);font-style:italic;font-weight:400}.lead{font-size:1.16rem;max-width:560px;color:rgba(255,255,255,.82)}.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:32px}.hero-card{border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.08);backdrop-filter:blur(18px);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow)}.stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:22px}.stat{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);padding:16px;border-radius:18px}.stat b{display:block;font-size:1.45rem}.searchbar{position:relative;z-index:4;margin-top:44px;background:rgba(245,239,227,.96);color:var(--ink);border-radius:28px;padding:16px;display:grid;grid-template-columns:repeat(4,1fr) auto;gap:10px;box-shadow:0 30px 80px rgba(0,0,0,.24)}.searchbar div{padding:10px 16px;border-right:1px solid rgba(8,21,20,.1)}.searchbar small{display:block;color:#6e766f;text-transform:uppercase;font-size:.68rem;font-weight:900;letter-spacing:.12em}.searchbar strong{display:block;margin-top:4px}.section{padding:92px 0}.section-head{display:flex;align-items:end;justify-content:space-between;gap:20px;margin-bottom:34px}.section-head h2{font-size:clamp(2rem,4.2vw,4.4rem);line-height:.98;margin:0;letter-spacing:-.05em}.muted{color:#65736e}.trips{display:grid;grid-template-columns:1.1fr .9fr .9fr;gap:22px}.trip-card{position:relative;overflow:hidden;border-radius:30px;min-height:430px;color:#fff;box-shadow:var(--shadow);background:#123}.trip-card.small{min-height:360px}.trip-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:.8s transform}.trip-card:hover img{transform:scale(1.07)}.trip-card:after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(5,21,20,.92),rgba(5,21,20,.06) 60%)}.trip-content{position:absolute;z-index:2;left:24px;right:24px;bottom:24px}.pill{display:inline-flex;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.22);padding:7px 10px;border-radius:999px;font-size:.72rem;font-weight:900;letter-spacing:.08em;text-transform:uppercase}.trip-content h3{font-size:2rem;line-height:1;margin:16px 0 12px}.meta{display:flex;gap:14px;flex-wrap:wrap;color:rgba(255,255,255,.78);font-size:.9rem}.split{display:grid;grid-template-columns:.85fr 1.15fr;gap:42px;align-items:center}.panel{background:#fff;border-radius:34px;padding:34px;box-shadow:0 20px 70px rgba(8,21,20,.09);border:1px solid rgba(8,21,20,.07)}.dark-panel{background:linear-gradient(145deg,#08211f,#123e38);color:#fff}.feature-list{display:grid;gap:16px;margin-top:22px}.feature{display:flex;gap:14px;align-items:flex-start}.icon{width:42px;height:42px;border-radius:14px;background:rgba(217,182,120,.18);display:grid;place-items:center;color:var(--sand);font-weight:900}.experience-strip{background:#081514;color:#fff;overflow:hidden}.gallery{display:grid;grid-template-columns:1fr .65fr .65fr;gap:18px}.gallery img{width:100%;height:420px;object-fit:cover;border-radius:30px}.gallery img:nth-child(2),.gallery img:nth-child(3){height:200px}.demo-note{border:1px solid rgba(217,182,120,.45);background:rgba(217,182,120,.12);padding:18px;border-radius:20px;color:#fff}.footer{padding:54px 0;background:#061414;color:rgba(255,255,255,.75)}.footer-grid{display:flex;justify-content:space-between;gap:20px;align-items:center}.page-hero{position:relative;min-height:62vh;color:#fff;display:grid;align-items:end;overflow:hidden;background:#061414}.page-hero:before{content:"";position:absolute;inset:0;background:var(--bg) center/cover no-repeat;filter:saturate(1.04)}.page-hero:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(4,18,18,.9),rgba(4,18,18,.25)),linear-gradient(0deg,#081514,transparent 45%)}.page-hero .wrap{position:relative;z-index:2;padding:140px 0 58px}.page-hero h1{font-size:clamp(3rem,7vw,7.4rem);line-height:.9;margin:12px 0;letter-spacing:-.06em}.filter-row{display:flex;gap:12px;flex-wrap:wrap;margin:30px 0}.filter{border:1px solid rgba(8,21,20,.12);background:#fff;border-radius:999px;padding:12px 16px;font-weight:850}.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}.content-grid{display:grid;grid-template-columns:1fr 360px;gap:34px;align-items:start}.sticky{position:sticky;top:110px}.itinerary{display:grid;gap:14px}.day{display:grid;grid-template-columns:86px 1fr;gap:18px;border:1px solid rgba(8,21,20,.08);background:#fff;padding:20px;border-radius:22px}.booking-grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:34px}.form{display:grid;gap:14px}.input{width:100%;border:1px solid rgba(8,21,20,.12);background:#fff;padding:15px 16px;border-radius:16px;font:inherit}.pay-box{border:1px solid rgba(8,21,20,.08);background:linear-gradient(145deg,#fff,#f7efe2);padding:22px;border-radius:24px}.admin-shell{background:#081514;color:#fff;min-height:100vh;padding-top:120px}.admin-grid{display:grid;grid-template-columns:260px 1fr;gap:24px}.side{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:28px;padding:20px}.dash{display:grid;gap:22px}.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.dash-card{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1);border-radius:24px;padding:20px}.dash-card b{font-size:2rem}.table{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:28px;overflow:hidden}.row{display:grid;grid-template-columns:1.3fr .8fr .8fr .8fr;gap:10px;padding:18px 22px;border-bottom:1px solid rgba(255,255,255,.08)}.badge{display:inline-flex;width:max-content;padding:6px 10px;border-radius:999px;background:rgba(217,182,120,.16);color:#f5d99a;font-size:.75rem;font-weight:900}.mobile-menu{display:none}
@media(max-width:900px){.navlinks{display:none}.mobile-menu{display:block}.hero-grid,.split,.content-grid,.booking-grid,.admin-grid{grid-template-columns:1fr}.searchbar{grid-template-columns:1fr}.searchbar div{border-right:0;border-bottom:1px solid rgba(8,21,20,.08)}.trips,.grid3,.cards{grid-template-columns:1fr}.gallery{grid-template-columns:1fr}.gallery img,.gallery img:nth-child(n){height:260px}.hero h1,.page-hero h1{font-size:3.6rem}.footer-grid{display:grid}.sticky{position:static}.nav{top:10px}.logo img{width:132px}}

/* Premium V3 image-led refinements */
.image-panel{position:relative;overflow:hidden;min-height:520px;padding:0;background:#061414;border:0;box-shadow:0 34px 90px rgba(5,18,17,.28)}
.image-panel>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.76;filter:saturate(1.08) contrast(1.08)}
.image-panel:after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(6,20,20,.96),rgba(6,20,20,.28) 62%,rgba(6,20,20,.18))}
.image-panel-copy{position:absolute;z-index:2;left:34px;right:34px;bottom:34px}
.detail-gallery{grid-template-columns:repeat(4,1fr)}
.detail-gallery img{height:260px!important}
.trip-card,.panel,.hero-card,.searchbar{transform:translateZ(0)}
.trip-card:before{content:"";position:absolute;z-index:3;inset:0;border-radius:30px;box-shadow:inset 0 0 0 1px rgba(255,255,255,.18);pointer-events:none}
.admin-shell{position:relative;background:#081514;overflow-x:hidden}
.admin-shell:before{content:"";position:fixed;inset:0;background:linear-gradient(90deg,rgba(8,21,20,.96),rgba(8,21,20,.72)),url('../img/admin-backdrop.jpg') center/cover no-repeat;opacity:1;pointer-events:none}
.admin-shell main{position:relative;z-index:2}
.dash-card{box-shadow:0 20px 70px rgba(0,0,0,.18)}
.row:hover{background:rgba(255,255,255,.045)}
@media(max-width:900px){.image-panel{min-height:420px}.detail-gallery{grid-template-columns:1fr}.detail-gallery img{height:260px!important}.image-panel-copy{left:22px;right:22px;bottom:22px}}

/* Responsive hardening pass: 340px to desktop */
html, body { overflow-x: hidden; }
body { min-width: 320px; }
button, input, select, textarea { max-width: 100%; }

@media (max-width: 1100px){
  .wrap{width:min(100% - 32px, 980px)}
  .hero-grid{grid-template-columns:1fr .72fr;gap:28px}
  .trips{grid-template-columns:1fr 1fr}
  .trips .trip-card:first-child{grid-column:1 / -1;min-height:380px}
  .content-grid{grid-template-columns:1fr 320px}
  .page-hero h1{font-size:clamp(3rem, 6.6vw, 6.2rem)}
  .admin-grid{grid-template-columns:220px 1fr}
  .row{grid-template-columns:1.1fr .9fr .8fr .9fr}
}

@media (max-width: 900px){
  .wrap{width:calc(100% - 28px)}
  .nav{width:calc(100% - 24px);top:10px;padding:9px 10px;gap:10px}
  .nav .cta{padding:11px 14px;font-size:.82rem;white-space:nowrap}
  .navlinks{display:none}
  .mobile-menu{display:block}
  .hero{min-height:auto;align-items:start}
  .hero-inner{padding:116px 0 34px}
  .hero-grid,.split,.content-grid,.booking-grid,.admin-grid{grid-template-columns:1fr}
  .hero-card{margin-top:4px}
  .searchbar{grid-template-columns:1fr;margin-top:28px;border-radius:24px;padding:12px}
  .searchbar div{border-right:0;border-bottom:1px solid rgba(8,21,20,.08);padding:10px 12px}
  .searchbar .cta{width:100%;justify-content:center}
  .trips,.grid3,.cards{grid-template-columns:1fr}
  .trips .trip-card:first-child{grid-column:auto;min-height:330px}
  .trip-card,.trip-card.small{min-height:320px;border-radius:24px}
  .gallery{grid-template-columns:1fr}
  .gallery img,.gallery img:nth-child(n){height:260px}
  .hero h1{font-size:clamp(3rem, 12vw, 4.5rem);line-height:.9}
  .page-hero{min-height:auto}
  .page-hero .wrap{padding:116px 0 42px}
  .page-hero h1{font-size:clamp(2.7rem, 11vw, 4.4rem);line-height:.92;letter-spacing:-.055em}
  .lead{font-size:1.02rem;max-width:100%}
  .section{padding:62px 0}
  .section-head{display:grid;gap:14px;align-items:start;margin-bottom:26px}
  .section-head h2{font-size:clamp(2.2rem, 9vw, 3.5rem)}
  .footer-grid{display:grid;gap:22px;align-items:start}
  .sticky{position:static}
  .logo img{width:132px}
  .image-panel{min-height:420px}
  .detail-gallery{grid-template-columns:1fr 1fr}
  .detail-gallery img{height:220px!important}
  .day{grid-template-columns:1fr;gap:8px}
  .admin-shell{padding-top:96px}
  .admin-shell .section-head h1{font-size:clamp(2.6rem, 10vw, 4rem)!important}
  .table{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .row{min-width:660px}
  .side{order:2}
}

@media (max-width: 600px){
  :root{--radius:22px}
  .wrap{width:calc(100% - 22px)}
  .nav{width:calc(100% - 18px);border-radius:22px;background:rgba(255,255,255,.55)}
  .logo img{width:118px}
  .nav .cta{padding:10px 12px;font-size:.76rem}
  .hero-inner{padding:104px 0 28px}
  .hero h1{font-size:clamp(2.6rem, 14vw, 3.55rem);letter-spacing:-.06em;line-height:.92;margin:14px 0 18px}
  .hero h1 span{line-height:.94}
  .lead{font-size:.98rem;line-height:1.55}
  .hero-actions{gap:10px;margin-top:22px}
  .hero-actions .cta,.hero-actions .ghost{width:100%;justify-content:center}
  .hero-card,.panel{border-radius:24px;padding:22px}
  .hero-card h2{font-size:1.85rem!important}
  .stat-grid{grid-template-columns:repeat(3,1fr);gap:8px}
  .stat{padding:12px 10px;border-radius:16px}
  .stat b{font-size:1.15rem}
  .stat span{font-size:.78rem}
  .searchbar{border-radius:22px;padding:10px;margin-top:24px}
  .section{padding:50px 0}
  .section-head h2{font-size:clamp(2rem, 10.5vw, 3rem);line-height:1}
  .trip-card,.trip-card.small{min-height:300px;border-radius:22px}
  .trip-content{left:18px;right:18px;bottom:18px}
  .trip-content h3{font-size:1.65rem;margin:12px 0 10px}
  .meta{font-size:.82rem;gap:10px}
  .pill{font-size:.64rem;padding:6px 9px}
  .split{gap:26px}
  .image-panel{min-height:360px}
  .image-panel-copy{left:22px;right:22px;bottom:22px}
  .image-panel-copy h2{font-size:2.35rem!important}
  .feature{gap:12px}
  .icon{width:38px;height:38px;min-width:38px;border-radius:13px;font-size:.8rem}
  .gallery img,.gallery img:nth-child(n){height:220px;border-radius:22px}
  .page-hero .wrap{padding:104px 0 34px}
  .page-hero h1{font-size:clamp(2.35rem, 12.5vw, 3.35rem);line-height:.95;letter-spacing:-.05em}
  .filter-row{gap:8px;margin:20px 0}
  .filter{padding:10px 12px;font-size:.82rem}
  .content-grid{gap:24px}
  article h2[style], .booking-grid h2[style]{font-size:2.2rem!important;line-height:1.02!important}
  .detail-gallery{grid-template-columns:1fr 1fr;gap:10px!important;margin:24px 0!important}
  .detail-gallery img{height:145px!important;border-radius:18px}
  .day{padding:16px;border-radius:18px}
  .booking-grid{gap:22px}
  .form{gap:12px}
  .input{padding:13px 14px;border-radius:14px;font-size:.95rem}
  .dark-panel h2{font-size:2rem!important}
  .footer{padding:38px 0}
  .footer .cta{width:100%;justify-content:center}
  .cards{gap:12px}
  .dash-card{padding:16px;border-radius:20px}
  .dash-card b{font-size:1.65rem}
  .admin-shell main.wrap{width:calc(100% - 18px)}
  .admin-shell .section-head{gap:10px}
  .admin-shell .section-head h1{font-size:2.5rem!important}
  .side{display:none}
  .row{min-width:620px;padding:15px 16px}
}

@media (max-width: 420px){
  .wrap{width:calc(100% - 18px)}
  .nav{width:calc(100% - 14px);padding:8px;border-radius:20px}
  .logo img{width:106px}
  .nav .cta{padding:9px 10px;font-size:.7rem;max-width:145px;overflow:hidden;text-overflow:ellipsis}
  .hero-inner{padding-top:96px}
  .hero h1{font-size:clamp(2.35rem, 14.4vw, 3.05rem)}
  .page-hero .wrap{padding-top:96px}
  .page-hero h1{font-size:clamp(2.12rem, 13.2vw, 3rem)}
  .eyebrow{font-size:.64rem;letter-spacing:.15em}
  .lead{font-size:.94rem}
  .hero-card,.panel{padding:18px;border-radius:20px}
  .stat-grid{grid-template-columns:1fr 1fr 1fr}
  .stat{padding:10px 8px}
  .stat span{font-size:.7rem;line-height:1.2;display:block}
  .searchbar small{font-size:.6rem}.searchbar strong{font-size:.88rem}
  .section-head h2{font-size:2.05rem}
  .trip-card,.trip-card.small{min-height:280px}
  .trip-content h3{font-size:1.48rem}
  .image-panel{min-height:330px}
  .image-panel-copy h2{font-size:2rem!important}
  .detail-gallery img{height:130px!important}
  .gallery img,.gallery img:nth-child(n){height:200px}
  .demo-note{font-size:.9rem;padding:14px;border-radius:16px}
  .cta,.ghost{padding:12px 14px;font-size:.86rem}
  .pay-box{padding:16px;border-radius:18px}
  .admin-shell .nav .cta{max-width:110px}
}

@media (max-width: 360px){
  .logo img{width:98px}
  .nav .cta{font-size:.66rem;padding:8px 9px;max-width:126px}
  .hero h1{font-size:2.2rem;letter-spacing:-.05em}
  .page-hero h1{font-size:2rem;letter-spacing:-.045em}
  .section-head h2{font-size:1.9rem}
  .trip-card,.trip-card.small{min-height:260px}
  .trip-content{left:15px;right:15px;bottom:15px}
  .trip-content h3{font-size:1.34rem}
  .meta{font-size:.78rem}
  .detail-gallery{grid-template-columns:1fr}
  .detail-gallery img{height:170px!important}
  .stat-grid{grid-template-columns:1fr}
  .cards{grid-template-columns:1fr}
}


/* Mobile navigation drawer */
.mobile-menu{
  width:44px;height:44px;border:0;border-radius:999px;
  background:linear-gradient(135deg,var(--sand),var(--coral));
  display:none;align-items:center;justify-content:center;gap:4px;flex-direction:column;
  box-shadow:0 16px 35px rgba(230,121,85,.26);cursor:pointer;flex:0 0 auto;
}
.mobile-menu span{width:18px;height:2px;border-radius:99px;background:#20120d;display:block}
.mobile-drawer{position:fixed;inset:0;z-index:80;background:rgba(4,18,18,.72);backdrop-filter:blur(10px);opacity:0;pointer-events:none;transition:.22s ease}
.mobile-drawer.is-open{opacity:1;pointer-events:auto}
.mobile-drawer-panel{position:absolute;top:12px;right:10px;left:10px;background:#fbf6ec;color:var(--ink);border:1px solid rgba(8,21,20,.08);border-radius:26px;padding:16px;box-shadow:0 35px 90px rgba(0,0,0,.35);transform:translateY(-12px);transition:.22s ease;max-height:calc(100vh - 24px);overflow:auto}
.mobile-drawer.is-open .mobile-drawer-panel{transform:translateY(0)}
.mobile-drawer-head{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid rgba(8,21,20,.08)}
.mobile-drawer-head img{width:145px;height:auto}.mobile-close{width:42px;height:42px;border:0;border-radius:999px;background:#081514;color:#fff;font-size:1.7rem;line-height:1;cursor:pointer}.mobile-drawer a{display:flex;align-items:center;justify-content:space-between;padding:15px 4px;border-bottom:1px solid rgba(8,21,20,.08);font-weight:900;text-transform:uppercase;letter-spacing:.08em;font-size:.83rem}.mobile-drawer a:after{content:"→";color:var(--coral);font-size:1rem}.mobile-drawer .mobile-cta{margin-top:14px;border:0;border-radius:999px;background:linear-gradient(135deg,var(--sand),var(--coral));justify-content:center;color:#24120d;padding:15px 18px;box-shadow:0 16px 35px rgba(230,121,85,.22)}.mobile-drawer .mobile-cta:after{content:""}body.menu-open{overflow:hidden}
@media(max-width:900px){
  .nav{gap:10px}.navlinks{display:none!important}.nav .cta{display:none}.mobile-menu{display:flex}
}
@media(min-width:901px){.mobile-drawer{display:none!important}}
@media(max-width:420px){.mobile-menu{width:40px;height:40px}.mobile-drawer-head img{width:128px}.mobile-drawer-panel{border-radius:22px;padding:14px}.mobile-drawer a{font-size:.78rem;padding:14px 2px}}

/* Demo interaction polish */
.filter{cursor:pointer;transition:.22s ease transform,.22s ease box-shadow,.22s ease background}.filter:hover,.filter.is-active{transform:translateY(-2px);background:#081514;color:#fff;box-shadow:0 14px 34px rgba(8,21,20,.14)}.trip-card{transition:.28s ease opacity,.28s ease transform}.trip-card.is-hidden{display:none}.demo-success{display:none;border:1px solid rgba(15,73,65,.18);background:linear-gradient(145deg,#f7efe2,#fff);border-radius:20px;padding:16px 18px;color:var(--deep)}.demo-success.is-visible{display:grid;gap:4px}.demo-success strong{color:var(--emerald)}.demo-success span{color:#65736e}.dash-card,.panel,.trip-card{animation:softRise .45s ease both}@keyframes softRise{from{opacity:.001;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

/* Option 2 selling layer */
.platform-showcase{background:linear-gradient(180deg,#f5efe3,#fff7eb)}.portal-shell{background:#f5efe3}.portal-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:28px;align-items:start}.portal-card h2{font-size:clamp(2.1rem,4vw,3.7rem);line-height:1;margin:10px 0}.portal-top{display:flex;justify-content:space-between;gap:18px;align-items:flex-start}.premium-badge{background:rgba(230,121,85,.12);color:#b75335}.progress-track{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin:26px 0}.progress-track span{position:relative;background:#f7efe2;border:1px solid rgba(8,21,20,.08);border-radius:16px;padding:13px 12px;font-size:.78rem;font-weight:900;text-transform:uppercase;letter-spacing:.06em;color:#6f766f}.progress-track .is-done{background:rgba(15,73,65,.11);color:var(--emerald)}.progress-track .is-current{background:linear-gradient(135deg,var(--sand),var(--coral));color:#24120d}.premium-pay{display:grid;gap:10px}.premium-pay .cta{width:max-content}.portal-actions{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:18px}.portal-actions div{border:1px solid rgba(8,21,20,.08);background:#fff;border-radius:18px;padding:16px}.portal-actions strong,.portal-actions span{display:block}.portal-actions span{color:#65736e;font-size:.9rem;margin-top:4px}@media(max-width:900px){.portal-grid,.portal-actions,.progress-track{grid-template-columns:1fr}.portal-top{display:grid}.premium-pay .cta{width:100%;justify-content:center}}


/* === Responsive menu + logo hotfix === */
.nav{
  min-height:64px;
  padding:9px 12px;
}
.logo{
  min-width:0;
  flex:0 1 auto;
}
.logo img{
  width:clamp(170px, 15vw, 220px) !important;
  max-width:100%;
  height:auto;
}
.mobile-menu{
  position:relative;
  z-index:140;
  flex:0 0 auto;
  pointer-events:auto;
  cursor:pointer;
  touch-action:manipulation;
  -webkit-tap-highlight-color:transparent;
}
.mobile-drawer{
  z-index:120;
}
.mobile-drawer-panel,
.mobile-drawer a,
.mobile-close{
  pointer-events:auto;
  touch-action:manipulation;
}
@media(max-width:900px){
  .nav{
    width:calc(100% - 24px);
    top:10px;
    min-height:62px;
    padding:9px 10px 9px 14px;
  }
  .logo img{
    width:clamp(148px, 44vw, 190px) !important;
  }
  .mobile-menu{
    display:flex !important;
    width:46px;
    height:46px;
  }
}
@media(max-width:420px){
  .nav{
    width:calc(100% - 18px);
    padding:8px 8px 8px 12px;
  }
  .logo img{
    width:clamp(136px, 47vw, 168px) !important;
  }
  .mobile-menu{
    width:44px;
    height:44px;
  }
}
@media(max-width:360px){
  .logo img{
    width:132px !important;
  }
  .mobile-menu{
    width:42px;
    height:42px;
  }
}


/* === Admin page + mobile menu final hotfix === */
.admin-shell .nav{
  position:fixed !important;
  z-index:3000 !important;
  top:18px !important;
  left:50% !important;
  transform:translateX(-50%) !important;
}
.admin-shell{
  padding-top:120px;
}
.mobile-menu{
  margin-left:auto;
  border:0;
  appearance:none;
  -webkit-appearance:none;
  background:rgba(245,239,227,.92);
  position:relative;
  z-index:3002 !important;
  pointer-events:auto !important;
  cursor:pointer;
}
.mobile-drawer{
  z-index:4000 !important;
}
.mobile-drawer.is-open{
  opacity:1 !important;
  pointer-events:auto !important;
}
.mobile-drawer.is-open .mobile-drawer-panel{
  transform:translateY(0) !important;
}
@media(max-width:900px){
  .admin-shell .nav{
    top:10px !important;
  }
  .nav .mobile-menu{
    display:flex !important;
    align-items:center;
    justify-content:center;
  }
  .nav .cta{
    display:none !important;
  }
}
@media(min-width:901px){
  .nav .mobile-menu{
    display:none !important;
  }
}


/* === FINAL RELIABLE MOBILE MENU PATCH ===
   Uses a checkbox + label trigger so mobile navigation does not depend on JS click handling.
   Keep this block last. */
.mobile-nav-toggle{
  position:fixed !important;
  width:1px !important;
  height:1px !important;
  opacity:0 !important;
  pointer-events:none !important;
  overflow:hidden !important;
}
.nav{
  position:fixed !important;
  z-index:3000 !important;
  top:18px !important;
  left:50% !important;
  transform:translateX(-50%) !important;
}
.logo img{
  width:clamp(168px, 15vw, 220px) !important;
  height:auto !important;
  display:block !important;
}
.mobile-menu{
  border:0 !important;
  appearance:none !important;
  -webkit-appearance:none !important;
  width:46px !important;
  height:46px !important;
  border-radius:999px !important;
  background:linear-gradient(135deg,var(--sand),var(--coral)) !important;
  align-items:center !important;
  justify-content:center !important;
  gap:4px !important;
  flex-direction:column !important;
  box-shadow:0 16px 35px rgba(230,121,85,.26) !important;
  cursor:pointer !important;
  flex:0 0 auto !important;
  pointer-events:auto !important;
  touch-action:manipulation !important;
  -webkit-tap-highlight-color:transparent !important;
  position:relative !important;
  z-index:3002 !important;
  margin-left:auto !important;
}
.mobile-menu span{
  width:19px !important;
  height:2px !important;
  border-radius:99px !important;
  background:#20120d !important;
  display:block !important;
  transition:.18s ease !important;
}
.mobile-drawer{
  position:fixed !important;
  inset:0 !important;
  z-index:4000 !important;
  background:rgba(4,18,18,.72) !important;
  backdrop-filter:blur(10px) !important;
  opacity:0 !important;
  pointer-events:none !important;
  transition:.22s ease !important;
  display:block !important;
}
.mobile-drawer-panel{
  position:absolute !important;
  top:12px !important;
  right:10px !important;
  left:10px !important;
  background:#fbf6ec !important;
  color:var(--ink) !important;
  border:1px solid rgba(8,21,20,.08) !important;
  border-radius:26px !important;
  padding:16px !important;
  box-shadow:0 35px 90px rgba(0,0,0,.35) !important;
  transform:translateY(-12px) !important;
  transition:.22s ease !important;
  max-height:calc(100vh - 24px) !important;
  overflow:auto !important;
  pointer-events:auto !important;
}
.mobile-nav-toggle:checked ~ .mobile-drawer{
  opacity:1 !important;
  pointer-events:auto !important;
}
.mobile-nav-toggle:checked ~ .mobile-drawer .mobile-drawer-panel{
  transform:translateY(0) !important;
}
.mobile-drawer-head{
  display:flex !important;
  align-items:center !important;
  justify-content:space-between !important;
  gap:14px !important;
  margin-bottom:12px !important;
  padding-bottom:12px !important;
  border-bottom:1px solid rgba(8,21,20,.08) !important;
}
.mobile-drawer-head img{width:150px !important;height:auto !important;display:block !important;}
.mobile-close{
  width:42px !important;
  height:42px !important;
  border:0 !important;
  border-radius:999px !important;
  background:#081514 !important;
  color:#fff !important;
  font-size:1.7rem !important;
  line-height:40px !important;
  cursor:pointer !important;
  display:grid !important;
  place-items:center !important;
  touch-action:manipulation !important;
}
.mobile-drawer a{
  display:flex !important;
  align-items:center !important;
  justify-content:space-between !important;
  padding:15px 4px !important;
  border-bottom:1px solid rgba(8,21,20,.08) !important;
  font-weight:900 !important;
  text-transform:uppercase !important;
  letter-spacing:.08em !important;
  font-size:.83rem !important;
  color:var(--ink) !important;
}
.mobile-drawer a:after{content:"→";color:var(--coral);font-size:1rem;}
.mobile-drawer .mobile-cta{
  margin-top:14px !important;
  border:0 !important;
  border-radius:999px !important;
  background:linear-gradient(135deg,var(--sand),var(--coral)) !important;
  justify-content:center !important;
  color:#24120d !important;
  padding:15px 18px !important;
  box-shadow:0 16px 35px rgba(230,121,85,.22) !important;
}
.mobile-drawer .mobile-cta:after{content:"" !important;}
.admin-shell{padding-top:120px !important;}
.admin-shell .nav{position:fixed !important;}
@media(max-width:900px){
  .nav{top:10px !important;width:calc(100% - 24px) !important;min-height:62px !important;padding:9px 10px 9px 14px !important;gap:10px !important;}
  .navlinks{display:none !important;}
  .nav .cta{display:none !important;}
  .mobile-menu{display:flex !important;}
  .logo img{width:clamp(148px,44vw,190px) !important;}
}
@media(min-width:901px){
  .mobile-menu{display:none !important;}
  .mobile-drawer{display:none !important;}
}
@media(max-width:420px){
  .nav{width:calc(100% - 18px) !important;padding:8px 8px 8px 12px !important;border-radius:20px !important;}
  .logo img{width:clamp(136px,47vw,168px) !important;}
  .mobile-menu{width:44px !important;height:44px !important;}
  .mobile-drawer-head img{width:128px !important;}
  .mobile-drawer-panel{border-radius:22px !important;padding:14px !important;}
  .mobile-drawer a{font-size:.78rem !important;padding:14px 2px !important;}
}
@media(max-width:360px){
  .logo img{width:132px !important;}
  .mobile-menu{width:42px !important;height:42px !important;}
}
body.menu-open{overflow:hidden !important;}
