/* Dewberry Hideout — Main Site Styles */
@import url('variables.css');

*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:'Inter',sans-serif;background:var(--cream);color:var(--text);overflow-x:hidden;line-height:1.7;}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:20px 56px;display:flex;align-items:center;justify-content:space-between;background:rgba(247,240,226,0.95);backdrop-filter:blur(14px);border-bottom:1px solid var(--border);transition:all .3s;}
.nav-brand{display:flex;align-items:center;gap:14px;}
.nav-berry svg{width:32px;height:32px;}
.nav-name{font-family:'Playfair Display',serif;font-size:16px;font-weight:700;color:var(--text);letter-spacing:.3px;}
.nav-name span{color:var(--purple);}
.nav-sub{font-size:9px;letter-spacing:3px;text-transform:uppercase;color:var(--muted);}
.nav-links{display:flex;gap:32px;list-style:none;}
.nav-links a{color:var(--text2);font-size:11px;letter-spacing:1.5px;text-transform:uppercase;text-decoration:none;transition:color .2s;}
.nav-links a:hover{color:var(--purple);}
.nav-cta{background:var(--purple);color:#fff;font-size:11px;font-weight:600;letter-spacing:2px;text-transform:uppercase;padding:11px 26px;border-radius:var(--r);text-decoration:none;transition:background .2s;}
.nav-cta:hover{background:var(--red);}

/* HERO */
#hero{min-height:100vh;position:relative;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;}
.hero-bg{position:absolute;inset:0;
  background:
    radial-gradient(ellipse at 65% 25%, rgba(212,168,67,0.22) 0%, transparent 55%),
    radial-gradient(ellipse at 15% 75%, rgba(94,45,138,0.1) 0%, transparent 50%),
    radial-gradient(ellipse at 85% 75%, rgba(196,40,60,0.08) 0%, transparent 45%),
    linear-gradient(165deg, #F5E8CC 0%, #F2E0B8 45%, #EDD8A8 100%);
}
.hero-sun{position:absolute;top:8%;right:12%;width:280px;height:280px;background:radial-gradient(circle,rgba(212,168,67,0.4) 0%,rgba(212,168,67,0.12) 45%,transparent 70%);border-radius:50%;filter:blur(32px);}
/* SVG hill silhouette */
.hero-hills{position:absolute;bottom:0;left:0;right:0;pointer-events:none;}
/* Berry decorations — corners */
.b-corner{position:absolute;pointer-events:none;}
.b-tl{top:14%;left:5%;}
.b-tr{top:10%;right:6%;}
.b-bl{bottom:20%;left:3%;}
.b-br{bottom:16%;right:4%;}
.hero-content{position:relative;z-index:2;padding:130px 24px 80px;}
.hero-label{display:inline-block;font-size:10px;letter-spacing:4px;text-transform:uppercase;color:var(--text2);border:1px solid var(--border);padding:6px 18px;border-radius:var(--r);margin-bottom:28px;}
.hero-h{font-family:'Playfair Display',serif;font-size:clamp(58px,10vw,110px);font-weight:700;line-height:.92;letter-spacing:-2px;color:var(--text);margin-bottom:14px;}
.hero-h span{display:block;font-size:.42em;font-weight:400;font-style:italic;color:var(--purple);letter-spacing:3px;margin-top:10px;font-family:'Cormorant Garamond',serif;}
.hero-tag{font-family:'Cormorant Garamond',serif;font-size:clamp(16px,2.2vw,22px);font-style:italic;color:var(--text2);opacity:.8;margin-bottom:10px;}
.hero-meta{font-size:10px;letter-spacing:3.5px;text-transform:uppercase;color:var(--muted);margin-bottom:44px;}
.hero-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}
.btn-p{background:var(--purple);color:#fff;font-size:11px;font-weight:600;letter-spacing:2px;text-transform:uppercase;padding:15px 34px;border-radius:var(--r);text-decoration:none;transition:all .2s;}
.btn-p:hover{background:var(--red);}
.btn-o{background:transparent;color:var(--text);font-size:11px;font-weight:500;letter-spacing:2px;text-transform:uppercase;padding:15px 34px;border-radius:var(--r);text-decoration:none;border:1.5px solid rgba(36,20,8,.22);transition:all .2s;}
.btn-o:hover{border-color:var(--purple);color:var(--purple);}

/* SHARED */
.wrap{max-width:1160px;margin:0 auto;}
.eyebrow{font-size:10px;letter-spacing:4px;text-transform:uppercase;color:var(--purple);display:block;margin-bottom:14px;font-weight:600;}
.sh{font-family:'Playfair Display',serif;font-size:clamp(30px,4.5vw,50px);font-weight:700;line-height:1.1;color:var(--text);}
.sh em{color:var(--red);font-style:italic;}
.rule{width:48px;height:2px;background:linear-gradient(to right,var(--gold),rgba(212,168,67,0));margin:16px 0;}
.bt{font-size:15px;color:var(--text2);line-height:1.85;max-width:500px;}

/* INTRO */
#intro{background:var(--cream2);padding:68px 56px;border-top:1px solid var(--cream3);border-bottom:1px solid var(--cream3);text-align:center;}
.intro-q{font-family:'Cormorant Garamond',serif;font-size:clamp(17px,2.6vw,25px);font-style:italic;color:var(--text2);max-width:760px;margin:0 auto 44px;line-height:1.65;}
.s-row{display:flex;justify-content:center;max-width:640px;margin:0 auto;}
.s-item{flex:1;padding:18px;border-right:1px solid var(--cream3);}
.s-item:last-child{border-right:none;}
.s-item .n{font-family:'Playfair Display',serif;font-size:40px;font-weight:700;color:var(--purple);line-height:1;}
.s-item .l{font-size:9px;letter-spacing:3px;text-transform:uppercase;color:var(--muted);margin-top:7px;}

/* VENUE */
#venue{padding:110px 56px;background:var(--linen);}
.venue-grid{max-width:1160px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center;}
.v-img{border-radius:var(--r);overflow:hidden;aspect-ratio:3/4;position:relative;box-shadow:0 16px 48px rgba(36,20,8,0.1);}
.v-img-fill{width:100%;height:100%;background:linear-gradient(145deg,#EDD8A8 0%,#E0C888 40%,#D4B870 100%);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;}
.v-img-fill .icon{font-size:52px;opacity:.35;}
.v-img-fill .lbl{font-family:'Cormorant Garamond',serif;font-size:17px;font-style:italic;color:rgba(94,45,138,0.45);}
.v-img-fill .sub{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:rgba(94,45,138,0.3);}
/* small berry in image corner */
.v-corner-berry{position:absolute;top:16px;right:16px;opacity:.5;}
.v-pill-row{display:flex;flex-wrap:wrap;gap:8px;margin:22px 0;}
.vpill{background:var(--cream2);border:1px solid var(--cream3);border-radius:var(--r);padding:5px 14px;font-size:10px;letter-spacing:1px;text-transform:uppercase;color:var(--text2);}
.v-feats{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:24px;}
.vf{background:var(--cream2);border-radius:var(--r);padding:14px 16px;border-left:3px solid var(--gold);}
.vf .vi{font-size:17px;margin-bottom:5px;}
.vf strong{display:block;font-size:12px;color:var(--text);margin-bottom:2px;}
.vf span{font-size:11px;color:var(--muted);}

/* CABINS */
#cabins{padding:110px 56px;background:var(--cream);}
.cabins-hd{max-width:1160px;margin:0 auto 56px;display:flex;justify-content:space-between;align-items:flex-end;gap:32px;}
.cabin-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;max-width:1160px;margin:0 auto;}
.cabin{background:var(--linen);border-radius:var(--r);overflow:hidden;border:1px solid var(--cream3);transition:box-shadow .3s,transform .3s;}
.cabin:hover{transform:translateY(-5px);box-shadow:0 20px 44px rgba(36,20,8,0.1);}
.c-top{height:185px;position:relative;display:flex;align-items:flex-end;padding:14px;}
.cn1 .c-top{background:linear-gradient(145deg,#E8D4A0,#D8C080);}
.cn2 .c-top{background:linear-gradient(145deg,#DCCFC0,#C8B8A0);}
.cn3 .c-top{background:linear-gradient(145deg,#C8D4C0,#B0C0A0);}
.cn4 .c-top{background:linear-gradient(145deg,#CCC0D8,#B8A8C8);}
.c-num{position:absolute;top:10px;right:14px;font-family:'Playfair Display',serif;font-size:52px;font-weight:700;color:rgba(36,20,8,0.07);line-height:1;}
.c-tag{background:rgba(247,240,226,0.88);border-radius:var(--r);padding:4px 11px;font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--purple);font-weight:600;}
.c-body{padding:18px 18px 0;}
.c-name{font-family:'Playfair Display',serif;font-size:18px;color:var(--text);margin-bottom:3px;}
.c-size{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-bottom:12px;font-weight:600;}
.c-list{list-style:none;display:flex;flex-direction:column;gap:6px;margin-bottom:14px;}
.c-list li{font-size:12px;color:var(--muted);padding-left:14px;position:relative;}
.c-list li::before{content:'·';position:absolute;left:0;color:var(--red);font-size:16px;top:-2px;}
.c-link{display:block;text-align:center;padding:12px;font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--purple);text-decoration:none;border-top:1px solid var(--cream3);font-weight:600;transition:all .2s;}
.c-link:hover{background:var(--purple);color:#fff;}

/* GROUNDS */
#grounds{padding:110px 56px;background:var(--cream2);}
.grounds-grid{max-width:1160px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center;}
.pond-art{border-radius:var(--r);overflow:hidden;aspect-ratio:1;position:relative;box-shadow:0 16px 48px rgba(36,20,8,0.1);}
.pond-fill{width:100%;height:100%;
  background:
    radial-gradient(ellipse at 50% 68%,rgba(80,140,148,0.55) 0%,rgba(50,100,108,0.35) 38%,transparent 65%),
    radial-gradient(ellipse at 28% 38%,rgba(74,96,56,0.38) 0%,transparent 50%),
    linear-gradient(160deg,#D4E8D0 0%,#C0D8BC 35%,#A8C8B4 70%,#98BCAA 100%);
  position:relative;display:flex;align-items:center;justify-content:center;}
.pond-glow{width:150px;height:70px;background:radial-gradient(ellipse,rgba(255,255,255,0.45) 0%,transparent 70%);border-radius:50%;filter:blur(5px);}
.pond-oak{position:absolute;top:8%;right:12%;font-size:40px;opacity:.55;}
.pond-grass{position:absolute;bottom:12%;left:8%;font-size:28px;opacity:.5;}
.g-list{display:flex;flex-direction:column;gap:20px;margin-top:28px;}
.gl{display:flex;gap:16px;align-items:flex-start;}
.gl-ic{width:38px;height:38px;border-radius:var(--r);background:var(--cream3);display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0;}
.gl-bd strong{display:block;font-size:13px;color:var(--text);margin-bottom:3px;font-weight:600;}
.gl-bd p{font-size:13px;color:var(--muted);line-height:1.6;margin:0;}

/* SERVICES */
#services{padding:110px 56px;background:var(--linen);}
.svc-hd{max-width:1160px;margin:0 auto 52px;display:flex;justify-content:space-between;align-items:flex-end;}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;max-width:1160px;margin:0 auto;}
.svc{background:var(--cream);border-radius:var(--r);padding:26px;border:1px solid var(--cream3);transition:all .25s;}
.svc:hover{border-color:var(--purple2);box-shadow:0 8px 24px rgba(94,45,138,0.09);transform:translateY(-2px);}
.svc-ic{font-size:26px;margin-bottom:12px;display:block;}
.svc-nm{font-family:'Playfair Display',serif;font-size:16px;color:var(--text);margin-bottom:7px;}
.svc-ds{font-size:12px;color:var(--muted);line-height:1.7;}

/* BOOKING */
#booking{padding:110px 56px;background:var(--cream);}
.bk-wrap{max-width:840px;margin:0 auto;}
.bk-hd{text-align:center;margin-bottom:48px;}
.bk-hd .rule{margin:16px auto;}
.tab-row{display:grid;grid-template-columns:1fr 1fr;gap:2px;background:var(--cream3);border-radius:var(--r);overflow:hidden;margin-bottom:40px;}
.tb{background:var(--cream2);border:none;padding:16px;font-family:'Inter',sans-serif;font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);cursor:pointer;transition:all .25s;}
.tb.active{background:var(--purple);color:#fff;font-weight:600;}
.tp{display:none;grid-template-columns:1fr 1fr;gap:18px;}
.tp.active{display:grid;}
.field{display:flex;flex-direction:column;gap:7px;}
.field.full{grid-column:1/-1;}
.field label{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--purple);font-weight:600;}
.field input,.field select,.field textarea{background:var(--linen);border:1px solid var(--cream3);border-radius:var(--r);padding:12px 14px;color:var(--text);font-size:14px;font-family:'Inter',sans-serif;transition:border-color .2s;outline:none;appearance:none;}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--purple);}
.field select option{background:var(--cream);}
.field textarea{resize:vertical;min-height:100px;}
.sub-btn{grid-column:1/-1;padding:17px;background:var(--purple);color:#fff;font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;border:none;border-radius:var(--r);cursor:pointer;font-family:'Inter',sans-serif;transition:background .2s;width:100%;}
.sub-btn:hover{background:var(--red);}
.sub-note{grid-column:1/-1;text-align:center;font-size:11px;color:var(--muted);margin-top:4px;}

/* COTA */
#cota{padding:100px 56px;background:var(--cream2);text-align:center;position:relative;overflow:hidden;}
.cota-dec-l{position:absolute;left:-20px;top:50%;transform:translateY(-50%);}
.cota-dec-r{position:absolute;right:-20px;top:50%;transform:translateY(-50%);}
.cota-in{max-width:680px;margin:0 auto;position:relative;z-index:1;}
.cota-d{display:flex;gap:56px;justify-content:center;margin:44px 0;flex-wrap:wrap;}
.cd .n{font-family:'Playfair Display',serif;font-size:54px;font-weight:700;color:var(--purple);line-height:1;}
.cd .l{font-size:9px;letter-spacing:3px;text-transform:uppercase;color:var(--muted);margin-top:6px;}

/* LOCATION */
#location{padding:110px 56px;background:var(--linen);}
.loc-grid{max-width:1160px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start;}
.loc-map{border-radius:var(--r);border:1px solid var(--cream3);aspect-ratio:4/3;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;background:var(--cream2);box-shadow:0 8px 28px rgba(36,20,8,0.06);}
.loc-map span{font-size:38px;}
.loc-map p{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);}
.loc-map a{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--purple);text-decoration:none;border:1.5px solid var(--purple);padding:9px 22px;border-radius:var(--r);transition:all .2s;}
.loc-map a:hover{background:var(--purple);color:#fff;}
.loc-rows{margin-top:20px;display:flex;flex-direction:column;gap:0;}
.lr{display:flex;gap:14px;align-items:flex-start;padding:16px 0;border-bottom:1px solid var(--cream3);}
.lr:last-child{border-bottom:none;}
.lr-ic{width:34px;height:34px;border-radius:var(--r);background:var(--cream3);display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;}
.lr-tx strong{display:block;font-size:13px;color:var(--text);margin-bottom:2px;font-weight:600;}
.lr-tx span{font-size:12px;color:var(--muted);}

/* FOOTER */
footer{background:var(--text);padding:68px 56px 32px;}
.f-top{max-width:1160px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:52px;margin-bottom:44px;}
.fb .fn{font-family:'Playfair Display',serif;font-size:19px;font-weight:700;color:var(--cream);margin-bottom:4px;}
.fb .fn span{color:var(--gold2);}
.fb .fe{font-size:9px;letter-spacing:3px;text-transform:uppercase;color:rgba(247,240,226,0.35);margin-bottom:14px;display:block;}
.fb .fd{font-size:13px;color:rgba(247,240,226,0.45);line-height:1.8;max-width:240px;}
.f-social{display:flex;gap:10px;margin-top:18px;}
.f-social a{width:33px;height:33px;border-radius:var(--r);border:1px solid rgba(247,240,226,0.15);display:flex;align-items:center;justify-content:center;font-size:13px;text-decoration:none;color:rgba(247,240,226,0.4);transition:all .2s;}
.f-social a:hover{border-color:var(--gold);color:var(--gold);}
.fc h4{font-size:9px;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-bottom:16px;}
.fc ul{list-style:none;display:flex;flex-direction:column;gap:10px;}
.fc a{font-size:13px;color:rgba(247,240,226,0.45);text-decoration:none;transition:color .2s;}
.fc a:hover{color:var(--cream);}
.f-bot{max-width:1160px;margin:0 auto;border-top:1px solid rgba(247,240,226,0.08);padding-top:22px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;}
.f-bot p,.f-bot a{font-size:11px;color:rgba(247,240,226,0.3);text-decoration:none;}
.f-bot a:hover{color:var(--cream);}

/* ───── MOBILE NAVIGATION (hamburger + slide-in drawer) ───── */
.mobile-toggle{display:none;background:transparent;border:none;cursor:pointer;padding:10px;width:44px;height:44px;flex-direction:column;align-items:center;justify-content:center;gap:5px;margin-left:auto;-webkit-tap-highlight-color:transparent;}
.mobile-toggle .mt-line{width:24px;height:2px;background:var(--text,#241408);border-radius:2px;transition:transform .25s ease, opacity .2s ease;transform-origin:center;}
body.mobile-drawer-open .mobile-toggle .mt-line:nth-child(1){transform:translateY(7px) rotate(45deg);}
body.mobile-drawer-open .mobile-toggle .mt-line:nth-child(2){opacity:0;}
body.mobile-drawer-open .mobile-toggle .mt-line:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

.mobile-drawer-backdrop{position:fixed;inset:0;background:rgba(36,20,8,.55);opacity:0;pointer-events:none;transition:opacity .3s ease;z-index:998;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);}
body.mobile-drawer-open .mobile-drawer-backdrop{opacity:1;pointer-events:auto;}

.mobile-drawer{position:fixed;top:0;right:0;bottom:0;width:min(320px, 85vw);background:var(--linen,#FAF5EB);z-index:999;transform:translateX(100%);visibility:hidden;pointer-events:none;transition:transform .35s cubic-bezier(.4,0,.2,1), visibility 0s linear .35s;display:flex;flex-direction:column;box-shadow:-20px 0 40px -10px rgba(0,0,0,.2);padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);padding-right:env(safe-area-inset-right);overflow-y:auto;-webkit-overflow-scrolling:touch;}
body.mobile-drawer-open .mobile-drawer{transform:translateX(0);visibility:visible;pointer-events:auto;transition:transform .35s cubic-bezier(.4,0,.2,1), visibility 0s linear 0s;}

/* Hide mobile nav UI in print/screenshot tools that flatten fixed-position elements */
@media print{
  .mobile-toggle, .mobile-drawer, .mobile-drawer-backdrop, .mobile-drawer-foot, .mobile-drawer-cta, .mobile-drawer-header, .mobile-drawer-links{display:none !important;visibility:hidden !important;}
}

.mobile-drawer-header{display:flex;align-items:center;justify-content:space-between;padding:22px 24px 16px;border-bottom:1px solid var(--cream3,#E4D4B0);}
.mdh-brand{font-family:'Playfair Display',serif;font-size:16px;font-weight:700;color:var(--text,#241408);letter-spacing:.3px;}
.mdh-brand span{color:var(--purple,#5E2D8A);}
.mobile-drawer-close{background:transparent;border:none;font-size:22px;color:var(--text,#241408);cursor:pointer;width:40px;height:40px;border-radius:6px;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent;transition:background .2s;}
.mobile-drawer-close:hover,.mobile-drawer-close:active{background:var(--cream2,#F0E6CE);}

.mobile-drawer-links{list-style:none;padding:12px 0;margin:0;display:flex;flex-direction:column;gap:0;flex:1;}
.mobile-drawer-links li{border-bottom:1px solid var(--cream2,#F0E6CE);}
.mobile-drawer-links li:last-child{border-bottom:none;}
.mobile-drawer-links a{display:block;padding:18px 24px;color:var(--text,#241408);font-size:16px;font-weight:500;letter-spacing:1.5px;text-transform:uppercase;text-decoration:none;transition:all .2s;-webkit-tap-highlight-color:transparent;}
.mobile-drawer-links a:hover,.mobile-drawer-links a:active{background:var(--cream2,#F0E6CE);color:var(--purple,#5E2D8A);padding-left:30px;}

.mobile-drawer-cta{display:block;margin:20px 24px 12px;padding:16px 20px;background:var(--purple,#5E2D8A);color:#fff;font-size:12px;font-weight:700;letter-spacing:2px;text-transform:uppercase;text-align:center;text-decoration:none;border-radius:var(--r,6px);-webkit-tap-highlight-color:transparent;}
.mobile-drawer-cta:hover,.mobile-drawer-cta:active{background:var(--red,#C4283C);}

.mobile-drawer-foot{padding:16px 24px 24px;display:flex;flex-direction:column;gap:8px;border-top:1px solid var(--cream3,#E4D4B0);margin-top:auto;}
.mobile-drawer-foot a{font-size:12px;color:var(--muted,#957860);text-decoration:none;letter-spacing:.3px;}
.mobile-drawer-foot a:hover{color:var(--purple,#5E2D8A);}

/* Prevent iOS Safari auto-zoom on form focus */
input,select,textarea{font-size:16px;}

@media(max-width:960px){
  nav{padding:14px 20px;padding-top:max(14px, env(safe-area-inset-top));padding-left:max(20px, env(safe-area-inset-left));padding-right:max(20px, env(safe-area-inset-right));}
  .nav-links{display:none;}
  .nav-cta{display:none;} /* hidden on mobile — available inside drawer */
  .mobile-toggle{display:flex;}
  .nav-sub{display:none;} /* tighter mobile header */
  #hero .hero-content,#intro,#venue,#cabins,#grounds,#services,#booking,#cota,#location,footer{padding-left:24px;padding-right:24px;}
  .venue-grid,.grounds-grid,.loc-grid{grid-template-columns:1fr;gap:44px;}
  .cabin-grid{grid-template-columns:1fr 1fr;}
  .svc-grid{grid-template-columns:1fr 1fr;}
  .f-top{grid-template-columns:1fr 1fr;gap:28px;}
  .s-row{flex-wrap:wrap;}
  .svc-hd,.cabins-hd{flex-direction:column;align-items:flex-start;gap:14px;}
}
@media(max-width:600px){
  nav{padding:12px 16px;}
  .nav-name{font-size:15px;}
  .hero-h{font-size:44px;line-height:1.05;}
  .cabin-grid,.svc-grid{grid-template-columns:1fr;}
  .tp.active{grid-template-columns:1fr;}
  .f-top{grid-template-columns:1fr;}
  .cota-d{gap:28px;flex-wrap:wrap;}
  /* Scale down big display type on small phones */
  .sh{font-size:30px;line-height:1.1;}
  /* Stackable button rows */
  .hero-cta,.confirm-cta-row{flex-direction:column;width:100%;}
  .hero-cta a,.confirm-cta-row a{width:100%;text-align:center;}
  /* Ensure sections breathe on iPhone SE / 6.1" screens */
  section{padding-top:48px;padding-bottom:48px;}
}
@media(max-width:380px){
  .hero-h{font-size:36px;}
  .sh{font-size:26px;}
  .nav-name{font-size:14px;}
}
