
:root {
  --blue:#0a77ff;
  --navy:#081f46;
  --yellow:#ffcb34;
  --orange:#ff7b22;
  --green:#17b469;
  --ink:#101828;
  --muted:#667085;
  --line:rgba(16,24,40,.10);
  --bg:#f7fbff;
  --white:#ffffff;
  --shadow:0 24px 70px rgba(8,31,70,.14);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  color:var(--ink);
  background:
    radial-gradient(circle at 12% 12%,rgba(255,203,52,.28),transparent 22%),
    radial-gradient(circle at 88% 16%,rgba(10,119,255,.15),transparent 25%),
    radial-gradient(circle at 50% 96%,rgba(23,180,105,.12),transparent 28%),
    var(--bg);
  overflow-x:hidden;
}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
.container{width:min(1180px,calc(100% - 40px));margin:0 auto}
.progress{position:fixed;top:0;left:0;width:0%;height:4px;z-index:99999;background:linear-gradient(90deg,var(--blue),var(--yellow),var(--orange))}

.site-header{position:fixed;top:16px;left:50%;transform:translateX(-50%);width:min(1180px,calc(100% - 40px));z-index:999;background:rgba(255,255,255,.83);backdrop-filter:blur(18px);border:1px solid rgba(255,255,255,.78);border-radius:999px;box-shadow:0 14px 42px rgba(8,31,70,.10)}
body.admin-bar .site-header{top:48px}
.nav{height:72px;display:flex;align-items:center;justify-content:space-between;gap:22px;padding:0 12px 0 16px}
.brand{display:flex;align-items:center;gap:12px;min-width:max-content}
.brand img{width:52px;height:52px;object-fit:cover;border-radius:50%;border:3px solid var(--blue);background:white}
.brand strong{display:block;font-size:19px;line-height:1;letter-spacing:-.02em}
.brand span{display:block;margin-top:5px;color:var(--muted);font-size:10px;font-weight:900;letter-spacing:.14em;text-transform:uppercase}
.menu{display:flex;align-items:center;gap:24px;color:var(--muted);font-size:13px;font-weight:800}
.menu a{position:relative;padding:8px 0}
.menu a:after{content:"";position:absolute;left:0;bottom:2px;width:0%;height:2px;border-radius:999px;background:var(--blue);transition:.25s}
.menu a:hover:after{width:100%}
.mobile-toggle{display:none;width:46px;height:46px;border:1px solid var(--line);border-radius:50%;background:white;align-items:center;justify-content:center;flex-direction:column;gap:4px;cursor:pointer}
.mobile-toggle span,.mobile-toggle:before,.mobile-toggle:after{content:"";display:block;width:20px;height:2px;background:var(--ink);border-radius:999px;transition:.25s}
.mobile-toggle.active span{opacity:0}
.mobile-toggle.active:before{transform:translateY(6px) rotate(45deg)}
.mobile-toggle.active:after{transform:translateY(-6px) rotate(-45deg)}

