/* ── RESET & BASE ── */
 *,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
 html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
 body{
   font-family:'Inter',sans-serif;
   background:#0a0f0a;
   color:#f0ece6;
   line-height:1.6;
   -webkit-font-smoothing:antialiased;
   -moz-osx-font-smoothing:grayscale;
   overflow-x:hidden;
 }

 :root{
   --rose:#c97d87;--rose-light:#e8b4bc;--rose-dark:#9e5a65;
   --gold:#c8963e;--gold-light:#e4d09e;--cream:#faf7f2;
   --text:#f0ece6;--dim:rgba(240,236,230,.55);--faint:rgba(240,236,230,.18);
   --border:rgba(255,255,255,.05);--card-bg:rgba(255,255,255,.015);
   --ease-out: cubic-bezier(0.16,1,0.3,1);
   --ease-spring: cubic-bezier(0.34,1.56,0.64,1);
 }

 /* ── ANIMATION KEYFRAMES ── */
 @keyframes fadeUp{from{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}
 @keyframes fadeIn{from{opacity:0}to{opacity:1}}
 @keyframes scaleIn{from{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}
 @keyframes slideDown{from{opacity:0;transform:translateY(-16px)}to{opacity:1;transform:translateY(0)}}
 @keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(201,125,135,.4)}50%{box-shadow:0 0 0 12px rgba(201,125,135,0)}}
 @keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
 @keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
 @keyframes scrollLine{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}50.01%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}
 @keyframes bgPulse{0%,100%{opacity:.6}50%{opacity:1}}

 /* ── REVEAL SYSTEM ── */
 .reveal{opacity:0;transform:translateY(40px);transition:opacity .8s var(--ease-out),transform .8s var(--ease-out)}
 .reveal.revealed{opacity:1;transform:translateY(0)}
 .reveal-d1{transition-delay:.05s}.reveal-d2{transition-delay:.1s}.reveal-d3{transition-delay:.15s}
 .reveal-d4{transition-delay:.2s}.reveal-d5{transition-delay:.25s}.reveal-d6{transition-delay:.3s}
 .reveal-d7{transition-delay:.35s}.reveal-d8{transition-delay:.4s}.reveal-d9{transition-delay:.45s}
 .reveal-d10{transition-delay:.5s}

 /* section labels/titles always animate */
 .section-label,.section-title,.section-sub{opacity:0;transform:translateY(30px);transition:opacity .7s var(--ease-out),transform .7s var(--ease-out)}
 .section-label.revealed,.section-title.revealed,.section-sub.revealed{opacity:1;transform:translateY(0)}
 .section-title{transition-delay:.05s}.section-sub{transition-delay:.1s}

 /* ── NAV ── */
 nav{
   position:fixed;top:0;left:0;right:0;z-index:1000;
   padding:16px clamp(18px,5vw,48px);
   display:flex;justify-content:space-between;align-items:center;
   transition:all .4s var(--ease-out);
   background:linear-gradient(180deg,rgba(10,15,10,.9) 0%,rgba(10,15,10,.3) 60%,transparent 100%);
 }
 nav.scrolled{
   background:rgba(10,15,10,.88);backdrop-filter:blur(24px) saturate(1.4);
   -webkit-backdrop-filter:blur(24px) saturate(1.4);
   border-bottom:1px solid rgba(255,255,255,.04);
   padding:10px clamp(18px,5vw,48px);
   box-shadow:0 1px 40px rgba(0,0,0,.3);
 }
 .nav-logo{
   font-family:'Cormorant Garamond',serif;
   font-weight:600;font-size:clamp(20px,3vw,24px);color:var(--cream);
   letter-spacing:2px;text-decoration:none;position:relative;z-index:1001;
   transition:color .3s;
 }
 .nav-logo span{color:var(--rose-light)}
 .nav-links{display:flex;gap:clamp(16px,3vw,28px);list-style:none}
 .nav-links a{
   font-size:11px;font-weight:500;color:rgba(250,247,240,.7);
   text-decoration:none;letter-spacing:3px;text-transform:uppercase;
   transition:color .3s;position:relative;padding:4px 0;
 }
 .nav-links a::after{
   content:'';position:absolute;bottom:0;left:0;width:0;height:1px;
   background:var(--rose-light);transition:width .3s var(--ease-out);
 }
 .nav-links a:hover{color:var(--rose-light)}
 .nav-links a:hover::after{width:100%}

 /* hamburger */
 .hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;z-index:1001;background:none;border:none;padding:8px}
 .hamburger span{display:block;width:24px;height:1.5px;background:var(--cream);border-radius:2px;transition:all .3s var(--ease-out)}
 .hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,4px)}
 .hamburger.open span:nth-child(2){opacity:0}
 .hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-4px)}

 /* mobile menu */
 .mobile-menu{
   position:fixed;inset:0;z-index:999;pointer-events:none;
   background:rgba(10,15,10,.96);backdrop-filter:blur(30px);
   -webkit-backdrop-filter:blur(30px);
   display:flex;align-items:center;justify-content:center;
   opacity:0;transition:opacity .4s var(--ease-out);
 }
 .mobile-menu.open{opacity:1;pointer-events:auto}
 .mobile-menu ul{list-style:none;text-align:center;display:flex;flex-direction:column;gap:24px}
 .mobile-menu a{
   font-family:'Cormorant Garamond',serif;
   font-size:clamp(28px,5vw,38px);color:var(--cream);text-decoration:none;
   font-weight:500;letter-spacing:2px;
   opacity:0;transform:translateY(20px);transition:all .5s var(--ease-out);
 }
 .mobile-menu.open a{opacity:1;transform:translateY(0)}
 .mobile-menu.open a:nth-child(1){transition-delay:.08s}
 .mobile-menu.open a:nth-child(2){transition-delay:.14s}
 .mobile-menu.open a:nth-child(3){transition-delay:.2s}
 .mobile-menu.open a:nth-child(4){transition-delay:.26s}
 .mobile-menu.open a:nth-child(5){transition-delay:.32s}
 .mobile-menu.open a:nth-child(6){transition-delay:.38s}

 /* ── HERO ── */
 .hero{
   height:100vh;min-height:600px;max-height:1080px;
   position:relative;display:flex;align-items:center;justify-content:center;
   text-align:center;overflow:hidden;
   padding-top:clamp(160px,22vh,190px);
   background:
     radial-gradient(ellipse 90% 55% at 50% 35%,rgba(201,125,135,.07) 0%,transparent 60%),
     radial-gradient(ellipse 65% 45% at 25% 75%,rgba(20,58,32,.45) 0%,transparent 55%),
     radial-gradient(ellipse 55% 45% at 75% 80%,rgba(200,150,62,.1) 0%,transparent 45%),
     #0a0f0a;
 }
 .hero::after{
   content:'';position:absolute;inset:0;z-index:1;opacity:.025;
   background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.55' numOctaves='4'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
   background-size:180px 180px;animation:bgPulse 8s ease-in-out infinite;
 }
 .hero-glow{
   position:absolute;z-index:0;
   width:600px;height:600px;border-radius:50%;
   background:radial-gradient(circle,rgba(201,125,135,.06) 0%,transparent 70%);
   top:50%;left:50%;transform:translate(-50%,-50%);
   animation:float 12s ease-in-out infinite;
 }
 .hero-content{position:relative;z-index:10;max-width:960px;padding:0 24px}
 .hero-badge{
   display:inline-flex;align-items:center;gap:10px;
   font-size:11px;font-weight:600;color:var(--rose-light);
   letter-spacing:6px;text-transform:uppercase;
   padding:10px 24px;margin-bottom:36px;
   border:1px solid rgba(201,125,135,.18);
   border-radius:40px;
   backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
   background:rgba(201,125,135,.04);
   animation:fadeUp .9s var(--ease-out) .2s both;
 }
 .hero-badge::before{
   content:'';width:6px;height:6px;
   background:var(--rose);border-radius:50%;
   box-shadow:0 0 12px var(--rose),0 0 24px var(--rose);
   animation:pulse 2.5s ease-in-out infinite;
 }
 .hero-title{
   font-family:'Cormorant Garamond',serif;
   font-weight:300;font-size:clamp(44px,8vw,88px);
   color:var(--cream);line-height:1.06;letter-spacing:-1px;
   animation:fadeUp .9s var(--ease-out) .35s both;
 }
 .hero-title em{
   font-style:italic;font-weight:400;
   background:linear-gradient(135deg,var(--rose-light) 0%,var(--rose) 30%,var(--gold-light) 70%,var(--gold) 100%);
   background-size:200% auto;
   -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
   animation:shimmer 4s linear infinite;
 }
 .hero-desc{
   font-size:clamp(15px,2vw,17px);font-weight:300;color:var(--dim);
   max-width:660px;margin:28px auto 0;line-height:1.65;
   animation:fadeUp .9s var(--ease-out) .5s both;
 }
 .hero-meta{
   display:flex;justify-content:center;gap:clamp(24px,5vw,48px);
   margin-top:40px;flex-wrap:wrap;
   animation:fadeUp .9s var(--ease-out) .65s both;
 }
 .hero-stat{text-align:center}
 .hero-stat-val{
   font-family:'Cormorant Garamond',serif;
   font-weight:600;font-size:40px;
   background:linear-gradient(180deg,var(--gold-light),var(--gold));
   -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
 }
 .hero-stat-lbl{
   font-size:10px;color:var(--dim);letter-spacing:3px;text-transform:uppercase;
   margin-top:2px;
 }
 .hero-cta-row{
   display:flex;justify-content:center;gap:16px;margin-top:44px;flex-wrap:wrap;
   animation:fadeUp .9s var(--ease-out) .8s both;
 }
 .hero-scroll{
   position:absolute;bottom:32px;left:50%;transform:translateX(-50%);z-index:10;
   display:flex;flex-direction:column;align-items:center;gap:8px;
   color:rgba(240,236,230,.18);font-size:9px;letter-spacing:4px;text-transform:uppercase;
 }
 .hero-scroll-line{
   width:1px;height:48px;position:relative;overflow:hidden;
 }

 .hero-scroll-line::after{
   content:'';position:absolute;inset:0;
   background:linear-gradient(180deg,transparent,var(--rose),transparent);
   animation:scrollLine 2s ease-in-out infinite;
 }

 /* ── BUTTONS ── */
 .btn{
   display:inline-flex;align-items:center;gap:8px;
   padding:13px 28px;font-size:12px;font-weight:600;
   letter-spacing:2.5px;text-transform:uppercase;
   text-decoration:none;border-radius:8px;
   transition:all .35s var(--ease-out);
   cursor:pointer;border:none;position:relative;overflow:hidden;
 }
 .btn::after{
   content:'';position:absolute;inset:0;opacity:0;
   background:linear-gradient(135deg,rgba(255,255,255,.08),transparent);
   transition:opacity .3s;
 }
 .btn:hover::after{opacity:1}
 .btn-rose{background:var(--rose);color:#fff;box-shadow:0 4px 20px rgba(201,125,135,.25)}
 .btn-rose:hover{background:var(--rose-dark);transform:translateY(-2px);box-shadow:0 8px 30px rgba(201,125,135,.35)}
 .btn-outline{border:1px solid rgba(201,125,135,.35);color:var(--rose-light);background:transparent}
 .btn-outline:hover{background:rgba(201,125,135,.08);border-color:var(--rose);transform:translateY(-2px)}
 .btn-gold{background:var(--gold);color:#fff;box-shadow:0 4px 20px rgba(200,150,62,.25)}
 .btn-gold:hover{background:#b8842e;transform:translateY(-2px);box-shadow:0 8px 30px rgba(200,150,62,.35)}

 /* ── SECTIONS ── */
 section{padding:clamp(80px,12vw,130px) clamp(18px,5vw,48px);position:relative}
 .section-label{
   font-size:10px;font-weight:600;color:var(--rose);letter-spacing:7px;
   text-transform:uppercase;text-align:center;margin-bottom:12px;
 }
 .section-title{
   font-family:'Cormorant Garamond',serif;
   font-weight:500;font-size:clamp(34px,5vw,54px);
   color:var(--cream);text-align:center;margin-bottom:14px;
 }
 .section-sub{
   font-size:clamp(14px,2vw,16px);color:var(--dim);text-align:center;
   max-width:640px;margin:0 auto clamp(48px,8vw,64px);line-height:1.65;
 }

 /* ── SECTION DIVIDERS ── */
 .section-divider{
   position:absolute;top:0;left:50%;transform:translateX(-50%);
   width:clamp(60px,10vw,100px);height:1px;
   background:linear-gradient(90deg,transparent,var(--rose),transparent);
   opacity:.4;
 }

 /* ── ENERGY ── */
 .energy{text-align:center}
 .energy-grid{
   display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
   gap:24px;max-width:1100px;margin:0 auto;
 }
 .energy-card{
   background:linear-gradient(180deg,rgba(255,255,255,.02),rgba(255,255,255,.005));
   border:1px solid var(--border);border-radius:16px;
   padding:40px 28px;text-align:center;
   transition:all .4s var(--ease-out);
   backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
 }
 .energy-card:hover{
   border-color:rgba(201,125,135,.15);
   transform:translateY(-6px);
   box-shadow:0 20px 50px rgba(0,0,0,.3),0 0 0 1px rgba(201,125,135,.08) inset;
 }
 .energy-icon{font-size:44px;margin-bottom:14px;transition:transform .4s var(--ease-spring)}
 .energy-card:hover .energy-icon{transform:scale(1.15)}
 .energy-card h4{
   font-family:'Cormorant Garamond',serif;
   font-weight:600;font-size:22px;color:var(--cream);margin-bottom:8px;
 }
 .energy-card p{font-size:14px;color:var(--dim);line-height:1.6}

 /* ── TIERS ── */
 .tier-grid{
   display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));
   gap:24px;max-width:1200px;margin:0 auto 48px;
 }
 .tier-card{
   background:linear-gradient(180deg,rgba(255,255,255,.02),rgba(255,255,255,.005));
   border:1px solid var(--border);border-radius:18px;overflow:hidden;
   transition:all .5s var(--ease-out);
   backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
 }
 .tier-card:hover{
   border-color:rgba(201,125,135,.18);
   transform:translateY(-8px);
   box-shadow:0 24px 60px rgba(0,0,0,.35);
 }
 .tier-header{
   padding:40px 28px 22px;text-align:center;
   border-bottom:1px solid var(--border);
   position:relative;overflow:hidden;
 }
 .tier-header::after{
   content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);
   width:40px;height:2px;border-radius:1px;
   transition:width .4s var(--ease-out);
 }
 .tier-card:nth-child(1) .tier-header::after{background:#aec6f0}
 .tier-card:nth-child(2) .tier-header::after{background:var(--gold-light)}
 .tier-card:nth-child(3) .tier-header::after{background:var(--rose-light)}
 .tier-card:hover .tier-header::after{width:80px}
 .tier-badge{
   display:inline-block;font-size:10px;font-weight:700;letter-spacing:5px;
   text-transform:uppercase;padding:6px 18px;border-radius:20px;margin-bottom:18px;
 }
 .badge-budget{background:rgba(142,180,227,.1);color:#aec6f0;border:1px solid rgba(142,180,227,.15)}
 .badge-mid{background:rgba(200,150,62,.1);color:var(--gold-light);border:1px solid rgba(200,150,62,.15)}
 .badge-premium{background:rgba(201,125,135,.1);color:var(--rose-light);border:1px solid rgba(201,125,135,.15)}
 .tier-price{
   font-family:'Cormorant Garamond',serif;
   font-weight:600;font-size:30px;color:var(--cream);margin-bottom:4px;
   transition:transform .3s var(--ease-spring);
 }
 .tier-card:hover .tier-price{transform:scale(1.05)}
 .tier-price small{font-size:13px;color:var(--dim);font-family:'Inter',sans-serif;font-weight:400}
 .tier-name{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:22px;color:var(--gold-light)}
 .tier-body{padding:28px}
 .tier-body > p{font-size:14px;color:var(--dim);line-height:1.6;margin-bottom:18px}
 .tier-features{list-style:none}
 .tier-features li{
   font-size:13px;color:var(--dim);padding:7px 0 7px 24px;
   position:relative;border-bottom:1px solid var(--border);
   transition:color .3s;
 }
 .tier-features li:hover{color:var(--text)}
 .tier-features li:last-child{border-bottom:none}
 .tier-features li::before{
   content:'✦';position:absolute;left:0;color:var(--rose-dark);font-size:7px;top:10px;
   transition:color .3s,transform .3s;
 }
 .tier-features li:hover::before{color:var(--rose-light);transform:scale(1.3)}

 /* ── AIRBNB ── */
 .airbnb-grid{
   display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
   gap:18px;max-width:1300px;margin:0 auto;
 }
 .airbnb-card{
   background:var(--card-bg);border:1px solid var(--border);
   border-radius:16px;overflow:hidden;
   transition:all .4s var(--ease-out);text-decoration:none;display:block;
 }
 .airbnb-card:hover{
   border-color:rgba(201,125,135,.15);
   transform:translateY(-4px);
   box-shadow:0 16px 40px rgba(0,0,0,.3);
 }
 .airbnb-img{
   width:100%;height:180px;position:relative;overflow:hidden;
   background:linear-gradient(135deg,#152415,#0d1f14);
   display:flex;align-items:center;justify-content:center;
 }
 .airbnb-img::after{
   content:'';position:absolute;inset:0;
   background:linear-gradient(180deg,transparent 50%,rgba(10,15,10,.6) 100%);
   transition:opacity .3s;
 }
 .airbnb-card:hover .airbnb-img::after{opacity:.8}
 .airbnb-img span{font-size:48px;opacity:.08;transition:transform .5s var(--ease-spring)}
 .airbnb-card:hover .airbnb-img span{transform:scale(1.1)}
 .airbnb-body{padding:18px 20px}
 .airbnb-body h4{
   font-family:'Cormorant Garamond',serif;
   font-weight:600;font-size:18px;color:var(--cream);margin-bottom:2px;
 }
 .airbnb-body .loc{font-size:11px;color:var(--dim);margin-bottom:8px}
 .airbnb-body .meta{display:flex;gap:14px;font-size:11px;color:var(--faint);margin-bottom:10px}
 .airbnb-body .price{
   font-family:'Cormorant Garamond',serif;
   font-weight:600;font-size:20px;color:var(--gold-light);
 }
 .airbnb-body .price small{font-size:10px;color:var(--dim);font-family:'Inter',sans-serif}

 /* ── EXTERNAL LINKS ── */
 .ext-links-grid{
   display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
   gap:14px;max-width:1000px;margin:0 auto;
 }
 .ext-link-card{
   background:var(--card-bg);border:1px solid var(--border);
   border-radius:14px;padding:28px 20px;text-align:center;
   transition:all .4s var(--ease-out);text-decoration:none;display:block;
 }
 .ext-link-card:hover{
   border-color:rgba(201,125,135,.15);
   transform:translateY(-3px);
   box-shadow:0 12px 35px rgba(0,0,0,.25);
 }
 .ext-link-card .pf{font-size:9px;font-weight:600;letter-spacing:4px;text-transform:uppercase;color:var(--faint);margin-bottom:8px}
 .ext-link-card h4{
   font-family:'Cormorant Garamond',serif;
   font-weight:600;font-size:19px;color:var(--cream);margin-bottom:6px;
 }

 .ext-link-card p{font-size:12px;color:var(--dim);line-height:1.5}

 /* ── CONCIERGE ── */
 .concierge-grid{
   display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
   gap:16px;max-width:1320px;margin:0 auto;
 }
 .concierge-card{
   background:var(--card-bg);border:1px solid var(--border);
   border-radius:14px;padding:28px 24px;
   transition:all .4s var(--ease-out);
   backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
 }
 .concierge-card:hover{
   border-color:rgba(201,125,135,.12);
   transform:translateY(-4px);
   box-shadow:0 16px 40px rgba(0,0,0,.25);
 }
 .cc-top{display:flex;align-items:center;gap:12px;margin-bottom:10px}
 .cc-icon{
   width:46px;height:46px;border-radius:12px;
   display:flex;align-items:center;justify-content:center;
   font-size:20px;flex-shrink:0;
   background:rgba(201,125,135,.06);color:var(--rose-light);
   transition:all .35s var(--ease-spring);
 }
 .concierge-card:hover .cc-icon{transform:scale(1.1);background:rgba(201,125,135,.12)}
 .concierge-card h4{
   font-family:'Cormorant Garamond',serif;
   font-weight:600;font-size:18px;color:var(--cream);
 }
 .concierge-card p{font-size:12px;color:var(--dim);line-height:1.6}

 /* ── LOCALS ── */
 .locals-grid{
   display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));
   gap:18px;max-width:1080px;margin:0 auto;
 }
 .local-card{
   background:var(--card-bg);border:1px solid var(--border);
   border-radius:14px;padding:32px 24px;text-align:center;
   transition:all .4s var(--ease-out);
 }
 .local-card:hover{
   border-color:rgba(200,150,62,.15);
   transform:translateY(-4px);
 }
 .local-card .icon{font-size:38px;margin-bottom:10px;transition:transform .35s var(--ease-spring);display:inline-block}
 .local-card:hover .icon{transform:scale(1.15)}
 .local-card h4{
   font-family:'Cormorant Garamond',serif;
   font-weight:600;font-size:20px;color:var(--cream);margin-bottom:6px;
 }
 .local-card p{font-size:13px;color:var(--dim);line-height:1.5}

 /* ── WHY US ── */
 .why-grid{
   display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));
   gap:18px;max-width:1080px;margin:0 auto;
 }
 .why-card{
   background:var(--card-bg);border:1px solid var(--border);
   border-radius:14px;padding:34px 24px;text-align:center;
   transition:all .4s var(--ease-out);
 }
 .why-card:hover{
   border-color:rgba(201,125,135,.12);
   transform:translateY(-4px);
 }
 .why-card .num{
   font-family:'Cormorant Garamond',serif;
   font-weight:700;font-size:44px;line-height:1;
   background:linear-gradient(180deg,var(--rose-light),var(--gold-light));
   -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
   margin-bottom:4px;
 }
 .why-card h4{
   font-family:'Cormorant Garamond',serif;
   font-weight:600;font-size:20px;color:var(--cream);margin:6px 0;
 }
 .why-card p{font-size:13px;color:var(--dim);line-height:1.5}

 /* ── BOOKING ── */
 .booking-platforms{
   display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));
   gap:14px;max-width:960px;margin:0 auto;
 }
 .platform-card{
   background:var(--card-bg);border:1px solid var(--border);
   border-radius:16px;padding:28px 16px;text-align:center;
   transition:all .4s var(--ease-out);text-decoration:none;display:block;
   backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
 }
 .platform-card:hover{
   border-color:rgba(201,125,135,.18);
   transform:translateY(-4px);
   box-shadow:0 16px 40px rgba(0,0,0,.3);
 }
 .platform-card h4{
   font-family:'Cormorant Garamond',serif;
   font-weight:600;font-size:18px;color:var(--cream);margin:8px 0 4px;
 }
 .platform-card p{font-size:10px;color:var(--dim);margin-bottom:14px}
 .platform-icon{
   width:52px;height:52px;margin:0 auto 4px;border-radius:14px;
   display:flex;align-items:center;justify-content:center;
   font-size:22px;font-weight:700;transition:transform .35s var(--ease-spring);
 }
 .platform-card:hover .platform-icon{transform:scale(1.1)}
 .pi-1{background:rgba(0,57,166,.15);color:#4d94ff}
 .pi-2{background:rgba(0,180,216,.12);color:#48cae4}
 .pi-3{background:rgba(255,56,92,.12);color:#ff5a7a}
 .pi-4{background:rgba(42,65,122,.15);color:#6b8cce}
 .pi-5{background:rgba(255,153,0,.12);color:#ffb347}

 .direct-book{
   background:linear-gradient(135deg,rgba(201,125,135,.04),rgba(200,150,62,.03));
   border:1px solid rgba(201,125,135,.12);
   border-radius:18px;padding:48px 36px;
   max-width:700px;margin:0 auto;text-align:center;
   backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
   transition:all .4s var(--ease-out);
 }
 .direct-book:hover{border-color:rgba(201,125,135,.2)}
 .direct-book h3{
   font-family:'Cormorant Garamond',serif;
   font-weight:600;font-size:clamp(22px,3vw,26px);color:var(--cream);margin-bottom:10px;
 }
 .direct-book p{font-size:14px;color:var(--dim);margin-bottom:24px}
 .direct-book .btn-rose{padding:16px 40px;font-size:13px}

 /* ── CONTACT ── */
 .contact-grid{
   display:grid;grid-template-columns:1fr 1fr;
   gap:24px;max-width:700px;margin:0 auto;
 }
 .contact-card{
   background:var(--card-bg);border:1px solid var(--border);
   border-radius:16px;padding:40px;text-align:center;
   transition:all .4s var(--ease-out);
   backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
 }
 .contact-card:hover{
   border-color:rgba(201,125,135,.15);
   transform:translateY(-4px);
 }
 .contact-card h4{
   font-family:'Cormorant Garamond',serif;
   font-weight:600;font-size:22px;color:var(--cream);margin:10px 0 6px;
 }
 .contact-card a{color:var(--rose-light);text-decoration:none;font-weight:500;font-size:15px;transition:color .3s}
 .contact-card a:hover{color:var(--rose)}
 .contact-card p{font-size:13px;color:var(--dim)}
 .contact-banner{
   max-width:640px;margin:48px auto 0;text-align:center;
   font-size:15px;color:var(--dim);line-height:1.7;
 }

 /* ── FOOTER ── */
 footer{
   padding:48px clamp(18px,5vw,48px);text-align:center;
   border-top:1px solid var(--border);
 }
 footer p{font-size:11px;color:rgba(240,236,230,.18);letter-spacing:2px}
 footer a{color:var(--rose-light);text-decoration:none;transition:color .3s}
 footer a:hover{color:var(--rose)}

 /* ── RESPONSIVE ── */
 @media(max-width:768px){
   .hamburger{display:flex}
   .nav-links{display:none}
   .contact-grid{grid-template-columns:1fr}
   .hero-meta{gap:20px}
   .hero-cta-row{flex-direction:column;align-items:center}
   .tier-grid{grid-template-columns:1fr;max-width:480px}
   .concierge-grid{grid-template-columns:1fr}
   .airbnb-grid{grid-template-columns:1fr 1fr}
   .locals-grid{grid-template-columns:1fr 1fr}
   .why-grid{grid-template-columns:1fr 1fr}
   .ext-links-grid{grid-template-columns:1fr 1fr}
   .hero-stat-val{font-size:30px}
   .tier-header{padding:30px 20px 18px}
   .tier-body{padding:22px 20px}
   .direct-book{padding:32px 20px}
 }
 @media(max-width:480px){
   .airbnb-grid{grid-template-columns:1fr}
   .locals-grid{grid-template-columns:1fr}
   .why-grid{grid-template-columns:1fr}
   .ext-links-grid{grid-template-columns:1fr}
   .hero-meta{flex-direction:column;align-items:center;gap:16px}
   .booking-platforms{grid-template-columns:1fr 1fr}
 }
/style>