.btn,button.btn,input[type=submit].btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:999px;padding:14px 20px;font-size:14px;font-weight:900;border:1px solid transparent;transition:.25s;white-space:nowrap;cursor:pointer;line-height:1}
.btn:hover{transform:translateY(-2px);box-shadow:0 16px 34px rgba(8,31,70,.14)}
.btn.primary{background:var(--blue);color:white}
.btn.yellow{background:var(--yellow);color:#172033}
.btn.light{background:white;border-color:var(--line);color:var(--ink)}
.btn.dark{background:var(--navy);color:white}

.hero{position:relative;min-height:100vh;display:grid;align-items:center;padding:138px 0 88px;overflow:hidden}
.hero:before{content:"";position:absolute;right:-170px;top:100px;width:520px;height:520px;border-radius:50%;background:rgba(255,203,52,.24);filter:blur(10px);z-index:-1}
.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.kicker{display:inline-flex;align-items:center;gap:10px;color:#0750bd;font-size:12px;font-weight:950;letter-spacing:.16em;text-transform:uppercase}
.kicker:before{content:"";width:34px;height:2px;border-radius:999px;background:var(--yellow)}
h1,h2,h3,h4{margin:0;letter-spacing:-.045em;line-height:1}
h1{font-size:clamp(46px,6.2vw,78px);max-width:760px;margin-top:22px}
h2{font-size:clamp(36px,4.8vw,58px)}
.hero-copy{margin:26px 0 0;max-width:580px;color:var(--muted);font-size:18px;line-height:1.75}
.actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:32px}
.stats{margin-top:36px;max-width:620px;display:grid;grid-template-columns:repeat(3,1fr);background:rgba(255,255,255,.78);border:1px solid rgba(255,255,255,.82);border-radius:26px;overflow:hidden;box-shadow:0 18px 48px rgba(8,31,70,.08)}
.stat{padding:20px 14px;text-align:center}
.stat:not(:last-child){border-right:1px solid var(--line)}
.stat strong{display:block;font-size:30px;line-height:1}
.stat span{display:block;margin-top:7px;color:var(--muted);font-size:10px;font-weight:900;letter-spacing:.14em;text-transform:uppercase}
.visual{position:relative;min-height:640px}
.card{position:absolute;overflow:hidden;border-radius:34px;background:white;box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.82);will-change:transform}
.card img{width:100%;height:100%;object-fit:cover;transition:transform .9s cubic-bezier(.2,.8,.2,1)}
.card:hover img{transform:scale(1.045)}
.hero-main{right:0;top:20px;width:70%;height:450px}
.hero-side{left:0;bottom:44px;width:48%;height:320px;z-index:2}
.logo-panel{position:absolute;top:0;left:26px;z-index:3;width:190px;height:190px;border-radius:32px;padding:10px;background:white;box-shadow:0 20px 54px rgba(8,31,70,.15);animation:float 5s ease-in-out infinite}
.logo-panel img{width:100%;height:100%;object-fit:cover;border-radius:24px}
.mini-note{position:absolute;right:20px;bottom:0;z-index:4;width:290px;padding:22px;background:rgba(255,255,255,.88);backdrop-filter:blur(14px);border-radius:26px;box-shadow:0 20px 55px rgba(8,31,70,.13);animation:float 6s ease-in-out infinite reverse}
.mini-note strong{display:block;font-size:26px;line-height:1.05}
.mini-note span{display:block;margin-top:10px;color:var(--muted);line-height:1.55;font-size:13px}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}

.marquee-wrap{border-block:1px solid var(--line);background:rgba(255,255,255,.58);overflow:hidden;padding:18px 0}
.marquee{width:max-content;display:flex;animation:marquee 32s linear infinite}
.marquee span{white-space:nowrap;margin-right:38px;font-size:clamp(32px,4vw,54px);font-weight:950;letter-spacing:-.045em;color:rgba(16,24,40,.78)}
.marquee em{color:var(--orange);font-style:normal}
@keyframes marquee{to{transform:translateX(-50%)}}

section{padding:94px 0;position:relative}
.section-head{display:flex;justify-content:space-between;gap:34px;align-items:end;margin-bottom:42px}
.section-head h2{max-width:720px}
.section-head p{max-width:390px;margin:0;color:var(--muted);line-height:1.72;font-size:15px}
.reveal{opacity:0;transform:translateY(28px);transition:opacity .75s ease,transform .75s cubic-bezier(.2,.8,.2,1)}
.reveal.visible{opacity:1;transform:translateY(0)}

.packages-list{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.package-card{background:white;border-radius:30px;overflow:hidden;box-shadow:0 18px 48px rgba(8,31,70,.07);transition:.3s;border:1px solid rgba(255,255,255,.8)}
.package-card:hover{transform:translateY(-8px);box-shadow:0 28px 80px rgba(8,31,70,.12)}
.package-image{height:250px;overflow:hidden;background:#eaf5ff}
.package-image img{width:100%;height:100%;object-fit:cover;transition:transform .9s}
.package-card:hover img{transform:scale(1.04)}
.package-body{padding:22px}
.package-body small{display:block;color:var(--blue);font-size:11px;font-weight:900;letter-spacing:.16em;text-transform:uppercase;margin-bottom:12px}
.package-body h3{font-size:25px;line-height:1.05}
.package-body p{margin:14px 0 0;color:var(--muted);line-height:1.65;font-size:14px}
.package-price{display:inline-flex;margin-top:16px;background:var(--yellow);color:#14233a;padding:10px 14px;border-radius:999px;font-size:13px;font-weight:950}
.center{text-align:center}
.center .btn{margin-top:34px}

.portfolio{background:var(--navy);color:white;overflow:hidden}
.portfolio .section-head p{color:rgba(255,255,255,.72)}
.gallery-grid{display:grid;grid-template-columns:1.15fr .85fr .85fr;gap:18px}
.gallery-card{position:relative;overflow:hidden;border-radius:30px;min-height:280px;box-shadow:0 20px 55px rgba(0,0,0,.18)}
.gallery-card.large,.gallery-card.tall{min-height:560px}
.gallery-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 1s cubic-bezier(.2,.8,.2,1)}
.gallery-card:hover img{transform:scale(1.04)}
.gallery-card:after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.42),rgba(0,0,0,.06) 45%,transparent 70%)}
.gallery-label{position:absolute;left:18px;right:18px;bottom:18px;z-index:2;color:white}
.gallery-label strong{display:block;font-size:26px;line-height:1.05}
.gallery-label span{display:block;margin-top:8px;font-size:13px;color:rgba(255,255,255,.82)}

.home-booking{padding:96px 0;background:linear-gradient(180deg,rgba(255,255,255,.55),rgba(247,251,255,.95))}
.home-booking-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px;align-items:stretch}
.home-booking-visual{position:relative;border-radius:38px;overflow:hidden;box-shadow:var(--shadow);min-height:700px;background:var(--navy)}
.home-booking-visual img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.home-booking-visual:after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.58),rgba(0,0,0,.05) 55%)}
.home-booking-label{position:absolute;left:36px;right:36px;bottom:32px;z-index:2;color:white}
.home-booking-label strong{display:block;font-size:42px;line-height:1.05;letter-spacing:-.045em}
.home-booking-steps{display:grid;gap:22px}
.home-booking-card{background:white;border-radius:36px;padding:42px 44px;box-shadow:0 18px 48px rgba(8,31,70,.07);min-height:210px;border:1px solid rgba(255,255,255,.8)}
.step-badge{width:58px;height:58px;border-radius:50%;display:grid;place-items:center;background:var(--blue);color:white;font-size:21px;font-weight:950;margin-bottom:28px}
.home-booking-card h3{font-size:30px;letter-spacing:-.04em}
.home-booking-card p{color:var(--muted);line-height:1.75;font-size:16px;margin:14px 0 0}

.delivery-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:28px;align-items:stretch}
.map-card{background:white;box-shadow:var(--shadow);border-radius:36px;overflow:hidden}
.map-preview{min-height:380px;background:radial-gradient(circle at center,rgba(8,119,255,.22) 0 34%,transparent 35%),radial-gradient(circle at center,rgba(8,119,255,.10) 0 52%,transparent 53%),linear-gradient(45deg,#eef7ff 25%,#f8fcff 25%,#f8fcff 50%,#eef7ff 50%,#eef7ff 75%,#f8fcff 75%);background-size:100% 100%,100% 100%,36px 36px;position:relative}
.pin{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:62px;height:62px;border-radius:50%;display:grid;place-items:center;background:var(--blue);color:white;font-size:24px;font-weight:950;box-shadow:0 12px 30px rgba(8,119,255,.3)}
.delivery-content{background:white;border-radius:36px;padding:36px;box-shadow:0 18px 48px rgba(8,31,70,.07)}
.delivery-content p{color:var(--muted);line-height:1.75}

.cta-section{padding:108px 0 54px}
.cta{position:relative;overflow:hidden;min-height:420px;border-radius:42px;background:linear-gradient(100deg,rgba(8,31,70,.95),rgba(8,31,70,.58)),var(--navy);background-size:cover;background-position:center;box-shadow:var(--shadow);padding:52px;color:white;display:grid;align-items:end}
.cta-content{position:relative;z-index:2;max-width:720px}
.cta p{margin:20px 0 0;color:rgba(255,255,255,.76);max-width:560px;line-height:1.72}
.cta-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:30px}

.site-footer{background:#08172f;color:white;padding:0 0 40px}
.footer-grid{display:grid;grid-template-columns:1.1fr .85fr .85fr .85fr;gap:28px;padding:40px 0 30px}
.footer-brand img{width:110px;border-radius:20px;box-shadow:0 14px 32px rgba(0,0,0,.18)}
.footer-brand h4{margin-top:18px;font-size:26px;line-height:1.05}
.footer-brand p{margin:14px 0 0;color:rgba(255,255,255,.72);line-height:1.7;font-size:14px}
.footer-col h5{margin:0 0 18px;font-size:16px;letter-spacing:.04em;text-transform:uppercase;color:var(--yellow)}
.footer-list{display:grid;gap:11px;color:rgba(255,255,255,.78);font-size:14px;line-height:1.55}
.footer-list a{color:rgba(255,255,255,.78)}
.footer-list a:hover{color:white}
.footer-bar{border-top:1px solid rgba(255,255,255,.10);padding-top:20px;display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;color:rgba(255,255,255,.68);font-size:13px}

.booking-page,.single-package,.packages-archive{padding:140px 0 80px}
.booking-layout,.package-hero{display:grid;grid-template-columns:.9fr 1.1fr;gap:28px;align-items:start}
.sidebar{position:sticky;top:115px;display:grid;gap:16px}
.summary-card,.form-card{background:white;border-radius:32px;box-shadow:0 20px 55px rgba(7,31,71,.08);border:1px solid rgba(255,255,255,.8)}
.summary-card,.form-card{padding:26px}
.summary-line{display:flex;justify-content:space-between;gap:12px;padding:14px 0;border-top:1px solid var(--line);font-size:14px}
.summary-line strong{font-size:16px}
.total{margin-top:16px;padding:18px;border-radius:22px;background:#f1f8ff;border:1px solid rgba(8,119,255,.14)}
.total span{display:block;font-size:12px;color:var(--muted);font-weight:900;letter-spacing:.14em;text-transform:uppercase}
.total strong{display:block;margin-top:6px;font-size:34px;letter-spacing:-.04em;color:var(--blue)}
.form-section{padding:24px 0;border-bottom:1px solid var(--line)}
.form-section:first-child{padding-top:0}
.form-section:last-child{border-bottom:0;padding-bottom:0}
.form-section h3{font-size:29px;margin-bottom:18px}
.field-grid,.deposit-options,.payment-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field{display:grid;gap:7px;margin-bottom:14px}
label{font-size:13px;font-weight:850;color:#344054}
input,select,textarea{width:100%;border:1px solid var(--line);border-radius:16px;padding:14px;font:inherit;background:#fbfdff;outline:none}
textarea{min-height:105px;resize:vertical}
.option{position:relative;border:1px solid var(--line);background:#fbfdff;border-radius:22px;padding:18px;cursor:pointer;transition:.2s}
.option:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(7,31,71,.08)}
.option.active{border-color:var(--blue);background:#eef7ff;box-shadow:0 0 0 4px rgba(8,119,255,.08)}
.option input{position:absolute;opacity:0;pointer-events:none}
.option strong{display:block;font-size:19px;letter-spacing:-.02em}
.option span{display:block;margin-top:8px;color:var(--muted);font-size:13px;line-height:1.5}
.option b{display:inline-block;margin-top:14px;color:var(--blue);font-size:25px}
.calendar-box{border:1px dashed rgba(8,119,255,.34);border-radius:26px;overflow:hidden;background:#f0f8ff}
.calendar-head{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:18px 20px;background:white;border-bottom:1px solid var(--line)}
.calendar-placeholder{min-height:290px;display:grid;place-items:center;padding:28px;text-align:center}
.calendar-placeholder h4{font-size:28px;margin-bottom:12px}
.calendar-placeholder p{color:var(--muted);line-height:1.65;max-width:420px;margin:0 auto 20px}
.calendar-embed iframe{width:100%;min-height:520px;border:0}
.payment-card{border-radius:22px;padding:18px;min-height:120px;color:white;display:flex;flex-direction:column;justify-content:space-between;transition:.25s}
.payment-card:hover{transform:translateY(-3px);box-shadow:0 16px 34px rgba(7,31,71,.16)}
.payment-card strong{font-size:20px}
.payment-card span{font-size:13px;opacity:.85;line-height:1.45}
.payment-card.cash{background:#00c244}
.payment-card.zelle{background:#6d1ed4}
.payment-card.apple{background:#101828}
.payment-card.custom{background:var(--orange)}
.notice{margin-top:16px;padding:16px 18px;border-radius:20px;background:#fff8e7;border:1px solid rgba(255,204,50,.45);color:#684b00;font-size:14px;line-height:1.6}
.final-cta{padding:28px;border-radius:32px;background:linear-gradient(120deg,var(--navy),#063b86);color:white;margin-top:18px}
.final-cta h3{font-size:30px}
.final-cta p{color:rgba(255,255,255,.72);line-height:1.7}
.final-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:18px}
.form-message{padding:16px 18px;border-radius:20px;margin-bottom:18px}
.form-message.success{background:#ecfdf3;color:#027a48;border:1px solid rgba(2,122,72,.15)}
.form-message.error{background:#fff1f3;color:#b42318;border:1px solid rgba(180,35,24,.15)}
.package-hero img{width:100%;border-radius:38px;box-shadow:var(--shadow)}
.package-content{max-width:780px}
.package-content p,.package-content li{color:var(--muted);line-height:1.75}
.package-content ul{padding-left:20px}

@media(max-width:980px){
  .menu{position:fixed;left:20px;right:20px;top:96px;display:none;flex-direction:column;align-items:stretch;gap:0;background:white;border:1px solid var(--line);border-radius:26px;box-shadow:var(--shadow);padding:18px}
  body.admin-bar .menu{top:128px}
  .menu.open{display:flex}
  .menu a{padding:14px;border-bottom:1px solid var(--line)}
  .menu a:last-child{border-bottom:0}
  .mobile-toggle{display:flex}
  .nav>.btn.primary{display:none}
  .hero-grid,.delivery-grid,.booking-layout,.package-hero,.home-booking-grid{grid-template-columns:1fr}
  .hero{min-height:auto;padding-top:118px}
  .visual{min-height:560px}
  .section-head{display:block}
  .section-head p{margin-top:18px}
  .packages-list,.booking-cards{grid-template-columns:repeat(2,1fr)}
  .gallery-grid{grid-template-columns:1fr}
  .sidebar{position:static}
  .footer-grid{grid-template-columns:1fr 1fr}
  .home-booking-visual{min-height:500px}
}
@media(max-width:620px){
  .container{width:min(100% - 28px,1180px)}
  .site-header{top:10px;width:calc(100% - 24px);border-radius:24px}
  body.admin-bar .site-header{top:56px}
  body.admin-bar .menu{top:125px}
  .nav{height:auto;padding:12px}
  .brand img{width:44px;height:44px}
  .brand strong{font-size:17px}
  .brand span{font-size:9px}
  h1{font-size:42px}
  .hero-copy{font-size:16px}
  .actions,.cta-actions,.final-actions{flex-direction:column}
  .btn{width:100%}
  .stats{grid-template-columns:1fr}
  .stat:not(:last-child){border-right:0;border-bottom:1px solid var(--line)}
  .visual{min-height:560px}
  .hero-main{width:78%;height:360px}
  .hero-side{width:58%;height:250px}
  .logo-panel{width:126px;height:126px;left:10px;top:20px}
  .mini-note{width:220px;right:4px;padding:18px}
  .packages-list,.booking-cards,.field-grid,.deposit-options,.payment-grid,.footer-grid{grid-template-columns:1fr}
  section{padding:76px 0}
  .gallery-card.large,.gallery-card.tall{min-height:360px}
  .home-booking-visual{min-height:430px}
  .home-booking-label{left:24px;right:24px;bottom:24px}
  .home-booking-label strong{font-size:34px}
  .home-booking-card{padding:28px}
  .cta{padding:32px 24px;min-height:460px;border-radius:32px}
  .form-card,.summary-card{padding:20px}
  .booking-page,.single-package,.packages-archive{padding-top:118px}
}


.selected-package-card{
  margin:0 0 24px;
  padding:22px;
  border-radius:24px;
  background:#eef7ff;
  border:1px solid rgba(10,119,255,.16);
}
.selected-package-card span{
  display:block;
  color:#0750bd;
  font-size:11px;
  font-weight:950;
  letter-spacing:.16em;
  text-transform:uppercase;
  margin-bottom:8px;
}
.selected-package-card strong{
  display:block;
  font-size:26px;
  line-height:1.05;
  letter-spacing:-.035em;
}
.selected-package-card small{
  display:inline-flex;
  margin:12px 10px 0 0;
  background:white;
  border:1px solid rgba(10,119,255,.12);
  border-radius:999px;
  padding:8px 12px;
  color:var(--ink);
  font-weight:850;
}
.selected-package-card p{
  color:var(--muted);
  margin:14px 0 0;
  line-height:1.6;
}
