/* =========================================================
   Home page styles
   ========================================================= */
/* =========================================================
   Fonts
   ========================================================= */
@font-face{
  font-family:"Cera Pro";
  src:url("../fonts/CeraPro-Light.woff2") format("woff2");
  font-weight:300;
  font-style:normal;
  font-display:swap;
}
@font-face{
  font-family:"Cera Pro";
  src:url("../fonts/CeraPro-Regular.woff2") format("woff2");
  font-weight:400;
  font-style:normal;
  font-display:swap;
}
@font-face{
  font-family:"Cera Pro";
  src:url("../fonts/CeraPro-Medium.woff2") format("woff2");
  font-weight:500;
  font-style:normal;
  font-display:swap;
}
@font-face{
  font-family:"Cera Pro";
  src:url("../fonts/CeraPro-LightItalic.woff2") format("woff2");
  font-weight:300;
  font-style:italic;
  font-display:swap;
}
@font-face{
  font-family:"Cera Pro";
  src:url("../fonts/CeraPro-RegularItalic.woff2") format("woff2");
  font-weight:400;
  font-style:italic;
  font-display:swap;
}

:root{
    --font-main:"Cera Pro","Avenir Next",Avenir,"Helvetica Neue",Arial,sans-serif;
    --white:#FFFFFF;
    --paper:#FBFAF7;
    --paper-2:#F4F1EB;
    --ink:#0F1115;
    --ink-soft:#5C5F66;
    --mute:#9A9CA1;
    --rule:rgba(15,17,21,0.10);
    --rule-light:rgba(15,17,21,0.05);
    --accent:#2B4F5C;
  }

  *{margin:0;padding:0;box-sizing:border-box;}
  html{scroll-behavior:smooth;}
  body{
    font-family:var(--font-main);font-weight:300;
    color:var(--ink);background:var(--paper);
    line-height:1.7;-webkit-font-smoothing:antialiased;
    overflow-x:hidden;font-size:16px;
  }

  .display{font-family:var(--font-main);font-weight:300;letter-spacing:-0.015em;line-height:1;}
  .display em{font-style:italic;font-weight:300;}
  .eyebrow{font-family:var(--font-main);font-size:0.7rem;font-weight:300;letter-spacing:0.36em;text-transform:uppercase;color:var(--ink-soft);}
  .didot{font-family:var(--font-main);}

  /* —— Navigation —— */
  nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:1.6rem 3rem;display:flex;justify-content:space-between;align-items:center;transition:all 0.45s ease;color:var(--white);mix-blend-mode:difference;}
  nav.scrolled{padding:1.1rem 3rem;background:rgba(251,250,247,0.96);backdrop-filter:blur(10px);color:var(--ink);mix-blend-mode:normal;border-bottom:1px solid var(--rule-light);}
  .brand{font-family:var(--font-main);font-size:1.4rem;font-style:italic;font-weight:300;letter-spacing:0.01em;text-decoration:none;color:inherit;}
  .brand span{font-family:var(--font-main);font-style:normal;font-size:0.65rem;letter-spacing:0.32em;margin-left:0.45rem;text-transform:uppercase;opacity:0.8;}
  .nav-links{display:flex;gap:2.4rem;align-items:center;}
  .nav-links a{color:inherit;text-decoration:none;font-size:0.72rem;letter-spacing:0.24em;text-transform:uppercase;font-weight:300;position:relative;padding-bottom:3px;}
  .nav-links a::after{content:'';position:absolute;left:0;bottom:0;width:0;height:1px;background:currentColor;transition:width 0.4s ease;}
  .nav-links a:hover::after{width:100%;}
  .lang-toggle{font-size:0.65rem;letter-spacing:0.28em;display:flex;gap:0.4rem;}
  .lang-toggle a{opacity:0.45;color:inherit;text-decoration:none;}
  .lang-toggle a::after{display:none;}
  .lang-toggle .active{opacity:1;}
  .lang-toggle a:hover{opacity:0.8;}
  .lang-separator{opacity:0.45;}

  /* —— Hero —— */
  .hero{position:relative;height:100vh;min-height:680px;background-image:linear-gradient(180deg,rgba(15,17,21,0.18) 0%,rgba(15,17,21,0.32) 100%),url('/assets/images/exterior/exterior%20(1).jpg');background-size:cover;background-position:center;background-attachment:fixed;color:var(--white);display:flex;align-items:flex-end;overflow:hidden;}
  .hero-inner{padding:0 3rem 6rem;width:100%;max-width:1280px;margin:0 auto;}
  .hero .eyebrow{color:rgba(255,255,255,0.85);margin-bottom:1.8rem;}
  .hero h1{font-size:clamp(4rem,12vw,11rem);margin-bottom:1.2rem;letter-spacing:-0.025em;}
  .hero-sub{font-family:var(--font-main);font-style:italic;font-weight:300;font-size:clamp(1.05rem,1.5vw,1.35rem);opacity:0.92;max-width:440px;}
  .scroll-cue{position:absolute;bottom:2rem;right:3rem;font-size:0.62rem;letter-spacing:0.4em;text-transform:uppercase;opacity:0.75;display:flex;align-items:center;gap:0.7rem;color:#fff;}
  .scroll-cue::after{content:'';display:block;width:30px;height:1px;background:#fff;animation:line 2.4s ease-in-out infinite;transform-origin:left;}
  @keyframes line{0%,100%{transform:scaleX(0.4);opacity:0.4;}50%{transform:scaleX(1);opacity:0.95;}}

  /* —— Section base —— */
  section{padding:11rem 3rem;}
  .container{max-width:1280px;margin:0 auto;}
  .narrow{max-width:780px;margin:0 auto;}
  .chapter{display:flex;align-items:center;gap:1.1rem;margin-bottom:2.5rem;}
  .chapter::before{content:'';display:block;width:36px;height:1px;background:var(--ink-soft);}
  .section-headline{font-size:clamp(2.4rem,4.8vw,3.8rem);margin-bottom:2.5rem;max-width:14ch;}

  /* —— Story —— */
  .story{background:var(--paper);}
  .story-grid{display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:center;}
  .story-text p{font-size:1rem;margin-bottom:1.4rem;color:var(--ink-soft);max-width:46ch;}
  .story-text p.lead{font-family:var(--font-main);font-style:italic;font-weight:400;font-size:1.5rem;line-height:1.5;color:var(--ink);margin-bottom:2rem;max-width:30ch;}
  .story-image{aspect-ratio:4/5;background:url('/assets/images/rhodes/rhodes%20(6).jpg') center/cover;}

  /* —— Parallax —— */
  .parallax{position:relative;height:70vh;min-height:480px;background-attachment:fixed;background-size:cover;background-position:center;display:flex;align-items:center;justify-content:center;color:var(--white);text-align:center;overflow:hidden;}
  .parallax::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,17,21,0.15),rgba(15,17,21,0.40));}
  .parallax-content{position:relative;z-index:2;padding:0 2rem;max-width:760px;}
  .parallax-quote{font-family:var(--font-main);font-style:italic;font-weight:300;font-size:clamp(1.5rem,2.8vw,2.4rem);line-height:1.4;margin-bottom:1.6rem;}
  .parallax-attr{font-size:0.65rem;letter-spacing:0.4em;text-transform:uppercase;opacity:0.8;}
  .p1{background-image:url('/assets/images/exterior/exterior%20(2).jpg');}
  .p2{background-image:url('/assets/images/exterior/exterior%20(3).jpg');}

  /* —— Residences —— */
  .residences{background:var(--paper);}
  .res-intro{display:grid;grid-template-columns:1fr 1.2fr;gap:5rem;margin-bottom:6rem;align-items:end;}
  .res-intro p{font-size:1rem;color:var(--ink-soft);max-width:48ch;}
  .res-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:3rem 1.6rem;}
  .res-card{cursor:pointer;text-decoration:none;color:inherit;display:block;transition:transform 0.7s cubic-bezier(.2,.7,.2,1);}
  .res-card:hover{transform:translateY(-4px);}
  .res-card .img{aspect-ratio:3/4;background-size:cover;background-position:center;margin-bottom:1.2rem;overflow:hidden;transition:filter 0.6s ease;}
  .res-card:hover .img{filter:brightness(1.04);}
  .res-num{font-family:var(--font-main);font-size:0.7rem;letter-spacing:0.32em;color:var(--mute);margin-bottom:0.4rem;}
  .res-name{font-family:var(--font-main);font-style:italic;font-size:1.65rem;font-weight:300;margin-bottom:0.5rem;line-height:1;color:var(--ink);}
  .res-meta{font-size:0.68rem;letter-spacing:0.22em;text-transform:uppercase;color:var(--ink-soft);display:flex;gap:0.7rem;}
  .res-meta span:not(:last-child)::after{content:'·';margin-left:0.7rem;opacity:0.5;}

  .a1 .img{background-image:url('/assets/images/ap1_cotton/ap1_cotton%20(1).jpg');}
  .a2 .img{background-image:url('/assets/images/ap2_crepe/ap2_crepe%20(1).jpg');}
  .a3 .img{background-image:url('/assets/images/ap3_linen/ap3_linen%20(1).jpg');}
  .a4 .img{background-image:url('/assets/images/ap4_silk/ap4_silk%20(1).jpg');}
  .a5 .img{background-image:url('/assets/images/ap5_velvet/ap5_velvet%20(1).jpg');}
  .a6 .img{background-image:url('/assets/images/ap6_satin/ap6_satin%20(1).jpg');}
  .a7 .img{background-image:url('/assets/images/ap7_chiffon/placeholder.jpg');}
  .a8 .img{background-image:url('/assets/images/ap8_voile/placeholder.jpg');}

  /* —— Gallery —— */
  .gallery{background:var(--white);padding:11rem 3rem 9rem;}
  .gallery-head{display:grid;grid-template-columns:1fr 1.4fr;gap:5rem;margin-bottom:5rem;align-items:end;}
  .gallery-head p{font-size:1rem;color:var(--ink-soft);max-width:48ch;}
  .gallery-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:1rem;}
  .g{background-size:cover;background-position:center;}
  .g1{grid-column:span 5;aspect-ratio:4/5;background-image:url('/assets/images/exterior/exterior%20(4).jpg');}
  .g2{grid-column:span 7;aspect-ratio:1.4;background-image:url('/assets/images/exterior/exterior%20(5).jpg');}
  .g3{grid-column:span 4;aspect-ratio:1;background-image:url('/assets/images/exterior/exterior%20(6).jpg');}
  .g4{grid-column:span 4;aspect-ratio:1;background-image:url('/assets/images/exterior/exterior%20(7).jpg');}
  .g5{grid-column:span 4;aspect-ratio:1;background-image:url('/assets/images/exterior/exterior%20(8).jpg');}
  .g6{grid-column:span 7;aspect-ratio:1.4;background-image:url('/assets/images/exterior/exterior%20(9).jpg');}
  .g7{grid-column:span 5;aspect-ratio:4/5;background-image:url('/assets/images/exterior/exterior%20(10).jpg');}
  .gallery-cta{margin-top:4rem;text-align:center;}
  .text-link{color:var(--ink);text-decoration:none;font-size:0.7rem;letter-spacing:0.32em;text-transform:uppercase;border-bottom:1px solid var(--ink);padding-bottom:5px;transition:all 0.3s ease;}
  .text-link:hover{color:var(--accent);border-color:var(--accent);}

  /* —— Location —— */
  .location{background:var(--paper);padding-bottom:0;}
  .loc-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:0;align-items:stretch;}
  .loc-text{padding:0 5rem 6rem 0;}
  .loc-text p{color:var(--ink-soft);font-size:1rem;margin-bottom:1.4rem;max-width:42ch;}
  .address{margin-top:2.8rem;padding-top:2rem;border-top:1px solid var(--rule);font-family:var(--font-main);font-size:1.1rem;line-height:1.75;color:var(--ink);}
  .address .eyebrow{margin-bottom:0.9rem;display:block;font-family:var(--font-main);font-size:0.65rem;}
  .map-wrap{position:relative;aspect-ratio:4/5;min-height:520px;background:#E8E5DD;overflow:hidden;}
  .map-wrap iframe{width:100%;height:100%;border:0;filter:grayscale(0.65) contrast(0.92);}
  .map-pin{position:absolute;top:1.5rem;left:1.5rem;z-index:2;background:var(--white);padding:1rem 1.4rem;font-size:0.72rem;letter-spacing:0.18em;text-transform:uppercase;border:1px solid var(--rule);}
  .map-pin .didot{display:block;font-size:0.95rem;letter-spacing:0.04em;text-transform:none;margin-top:0.3rem;color:var(--ink);}

  /* —— Reserve —— */
  .reserve{background:var(--white);padding:11rem 3rem;}
  .reserve-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:6rem;align-items:start;}
  .reserve-text .section-headline{margin-bottom:2rem;}
  .reserve-text p{font-family:var(--font-main);font-style:italic;font-size:1.3rem;line-height:1.55;color:var(--ink-soft);max-width:30ch;margin-bottom:2.5rem;}
  .reserve-text .small{font-family:var(--font-main);font-style:normal;font-size:0.85rem;line-height:1.7;color:var(--ink-soft);}
  .reserve-text .small strong{font-weight:400;color:var(--ink);}
  form{display:grid;gap:2rem;}
  .row{display:grid;grid-template-columns:1fr 1fr;gap:2rem;}
  .field{display:flex;flex-direction:column;border-bottom:1px solid var(--rule);padding-bottom:0.9rem;}
  .field label{font-size:0.65rem;letter-spacing:0.32em;text-transform:uppercase;color:var(--mute);margin-bottom:0.6rem;}
  .field input,.field textarea,.field select{border:none;background:transparent;font-family:var(--font-main);font-size:1rem;color:var(--ink);padding:0.2rem 0;outline:none;font-weight:300;}
  .field input::placeholder,.field textarea::placeholder{color:var(--mute);font-style:italic;}
  .field textarea{resize:none;min-height:90px;font-family:var(--font-main);font-style:italic;font-size:1.1rem;}
  .submit{margin-top:1rem;padding:1.1rem 3rem;background:var(--ink);color:var(--white);font-family:var(--font-main);font-size:0.72rem;letter-spacing:0.32em;text-transform:uppercase;font-weight:300;border:1px solid var(--ink);cursor:pointer;transition:all 0.4s ease;justify-self:start;}
  .submit:hover{background:transparent;color:var(--ink);}

  /* —— Footer —— */
  footer{background:var(--paper-2);color:var(--ink-soft);padding:5rem 3rem 2rem;font-size:0.85rem;}
  .foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;max-width:1280px;margin:0 auto 3rem;}
  footer h4{font-family:var(--font-main);font-size:0.65rem;letter-spacing:0.32em;text-transform:uppercase;color:var(--ink);margin-bottom:1.2rem;font-weight:400;}
  footer .brand{color:var(--ink);font-size:1.5rem;margin-bottom:0.8rem;display:inline-block;}
  footer p,footer a{color:var(--ink-soft);text-decoration:none;line-height:1.85;}
  footer a:hover{color:var(--ink);}
  footer h4 .fa{letter-spacing:0;margin-right:.55rem;}
  footer p .fa{letter-spacing:0;margin-right:.45rem;}
  .foot-bottom{max-width:1280px;margin:0 auto;padding-top:2rem;border-top:1px solid var(--rule);display:flex;justify-content:space-between;font-size:0.7rem;letter-spacing:0.18em;color:var(--mute);}

  /* —— Responsive —— */
  @media(max-width:980px){
    nav{padding:1.1rem 1.4rem;}
    nav.scrolled{padding:0.8rem 1.4rem;}
    .nav-links{gap:1rem;}
    .nav-links > a{font-size:0.65rem;letter-spacing:0.16em;}
    section,.gallery,.reserve{padding:6rem 1.4rem;}
    .hero-inner{padding:0 1.4rem 3.5rem;}
    .scroll-cue{right:1.4rem;}
    .story-grid,.res-intro,.gallery-head,.loc-grid,.reserve-grid{grid-template-columns:1fr;gap:3rem;}
    .loc-text{padding:0 0 3rem 0;}
    .res-grid{grid-template-columns:repeat(2,1fr);gap:2.5rem 1.2rem;}
    .gallery-grid{grid-template-columns:repeat(6,1fr);}
    .g1,.g2,.g3,.g4,.g5,.g6,.g7{grid-column:span 6;aspect-ratio:1.3;}
    .row{grid-template-columns:1fr;}
    .foot-grid{grid-template-columns:1fr 1fr;}
    .hero,.parallax{background-attachment:scroll;}
  }
  @media(max-width:520px){
    .res-grid{grid-template-columns:1fr;}
    .foot-grid{grid-template-columns:1fr;}
    .nav-links > a{display:none;}
    .foot-bottom{flex-direction:column;gap:0.8rem;}
  }

/* =========================================================
   Residence page styles
   ========================================================= */
:root{
    --white:#FFFFFF;
    --paper:#FBFAF7;
    --paper-2:#F4F1EB;
    --ink:#0F1115;
    --ink-soft:#5C5F66;
    --mute:#9A9CA1;
    --rule:rgba(15,17,21,0.10);
    --rule-light:rgba(15,17,21,0.05);
    --accent:#2B4F5C;
  }
  *{margin:0;padding:0;box-sizing:border-box;}
  html{scroll-behavior:smooth;}
  body{font-family:var(--font-main);font-weight:300;color:var(--ink);background:var(--paper);line-height:1.7;-webkit-font-smoothing:antialiased;overflow-x:hidden;font-size:16px;}

  .display{font-family:var(--font-main);font-weight:300;letter-spacing:-0.015em;line-height:1;}
  .display em{font-style:italic;font-weight:300;}
  .eyebrow{font-family:var(--font-main);font-size:0.7rem;font-weight:300;letter-spacing:0.36em;text-transform:uppercase;color:var(--ink-soft);}
  .didot{font-family:var(--font-main);}

  /* —— Nav (same as main) —— */
  nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:1.6rem 3rem;display:flex;justify-content:space-between;align-items:center;transition:all 0.45s ease;color:var(--white);mix-blend-mode:difference;}
  nav.scrolled{padding:1.1rem 3rem;background:rgba(251,250,247,0.96);backdrop-filter:blur(10px);color:var(--ink);mix-blend-mode:normal;border-bottom:1px solid var(--rule-light);}
  .brand{font-family:var(--font-main);font-size:1.4rem;font-style:italic;font-weight:300;text-decoration:none;color:inherit;}
  .brand span{font-family:var(--font-main);font-style:normal;font-size:0.65rem;letter-spacing:0.32em;margin-left:0.45rem;text-transform:uppercase;opacity:0.8;}
  .nav-links{display:flex;gap:2.4rem;align-items:center;}
  .nav-links a{color:inherit;text-decoration:none;font-size:0.72rem;letter-spacing:0.24em;text-transform:uppercase;font-weight:300;position:relative;padding-bottom:3px;}
  .nav-links a::after{content:'';position:absolute;left:0;bottom:0;width:0;height:1px;background:currentColor;transition:width 0.4s ease;}
  .nav-links a:hover::after{width:100%;}
  .lang-toggle{font-size:0.65rem;letter-spacing:0.28em;display:flex;gap:0.4rem;}
  .lang-toggle a{opacity:0.45;color:inherit;text-decoration:none;}
  .lang-toggle a::after{display:none;}
  .lang-toggle .active{opacity:1;}
  .lang-toggle a:hover{opacity:0.8;}
  .lang-separator{opacity:0.45;}

  /* —— Hero Residence —— */
  .res-hero{position:relative;height:90vh;min-height:680px;background-image:linear-gradient(180deg,rgba(15,17,21,0.20),rgba(15,17,21,0.45)),url('/assets/images/ap1_cotton/ap1_cotton%20(1).jpg');background-size:cover;background-position:center;background-attachment:fixed;color:var(--white);display:flex;align-items:flex-end;}
  .res-hero-inner{padding:0 3rem 5rem;width:100%;max-width:1280px;margin:0 auto;}
  .breadcrumb{font-size:0.65rem;letter-spacing:0.32em;text-transform:uppercase;color:rgba(255,255,255,0.7);margin-bottom:2rem;}
  .breadcrumb a{color:inherit;text-decoration:none;border-bottom:1px solid rgba(255,255,255,0.4);padding-bottom:2px;}
  .breadcrumb a:hover{border-color:#fff;}
  .res-num-big{font-family:var(--font-main);font-size:0.85rem;letter-spacing:0.4em;color:rgba(255,255,255,0.8);margin-bottom:1rem;}
  .res-hero h1{font-size:clamp(4rem,11vw,9.5rem);letter-spacing:-0.025em;font-style:italic;font-family:var(--font-main);font-weight:300;line-height:0.95;margin-bottom:1.4rem;}
  .res-tag{font-family:var(--font-main);font-style:italic;font-size:1.3rem;opacity:0.9;max-width:480px;}

  /* —— Spec strip —— */
  .specs{background:var(--white);padding:3.5rem 3rem;border-bottom:1px solid var(--rule);}
  .specs-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:2rem;max-width:1280px;margin:0 auto;text-align:center;}
  .spec{display:flex;flex-direction:column;gap:0.5rem;border-right:1px solid var(--rule);padding:0.5rem 1rem;}
  .spec:last-child{border-right:none;}
  .spec-label{font-size:0.65rem;letter-spacing:0.32em;text-transform:uppercase;color:var(--mute);}
  .spec-value{font-family:var(--font-main);font-style:italic;font-size:1.5rem;color:var(--ink);}

  /* —— Description —— */
  section{padding:9rem 3rem;}
  .container{max-width:1280px;margin:0 auto;}
  .description{background:var(--paper);}
  .desc-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:6rem;align-items:start;}
  .desc-grid .chapter{display:flex;align-items:center;gap:1.1rem;margin-bottom:2rem;}
  .desc-grid .chapter::before{content:'';display:block;width:36px;height:1px;background:var(--ink-soft);}
  .desc-grid h2{font-size:clamp(2.2rem,4vw,3.4rem);max-width:11ch;}
  .desc-grid .body p{margin-bottom:1.4rem;color:var(--ink-soft);max-width:50ch;}
  .desc-grid .body p.lead{font-family:var(--font-main);font-style:italic;font-size:1.4rem;line-height:1.55;color:var(--ink);max-width:36ch;margin-bottom:2rem;}

  /* —— Image showcase split —— */
  .showcase{background:var(--paper);padding:0 3rem 9rem;}
  .showcase-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;max-width:1280px;margin:0 auto;}
  .show-img{aspect-ratio:4/5;background-size:cover;background-position:center;}
  .show-img.tall{aspect-ratio:3/5;align-self:start;}
  .show-img.short{aspect-ratio:5/4;margin-top:5rem;}
  .si1{background-image:url('/assets/images/ap1_cotton/ap1_cotton%20(2).jpg');}
  .si2{background-image:url('/assets/images/ap1_cotton/ap1_cotton%20(3).jpg');}

  /* —— Parallax break —— */
  .parallax{position:relative;height:60vh;min-height:420px;background-attachment:fixed;background-size:cover;background-position:center;display:flex;align-items:center;justify-content:center;color:var(--white);text-align:center;background-image:url('/assets/images/ap1_cotton/ap1_cotton%20(4).jpg');}
  .parallax::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,17,21,0.20),rgba(15,17,21,0.40));}
  .parallax-content{position:relative;z-index:2;padding:0 2rem;max-width:760px;}
  .parallax-quote{font-family:var(--font-main);font-style:italic;font-weight:300;font-size:clamp(1.5rem,2.6vw,2.2rem);line-height:1.4;}

  /* —— Amenities + floor plan —— */
  .amenities{background:var(--white);}
  .amen-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:6rem;align-items:start;}
  .amen-list h3{font-family:var(--font-main);font-style:italic;font-weight:300;font-size:2.2rem;margin-bottom:2.5rem;}
  .amen-list ul{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:0.9rem 2rem;}
  .amen-list li{font-size:0.92rem;color:var(--ink-soft);padding:0.5rem 0;border-bottom:1px solid var(--rule-light);}
  .amen-list li::before{content:'—';margin-right:0.6rem;color:var(--mute);}

  .floorplan{background:var(--paper);aspect-ratio:1;padding:2rem;display:flex;align-items:center;justify-content:center;position:relative;border:1px solid var(--rule);overflow:hidden;}
  .floorplan img{width:82%;height:82%;display:block;object-fit:contain;filter:grayscale(1) contrast(0.92);}
  .fp-label{position:absolute;top:1.4rem;left:1.4rem;font-size:0.65rem;letter-spacing:0.32em;text-transform:uppercase;color:var(--mute);}
  .fp-scale{position:absolute;bottom:1.4rem;left:1.4rem;font-family:var(--font-main);font-size:0.85rem;color:var(--ink-soft);}
  .fp-north{position:absolute;top:1.4rem;right:1.4rem;display:flex;flex-direction:column;align-items:center;gap:0.25rem;font-size:0.7rem;color:var(--ink-soft);line-height:1;}
  .fp-north::after{content:'';width:1.25rem;height:1.25rem;border:1px solid currentColor;border-radius:50%;display:block;background:linear-gradient(currentColor,currentColor) center/1px 100% no-repeat;}

  /* —— Mini gallery —— */
  .mini-gallery{background:var(--paper);padding:9rem 3rem;}
  .mg-head{margin-bottom:3rem;}
  .mg-head h2{font-size:clamp(2rem,3.6vw,2.8rem);}
  .mg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;max-width:1280px;margin:0 auto;}
  .mg-grid .g{aspect-ratio:1;background-size:cover;background-position:center;}
  .mg1{background-image:url('/assets/images/ap1_cotton/ap1_cotton%20(5).jpg');}
  .mg2{background-image:url('/assets/images/ap1_cotton/ap1_cotton%20(6).jpg');}
  .mg3{background-image:url('/assets/images/ap1_cotton/ap1_cotton%20(7).jpg');}
  .mg4{background-image:url('/assets/images/ap1_cotton/ap1_cotton%20(8).jpg');}
  .mg5{background-image:url('/assets/images/ap1_cotton/ap1_cotton%20(9).jpg');}
  .mg6{background-image:url('/assets/images/ap1_cotton/ap1_cotton%20(10).jpg');}

  /* —— Booking strip —— */
  .book-strip{background:var(--ink);color:var(--paper);padding:6rem 3rem;text-align:center;}
  .book-strip .eyebrow{color:rgba(251,250,247,0.6);}
  .book-strip h2{font-size:clamp(2.4rem,4.5vw,3.6rem);margin:1.5rem auto 2.2rem;max-width:18ch;}
  .book-strip p{font-family:var(--font-main);font-style:italic;font-size:1.2rem;color:rgba(251,250,247,0.85);max-width:46ch;margin:0 auto 2.5rem;}
  .cta{display:inline-block;padding:1.1rem 3rem;background:var(--paper);color:var(--ink);text-decoration:none;font-family:var(--font-main);font-size:0.72rem;letter-spacing:0.32em;text-transform:uppercase;border:1px solid var(--paper);transition:all 0.4s ease;}
  .cta:hover{background:transparent;color:var(--paper);}

  /* —— Other residences —— */
  .others{background:var(--white);padding:9rem 3rem;}
  .others-head{display:flex;justify-content:space-between;align-items:end;margin-bottom:3rem;max-width:1280px;margin:0 auto 3rem;}
  .others-head h2{font-size:clamp(1.8rem,3vw,2.4rem);font-style:italic;font-family:var(--font-main);font-weight:300;}
  .others-head a{color:var(--ink);text-decoration:none;font-size:0.7rem;letter-spacing:0.32em;text-transform:uppercase;border-bottom:1px solid var(--ink);padding-bottom:4px;}
  .others-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;max-width:1280px;margin:0 auto;}
  .other-card{text-decoration:none;color:inherit;}
  .other-card .img{aspect-ratio:4/5;background-size:cover;background-position:center;margin-bottom:1.2rem;}
  .other-card .res-num{font-family:var(--font-main);font-size:0.7rem;letter-spacing:0.32em;color:var(--mute);margin-bottom:0.4rem;}
  .other-card .res-name{font-family:var(--font-main);font-style:italic;font-size:1.55rem;margin-bottom:0.5rem;line-height:1;}
  .other-card .res-meta{font-size:0.68rem;letter-spacing:0.22em;text-transform:uppercase;color:var(--ink-soft);}
  .o1 .img{background-image:url('/assets/images/ap2_crepe/ap2_crepe%20(1).jpg');}
  .o2 .img{background-image:url('/assets/images/ap3_linen/ap3_linen%20(1).jpg');}
  .o3 .img{background-image:url('/assets/images/ap4_silk/ap4_silk%20(1).jpg');}

  /* —— Footer —— */
  footer{background:var(--paper-2);color:var(--ink-soft);padding:5rem 3rem 2rem;font-size:0.85rem;}
  .foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;max-width:1280px;margin:0 auto 3rem;}
  footer h4{font-family:var(--font-main);font-size:0.65rem;letter-spacing:0.32em;text-transform:uppercase;color:var(--ink);margin-bottom:1.2rem;font-weight:400;}
  footer .brand{color:var(--ink);font-size:1.5rem;margin-bottom:0.8rem;display:inline-block;}
  footer p,footer a{color:var(--ink-soft);text-decoration:none;line-height:1.85;}
  footer a:hover{color:var(--ink);}
  footer h4 .fa{letter-spacing:0;margin-right:.55rem;}
  footer p .fa{letter-spacing:0;margin-right:.45rem;}
  .foot-bottom{max-width:1280px;margin:0 auto;padding-top:2rem;border-top:1px solid var(--rule);display:flex;justify-content:space-between;font-size:0.7rem;letter-spacing:0.18em;color:var(--mute);}

  @media(max-width:980px){
    nav{padding:1.1rem 1.4rem;}
    nav.scrolled{padding:0.8rem 1.4rem;}
    .nav-links{gap:1rem;}
    .nav-links > a{font-size:0.65rem;letter-spacing:0.16em;}
    section,.showcase,.mini-gallery,.others,.book-strip{padding:5rem 1.4rem;}
    .res-hero-inner{padding:0 1.4rem 3rem;}
    .res-hero,.parallax{background-attachment:scroll;}
    .specs{padding:2.5rem 1.4rem;}
    .specs-grid{grid-template-columns:repeat(2,1fr);gap:1.5rem 1rem;}
    .spec{border-right:none;border-bottom:1px solid var(--rule);padding-bottom:1rem;}
    .spec:last-child,.spec:nth-last-child(2){border-bottom:none;}
    .desc-grid,.amen-grid{grid-template-columns:1fr;gap:3rem;}
    .show-img.short{margin-top:0;}
    .showcase-grid{grid-template-columns:1fr;}
    .amen-list ul{grid-template-columns:1fr;}
    .mg-grid{grid-template-columns:repeat(2,1fr);}
    .others-grid{grid-template-columns:1fr;gap:3rem;}
    .others-head{flex-direction:column;align-items:flex-start;gap:1.5rem;}
    .foot-grid{grid-template-columns:1fr 1fr;}
  }
  @media(max-width:520px){
    .nav-links > a{display:none;}
    .specs-grid{grid-template-columns:1fr;}
    .spec{border-right:none;border-bottom:1px solid var(--rule);}
    .spec:last-child{border-bottom:none;}
    .mg-grid{grid-template-columns:1fr;}
    .foot-grid{grid-template-columns:1fr;}
    .foot-bottom{flex-direction:column;gap:0.8rem;}
  }

/* =========================================================
   Extracted inline utility styles
   ========================================================= */
footer .footer-description {
  margin-top: 0.6rem;
  max-width: 32ch;
}

/* =========================================================
   Flask booking request + admin module
   ========================================================= */
.hp-field{position:absolute!important;left:-10000px!important;width:1px!important;height:1px!important;opacity:0!important;pointer-events:none!important;}
.nav-booking{border:1px solid rgba(255,255,255,.55);padding:.62rem .85rem!important;}
nav.scrolled .nav-booking{border-color:rgba(15,17,21,.2);}
.reserve-actions{margin-top:2rem;}
.outline-link{display:inline-flex;align-items:center;gap:.5rem;border:1px solid var(--ink);padding:.85rem 1.2rem;text-decoration:none;color:var(--ink);font-size:.68rem;letter-spacing:.24em;text-transform:uppercase;transition:.25s ease;}
.outline-link:hover{background:var(--ink);color:var(--white);}
.form-status{margin-top:1rem;font-size:.82rem;line-height:1.5;color:var(--ink-soft);}
.form-status.success{color:#1f5c38;}
.form-status.error{color:#8b1e1e;}
.turnstile-field{display:flex;align-items:center;justify-content:flex-start;min-height:65px;margin:.2rem 0 .4rem;overflow:hidden;}
.turnstile-field .cf-turnstile{max-width:100%;}
button:disabled{opacity:.55;cursor:not-allowed;}

.booking-page{background:var(--paper);}
.booking-hero{min-height:52vh;background:linear-gradient(135deg,rgba(15,17,21,.70),rgba(15,17,21,.35)),url('/assets/images/exterior/exterior%20(11).jpg');background-size:cover;background-position:center;display:flex;align-items:flex-end;padding:9rem 3rem 5rem;color:var(--white);}
.booking-hero>div{max-width:880px;}
.booking-hero p{max-width:58ch;font-size:1.05rem;color:rgba(255,255,255,.80);}
.booking-shell{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(340px,.75fr);gap:4rem;max-width:1320px;margin:0 auto;padding:7rem 3rem;align-items:start;}
.selector-head{display:grid;grid-template-columns:1fr 1fr;gap:3rem;margin-bottom:3rem;align-items:end;}
.selector-head p{color:var(--ink-soft);max-width:44ch;}
.booking-apartments{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1.4rem;}
.booking-apartment-card{display:grid;grid-template-columns:155px 1fr;gap:1.2rem;border:1px solid var(--rule);background:var(--white);padding:1rem;cursor:pointer;transition:.25s ease;min-height:210px;}
.booking-apartment-card:hover,.booking-apartment-card.selected{border-color:var(--ink);box-shadow:0 18px 50px rgba(15,17,21,.08);transform:translateY(-2px);}
.booking-apartment-card input{display:none;}
.booking-card-image{background-size:cover;background-position:center;min-height:180px;}
.booking-card-body{display:flex;flex-direction:column;gap:.55rem;}
.booking-card-body h3{font-family:var(--font-main);font-size:1.55rem;font-weight:300;margin:0;color:var(--ink);}
.booking-card-body p{font-size:.9rem;color:var(--ink-soft);line-height:1.55;margin:0;}
.booking-card-body strong{margin-top:auto;font-weight:400;color:var(--ink);}
.booking-meta{display:flex;flex-wrap:wrap;gap:.65rem;font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--mute);}
.booking-meta span:not(:last-child)::after{content:'·';margin-left:.65rem;opacity:.5;}
.booking-form-section{position:sticky;top:6rem;background:var(--white);border:1px solid var(--rule);padding:2rem;box-shadow:0 18px 60px rgba(15,17,21,.06);}
.booking-form{gap:1.5rem;}
.estimate-box{background:var(--paper);border:1px solid var(--rule);padding:1.2rem;display:grid;gap:.35rem;}
.estimate-label{font-size:.65rem;letter-spacing:.28em;text-transform:uppercase;color:var(--mute);}
.estimate-box strong{font-size:1.8rem;font-weight:300;color:var(--ink);}
.estimate-box small{color:var(--ink-soft);line-height:1.5;}

.admin-body{background:var(--paper);min-height:100vh;font-family:var(--font-main);}
.admin-topbar{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.94);backdrop-filter:blur(16px);border-bottom:1px solid var(--rule);display:flex;align-items:center;justify-content:space-between;padding:1rem 2rem;}
.admin-brand{font-size:1.05rem;letter-spacing:.2em;text-transform:uppercase;text-decoration:none;color:var(--ink);}
.admin-brand span{display:block;font-size:.58rem;color:var(--mute);letter-spacing:.36em;margin-top:.1rem;}
.admin-topbar nav{display:flex;gap:1.2rem;}
.admin-topbar nav a{text-decoration:none;color:var(--ink-soft);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;}
.admin-topbar nav a:hover{color:var(--ink);}
.admin-main{max-width:1240px;margin:0 auto;padding:3rem 2rem 5rem;}
.admin-head{display:flex;justify-content:space-between;align-items:end;gap:2rem;margin-bottom:2rem;}
.admin-head h1{font-size:2.6rem;font-weight:300;line-height:1.1;}
.admin-button,.admin-form button,.photo-admin-grid button,.admin-table button{display:inline-flex;align-items:center;justify-content:center;background:var(--ink);color:var(--white);border:1px solid var(--ink);padding:.85rem 1.1rem;text-decoration:none;font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;cursor:pointer;transition:.2s ease;font-family:var(--font-main);}
.admin-button.secondary{background:transparent;color:var(--ink);}
.admin-button:hover,.admin-form button:hover{background:transparent;color:var(--ink);}
.admin-login-body{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--ink);padding:2rem;position:relative;isolation:isolate;overflow:hidden;}
.admin-login-body::before{content:"";position:fixed;inset:-18px;background-image:url("/assets/images/admin_login/exterior (1).jpg");background-size:cover;background-position:center;filter:blur(5px);transform:scale(1.035);z-index:-2;}
.admin-login-body::after{content:"";position:fixed;inset:0;background:rgba(255,255,255,.34);z-index:-1;}
.admin-login-card{width:min(420px,100%);position:relative;z-index:1;overflow:hidden;background:rgba(255,255,255,.90);padding:2.4rem;border:1px solid rgba(255,255,255,.58);box-shadow:0 24px 70px rgba(15,17,21,.18);display:grid;gap:1.2rem;}
.admin-login-card>*{position:relative;}
.admin-login-card h1{font-weight:300;font-size:2.2rem;}
.admin-login-card label,.admin-form label,.admin-panel label{display:grid;gap:.45rem;font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:var(--mute);}
.admin-login-card input,.admin-form input,.admin-form textarea,.admin-form select,.admin-panel select{border:1px solid var(--rule);background:#fff;padding:.85rem;font-family:var(--font-main);font-size:1rem;color:var(--ink);letter-spacing:normal;text-transform:none;}
.admin-login-card button{background:var(--ink);color:var(--white);border:1px solid var(--ink);padding:1rem;font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;cursor:pointer;}
.admin-login-card button:disabled{opacity:.55;cursor:not-allowed;}
.admin-lockout{display:grid;gap:.35rem;border:1px solid rgba(139,30,30,.22);background:rgba(139,30,30,.055);color:#8b1e1e;padding:1rem;}
.admin-lockout span{display:inline-flex;align-items:center;gap:.45rem;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;}
.admin-lockout strong{font-size:1.9rem;font-weight:300;line-height:1;color:var(--ink);}
.admin-lockout small{font-size:.78rem;line-height:1.55;color:var(--mute);}
.flash-stack{display:grid;gap:.7rem;margin-bottom:1rem;}.flash{padding:.85rem 1rem;border:1px solid var(--rule);background:var(--white);font-size:.85rem;}.flash.success{border-color:rgba(31,92,56,.25);color:#1f5c38;}.flash.error{border-color:rgba(139,30,30,.25);color:#8b1e1e;}
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:2rem;}.stat-card{background:var(--white);border:1px solid var(--rule);padding:1.4rem;display:grid;gap:.6rem;}.stat-card span{font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--mute);}.stat-card strong{font-size:2rem;font-weight:300;color:var(--ink);}
.admin-panel{background:var(--white);border:1px solid var(--rule);padding:1.5rem;margin-bottom:2rem;}.panel-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;}.panel-head h2,.admin-panel h2{font-weight:300;font-size:1.5rem;}.panel-head a{color:var(--ink);}
.admin-table-wrap{overflow:auto;background:var(--white);border:1px solid var(--rule);}.admin-table{width:100%;border-collapse:collapse;min-width:780px;}.admin-table th,.admin-table td{text-align:left;border-bottom:1px solid var(--rule);padding:.95rem;vertical-align:top;font-size:.9rem;}.admin-table th{font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;color:var(--mute);font-weight:400;}.admin-table a{color:var(--ink);}.admin-table small{color:var(--mute);}.status-pill{display:inline-flex;border:1px solid var(--rule);padding:.25rem .55rem;font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);}
.admin-grid-cards{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1.2rem;}.admin-apartment-card{display:grid;grid-template-columns:190px 1fr;gap:1rem;background:var(--white);border:1px solid var(--rule);padding:1rem;}.admin-apartment-card .thumb{background-size:cover;background-position:center;min-height:170px;}.admin-apartment-card h2{font-weight:300;font-size:1.6rem;margin:.2rem 0;}.admin-apartment-card p{color:var(--ink-soft);}.admin-actions{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:1rem;}.admin-actions a{border:1px solid var(--rule);padding:.45rem .7rem;text-decoration:none;color:var(--ink);font-size:.72rem;text-transform:uppercase;letter-spacing:.15em;}
.admin-form{background:var(--white);border:1px solid var(--rule);padding:1.6rem;display:grid;gap:1.2rem;}.admin-form .row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;}.admin-form .row.four{grid-template-columns:repeat(4,1fr);}.admin-form textarea{min-height:120px;resize:vertical;}.checkline{display:flex!important;align-items:center;gap:.55rem;text-transform:none!important;letter-spacing:normal!important;color:var(--ink-soft)!important;}.checkline input{width:auto;}
.photo-admin-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem;margin-top:2rem;}.photo-admin-grid article{background:var(--white);border:1px solid var(--rule);overflow:hidden;}.photo-admin-grid img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block;}.photo-admin-grid article>div{padding:1rem;display:grid;gap:.6rem;}.photo-admin-grid small{color:var(--mute);word-break:break-all;}
.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem;}.detail-grid p{color:var(--ink-soft);line-height:1.7;}

@media(max-width:980px){.booking-shell{grid-template-columns:1fr;padding:5rem 1.4rem}.booking-form-section{position:static}.selector-head{grid-template-columns:1fr}.booking-apartments{grid-template-columns:1fr}.stat-grid{grid-template-columns:repeat(2,1fr)}.admin-grid-cards{grid-template-columns:1fr}.detail-grid{grid-template-columns:1fr}.photo-admin-grid{grid-template-columns:repeat(2,1fr)}.admin-form .row,.admin-form .row.four{grid-template-columns:1fr}.admin-topbar{align-items:flex-start;gap:1rem;flex-direction:column}.admin-topbar nav{flex-wrap:wrap}.nav-booking{display:inline-flex!important}}
@media(max-width:620px){.booking-hero{padding:7rem 1.4rem 3.5rem}.booking-apartment-card{grid-template-columns:1fr}.booking-card-image{min-height:220px}.stat-grid{grid-template-columns:1fr}.photo-admin-grid{grid-template-columns:1fr}.admin-main{padding:2rem 1rem 4rem}.admin-head{align-items:flex-start;flex-direction:column}.admin-table{min-width:720px}}

/* =========================================================
   Booking request + admin layout refinement
   CSS-only pass: prevents global section/form rules from breaking
   the backend-driven request/admin screens.
   ========================================================= */
.booking-page nav{
  mix-blend-mode:normal;
}

.booking-shell{
  grid-template-columns:minmax(0,1fr) minmax(420px,440px);
  gap:clamp(2rem,4vw,3.5rem);
  max-width:1440px;
  width:100%;
  padding:6rem clamp(1.5rem,3vw,3rem);
}

.booking-selector{
  padding:0;
  min-width:0;
}

.booking-form-section{
  width:100%;
  max-width:440px;
  min-width:0;
  justify-self:end;
  overflow:hidden;
  padding:1.75rem;
}

.booking-form{
  display:grid;
  gap:1.25rem;
  width:100%;
  min-width:0;
}

.booking-form .row{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  gap:1rem;
  min-width:0;
}

.booking-form .field,
.booking-form .estimate-box{
  min-width:0;
  width:100%;
}

.booking-form input,
.booking-form select,
.booking-form textarea{
  width:100%;
  min-width:0;
  max-width:100%;
}

.booking-form textarea{
  min-height:86px;
}

.booking-form .submit{
  width:100%;
  justify-self:stretch;
  text-align:center;
  padding-left:1rem;
  padding-right:1rem;
}

.estimate-box{
  width:100%;
  box-sizing:border-box;
}

.estimate-box strong{
  font-size:clamp(1.35rem,2vw,1.75rem);
  line-height:1.15;
}

.booking-apartments{
  grid-template-columns:repeat(auto-fit,minmax(300px,1fr));
  align-items:stretch;
}

.booking-apartment-card{
  grid-template-columns:minmax(125px,38%) minmax(0,1fr);
  min-width:0;
  height:100%;
}

.booking-card-body{
  min-width:0;
}

.booking-card-body h3,
.booking-card-body p,
.booking-card-body strong{
  overflow-wrap:anywhere;
}

.booking-meta{
  row-gap:.35rem;
}

/* Admin screens are app screens, not marketing sections. */
.admin-body{
  overflow-x:hidden;
}

.admin-main{
  width:100%;
}

.admin-head{
  padding:0;
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:1.5rem;
  margin-bottom:2rem;
}

.admin-head h1{
  margin:0;
}

.admin-topbar{
  gap:1.5rem;
}

.admin-topbar nav{
  flex-wrap:wrap;
  justify-content:flex-end;
  row-gap:.55rem;
}

.admin-panel{
  padding:1.5rem;
}

.admin-grid-cards{
  grid-template-columns:repeat(auto-fit,minmax(360px,1fr));
}

.admin-apartment-card{
  min-width:0;
}

.admin-apartment-card > div:last-child{
  min-width:0;
}

.admin-actions a,
.admin-button,
.admin-form button,
.photo-admin-grid button,
.admin-table button{
  white-space:nowrap;
}

.admin-form{
  width:100%;
  min-width:0;
}

.admin-form .row,
.admin-form .row.four{
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:1rem;
}

.admin-form label{
  min-width:0;
}

.admin-form input,
.admin-form textarea,
.admin-form select,
.admin-panel select{
  width:100%;
  min-width:0;
}

.admin-table-wrap{
  width:100%;
  max-width:100%;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
}

.admin-table td,
.admin-table th{
  overflow-wrap:anywhere;
}

.photo-admin-grid{
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
}

@media(max-width:1180px){
  .booking-shell{
    grid-template-columns:1fr;
    max-width:980px;
  }

  .booking-form-section{
    position:static;
    justify-self:stretch;
    max-width:none;
  }
}

@media(max-width:760px){
  .booking-shell{
    padding:4rem 1rem;
  }

  .booking-form-section{
    padding:1.25rem;
  }

  .booking-form .row{
    grid-template-columns:1fr;
  }

  .booking-apartments{
    grid-template-columns:1fr;
  }

  .booking-apartment-card{
    grid-template-columns:1fr;
  }

  .booking-card-image{
    min-height:220px;
  }

  .admin-topbar{
    padding:1rem;
  }

  .admin-topbar nav{
    justify-content:flex-start;
    gap:.85rem;
  }

  .admin-main{
    padding:2rem 1rem 4rem;
  }

  .admin-head{
    align-items:flex-start;
    flex-direction:column;
  }

  .admin-grid-cards{
    grid-template-columns:1fr;
  }

  .admin-apartment-card{
    grid-template-columns:1fr;
  }

  .admin-apartment-card .thumb{
    min-height:220px;
  }
}

/* =========================================================
   Footer credits
   ========================================================= */
.foot-bottom{
  flex-wrap:wrap;
  gap:.85rem 2rem;
  align-items:flex-start;
}

.footer-copy-stack{
  display:flex;
  flex-direction:column;
  gap:.36rem;
  min-width:min(100%, 420px);
}

.footer-copy-stack > span:first-child{
  display:block;
}

.footer-credit{
  display:block;
  flex:none;
  text-align:left;
  font-size:.66rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--mute);
  line-height:1.7;
}

.footer-credit strong{
  color:var(--ink);
  font-weight:400;
}

@media(max-width:520px){
  .footer-copy-stack{
    min-width:100%;
  }

  .footer-credit{
    letter-spacing:.12em;
  }
}

/* =========================================================
   Language dropdown
   ========================================================= */
.language-switcher{
  display:inline-flex;
  align-items:center;
}

.language-select{
  appearance:none;
  -webkit-appearance:none;
  border:1px solid currentColor;
  border-radius:999px;
  background:rgba(255,255,255,0.04);
  color:inherit;
  font-family:var(--font-main);
  font-size:0.64rem;
  font-weight:300;
  letter-spacing:0.18em;
  text-transform:uppercase;
  line-height:1;
  padding:0.52rem 2rem 0.52rem 0.8rem;
  cursor:pointer;
  min-width:132px;
  background-image:linear-gradient(45deg,transparent 50%,currentColor 50%),linear-gradient(135deg,currentColor 50%,transparent 50%);
  background-position:calc(100% - 14px) 50%,calc(100% - 9px) 50%;
  background-size:5px 5px,5px 5px;
  background-repeat:no-repeat;
}

.language-select option{
  color:var(--ink);
  background:var(--paper);
  letter-spacing:normal;
  text-transform:none;
}

.language-select:focus{
  outline:1px solid currentColor;
  outline-offset:3px;
}

@media(max-width:980px){
  .language-select{
    min-width:102px;
    max-width:128px;
    padding-right:1.6rem;
    font-size:0.6rem;
    letter-spacing:0.12em;
  }
}

@media(max-width:520px){
  .language-select{
    min-width:86px;
    max-width:96px;
    padding-left:0.65rem;
    padding-right:1.45rem;
  }
}

/* =========================================================
   Minimal language selector + Font Awesome icon pass
   ========================================================= */
.language-switcher{
  position:relative;
  display:inline-flex;
  align-items:center;
  flex:0 0 auto;
}

.language-switcher::after{
  content:"\f107";
  font-family:"FontAwesome";
  position:absolute;
  right:1rem;
  top:50%;
  transform:translateY(-50%);
  font-size:.7rem;
  line-height:1;
  pointer-events:none;
  color:currentColor;
}

.language-select{
  appearance:none;
  -webkit-appearance:none;
  border:1px solid currentColor;
  border-radius:0;
  background:transparent;
  background-image:none;
  color:inherit;
  font-family:var(--font-main);
  font-size:.66rem;
  font-weight:300;
  letter-spacing:.22em;
  text-transform:uppercase;
  line-height:1;
  min-width:176px;
  min-height:42px;
  padding:.9rem 2.35rem .9rem 1rem;
  cursor:pointer;
}

.language-select:hover,
.language-select:focus{
  background:rgba(255,255,255,.08);
  outline:none;
}

nav.scrolled .language-select:hover,
nav.scrolled .language-select:focus{
  background:rgba(15,17,21,.035);
}

.language-select option{
  color:var(--ink);
  background:var(--paper);
  letter-spacing:normal;
  text-transform:none;
}

.amenities-icon-list{
  list-style:none;
}

.amen-list li{
  display:flex;
  align-items:center;
  gap:.85rem;
  padding:.65rem 0;
  border-bottom:1px solid var(--rule-light);
  color:var(--ink-soft);
}

.amen-list li::before{
  display:none;
  content:none;
}

.amen-list li .fa{
  width:1.15rem;
  min-width:1.15rem;
  text-align:center;
  color:var(--ink);
  font-size:.9rem;
  opacity:.78;
}

.admin-topbar nav a,
.admin-button,
.admin-actions a,
.admin-form button,
.photo-admin-grid button,
.admin-table button,
.panel-head a,
.admin-login-card button{
  gap:.55rem;
}

.admin-topbar nav a{
  display:inline-flex;
  align-items:center;
}

.admin-topbar nav a .fa,
.admin-button .fa,
.admin-actions a .fa,
.admin-form button .fa,
.photo-admin-grid button .fa,
.admin-table button .fa,
.panel-head a .fa,
.admin-login-card button .fa{
  font-size:.85em;
  line-height:1;
  opacity:.78;
}

.admin-head h1 .fa,
.admin-panel h2 .fa,
.panel-head h2 .fa,
.admin-login-card h1 .fa{
  font-size:.55em;
  margin-right:.45rem;
  vertical-align:.1em;
  opacity:.72;
}

.stat-card{
  position:relative;
  overflow:hidden;
}

.admin-stat-icon{
  font-size:1rem;
  color:var(--ink);
  opacity:.55;
  margin-bottom:.15rem;
}

.status-pill::before{
  content:"\f111";
  font-family:"FontAwesome";
  font-size:.42rem;
  margin-right:.45rem;
  opacity:.55;
  transform:translateY(-.02rem);
}

@media(max-width:980px){
  .language-select{
    min-width:142px;
    min-height:40px;
    padding-right:2rem;
    font-size:.6rem;
    letter-spacing:.14em;
  }

  .language-switcher::after{
    right:.78rem;
  }
}

@media(max-width:520px){
  .language-select{
    min-width:116px;
    max-width:132px;
    padding-left:.7rem;
    padding-right:1.75rem;
  }
}

/* =========================================================
   Booking request page refinement
   Parallax hero + minimal Font Awesome form icons + country select.
   ========================================================= */
.booking-hero{
  position:relative;
  min-height:64vh;
  background-image:linear-gradient(180deg,rgba(15,17,21,.20),rgba(15,17,21,.62)),url('/assets/images/exterior/exterior%20(12).jpg');
  background-size:cover;
  background-position:center;
  background-attachment:fixed;
  overflow:hidden;
}

.booking-hero::after{
  content:'';
  position:absolute;
  left:3rem;
  right:3rem;
  bottom:2.2rem;
  height:1px;
  background:rgba(255,255,255,.28);
  transform-origin:left;
}

.booking-hero > div{
  position:relative;
  z-index:1;
}

.booking-hero-eyebrow,
.booking-form-section .chapter,
.selector-head .chapter{
  display:flex;
  align-items:center;
  gap:.8rem;
}

.booking-hero-eyebrow .fa,
.booking-form-section .chapter .fa,
.selector-head .chapter .fa,
.booking-form label .fa,
.estimate-label .fa,
.booking-meta .fa,
.booking-form .submit .fa{
  letter-spacing:0;
  line-height:1;
  opacity:.78;
}

.booking-form-section{
  border-color:rgba(15,17,21,.13);
  box-shadow:0 28px 80px rgba(15,17,21,.075);
}

.booking-form .field label{
  display:flex;
  align-items:center;
  gap:.65rem;
}

.booking-form label .fa{
  width:1rem;
  min-width:1rem;
  color:var(--ink);
  font-size:.85rem;
  text-align:center;
}

.booking-form select.country-select{
  cursor:pointer;
  color:var(--ink);
  background:transparent;
}

.booking-form select.country-select:invalid{
  color:var(--mute);
}

.booking-form select.country-select option{
  color:var(--ink);
  background:var(--paper);
}

.estimate-label{
  display:flex;
  align-items:center;
  gap:.65rem;
}

.estimate-label .fa{
  color:var(--ink);
  font-size:.82rem;
}

.booking-meta span{
  display:inline-flex;
  align-items:center;
  gap:.38rem;
}

.booking-meta .fa{
  color:var(--ink);
  font-size:.82rem;
}

.booking-form .submit{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.75rem;
}

@media(max-width:980px){
  .booking-hero{
    background-attachment:scroll;
    min-height:56vh;
  }
}

@media(max-width:620px){
  .booking-hero::after{
    left:1.4rem;
    right:1.4rem;
    bottom:1.6rem;
  }
}

/* =========================================================
   Mobile navigation, touch carousels and global back-to-top
   ========================================================= */
.nav-toggle{
  display:none;
  width:44px;
  height:44px;
  border:1px solid currentColor;
  background:transparent;
  color:inherit;
  align-items:center;
  justify-content:center;
  flex-direction:column;
  gap:5px;
  cursor:pointer;
  z-index:140;
  transition:background .25s ease,color .25s ease,border-color .25s ease;
}

.nav-toggle span{
  display:block;
  width:18px;
  height:1px;
  background:currentColor;
  transform-origin:center;
  transition:transform .25s ease,opacity .2s ease;
}

nav.open .nav-toggle span:nth-child(1){transform:translateY(6px) rotate(45deg);}
nav.open .nav-toggle span:nth-child(2){opacity:0;}
nav.open .nav-toggle span:nth-child(3){transform:translateY(-6px) rotate(-45deg);}

.back-to-top{
  position:fixed;
  right:clamp(1rem,2.4vw,2rem);
  bottom:clamp(1rem,2.4vw,2rem);
  width:46px;
  height:46px;
  border:1px solid rgba(15,17,21,.18);
  background:rgba(251,250,247,.94);
  color:var(--ink);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  z-index:130;
  cursor:pointer;
  opacity:0;
  pointer-events:none;
  transform:translateY(12px);
  transition:opacity .25s ease,transform .25s ease,background .25s ease,color .25s ease,border-color .25s ease;
  box-shadow:0 16px 45px rgba(15,17,21,.10);
  backdrop-filter:blur(12px);
}

.back-to-top.visible{
  opacity:1;
  pointer-events:auto;
  transform:translateY(0);
}

.back-to-top:hover{
  background:var(--ink);
  border-color:var(--ink);
  color:var(--white);
}

.back-to-top .fa{
  font-size:1.25rem;
  line-height:1;
}

@media(max-width:980px){
  body.nav-lock{
    overflow:hidden;
  }

  nav,
  nav.scrolled{
    padding:.9rem 1rem;
    mix-blend-mode:normal;
    color:var(--ink);
    z-index:200;
  }

  nav:not(.scrolled):not(.open){
    color:var(--white);
    background:rgba(15,17,21,.22);
    backdrop-filter:blur(10px);
    border-bottom:1px solid rgba(255,255,255,.12);
  }

  nav.open,
  nav.open.scrolled{
    color:var(--ink);
    background:rgba(251,250,247,.98);
    border-bottom:1px solid var(--rule-light);
  }

  .nav-toggle{
    display:inline-flex;
    flex:0 0 auto;
  }

  nav .nav-links{
    position:fixed;
    top:0;
    right:0;
    width:min(86vw,380px);
    height:100dvh;
    display:flex!important;
    flex-direction:column;
    align-items:stretch;
    justify-content:flex-start;
    gap:0;
    padding:6.2rem 1.25rem 2rem;
    background:var(--paper);
    color:var(--ink);
    border-left:1px solid var(--rule);
    box-shadow:-30px 0 80px rgba(15,17,21,.18);
    transform:translateX(105%);
    opacity:0;
    pointer-events:none;
    overflow-y:auto;
    -webkit-overflow-scrolling:touch;
    transition:transform .32s cubic-bezier(.2,.7,.2,1),opacity .25s ease;
    z-index:130;
  }

  nav.open .nav-links{
    transform:translateX(0);
    opacity:1;
    pointer-events:auto;
  }

  nav .nav-links > a{
    display:flex!important;
    align-items:center;
    justify-content:space-between;
    width:100%;
    padding:1.05rem 0;
    border-bottom:1px solid var(--rule-light);
    color:var(--ink);
    font-size:.72rem;
    letter-spacing:.24em;
  }

  nav .nav-links > a::after{
    display:none;
  }

  nav .nav-links > a:not(.nav-booking)::before{
    content:'—';
    order:2;
    color:var(--mute);
    letter-spacing:0;
    font-size:.9rem;
  }

  nav .nav-links .nav-booking{
    margin-top:1rem;
    justify-content:center;
    border-color:var(--ink)!important;
    background:var(--ink);
    color:var(--white);
    padding:1rem!important;
  }

  nav .nav-links .language-switcher{
    width:100%;
    margin-top:1.1rem;
  }

  nav .nav-links .language-switcher::after{
    right:1rem;
  }

  nav .nav-links .language-select{
    width:100%;
    max-width:none;
    min-width:0;
    min-height:48px;
    color:var(--ink);
    border-color:var(--rule);
    letter-spacing:.16em;
  }
}

@media(max-width:760px){
  .residences .res-grid,
  .gallery .gallery-grid,
  .showcase .showcase-grid,
  .mini-gallery .mg-grid,
  .others .others-grid,
  .booking-apartments{
    display:flex;
    overflow-x:auto;
    overflow-y:hidden;
    gap:1rem;
    scroll-snap-type:x mandatory;
    scroll-padding-left:1.4rem;
    -webkit-overflow-scrolling:touch;
    margin-left:-1.4rem;
    margin-right:-1.4rem;
    padding-left:1.4rem;
    padding-right:1.4rem;
    padding-bottom:1.25rem;
    scrollbar-width:none;
  }

  .residences .res-grid::-webkit-scrollbar,
  .gallery .gallery-grid::-webkit-scrollbar,
  .showcase .showcase-grid::-webkit-scrollbar,
  .mini-gallery .mg-grid::-webkit-scrollbar,
  .others .others-grid::-webkit-scrollbar,
  .booking-apartments::-webkit-scrollbar{
    display:none;
  }

  .residences .res-card,
  .gallery .gallery-grid .g,
  .showcase .show-img,
  .mini-gallery .mg-grid .g,
  .others .other-card,
  .booking-apartment-card{
    flex:0 0 min(82vw,380px);
    scroll-snap-align:start;
    scroll-snap-stop:always;
  }

  .gallery .gallery-grid .g,
  .showcase .show-img,
  .mini-gallery .mg-grid .g{
    grid-column:auto!important;
    aspect-ratio:4/5!important;
    min-height:0;
    margin-top:0!important;
  }

  .booking-apartment-card{
    width:auto;
    min-width:0;
  }

  .booking-card-image{
    min-height:240px;
  }

  .residences .res-grid::after,
  .gallery .gallery-grid::after,
  .showcase .showcase-grid::after,
  .mini-gallery .mg-grid::after,
  .others .others-grid::after,
  .booking-apartments::after{
    content:'';
    flex:0 0 .4rem;
  }
}

@media(max-width:520px){
  nav .brand{
    font-size:1.18rem;
  }

  nav .brand span{
    font-size:.55rem;
    letter-spacing:.22em;
    margin-left:.32rem;
  }

  .nav-toggle{
    width:42px;
    height:42px;
  }

  .back-to-top{
    width:42px;
    height:42px;
    right:1rem;
    bottom:1rem;
  }

  .residences .res-card,
  .gallery .gallery-grid .g,
  .showcase .show-img,
  .mini-gallery .mg-grid .g,
  .others .other-card,
  .booking-apartment-card{
    flex-basis:84vw;
  }
}

/* =========================================================
   Mobile stability refinements
   Keeps the mobile header pinned and prevents page-level side drift,
   while preserving horizontal swipe carousels inside their own sections.
   ========================================================= */
html,
body{
  width:100%;
  max-width:100%;
  overflow-x:hidden;
  overscroll-behavior-x:none;
}

body{
  position:relative;
}

@supports (overflow:clip){
  html,
  body{
    overflow-x:clip;
  }
}

img,
video,
iframe{
  max-width:100%;
}

nav,
header,
main,
section,
footer{
  max-width:100vw;
}

@media(max-width:980px){
  nav,
  nav.scrolled,
  nav.open,
  nav.open.scrolled{
    position:fixed!important;
    top:0!important;
    left:0!important;
    right:0!important;
    width:100%!important;
    max-width:100vw;
    transform:translate3d(0,0,0)!important;
    -webkit-transform:translate3d(0,0,0)!important;
    backface-visibility:hidden;
    -webkit-backface-visibility:hidden;
    will-change:transform;
    min-height:68px;
  }

  nav,
  nav.scrolled{
    padding-top:calc(.9rem + env(safe-area-inset-top,0px));
  }

  nav .nav-links{
    max-width:100vw;
    overscroll-behavior-x:contain;
  }
}

@media(max-width:760px){
  .residences .res-grid,
  .gallery .gallery-grid,
  .showcase .showcase-grid,
  .mini-gallery .mg-grid,
  .others .others-grid,
  .booking-apartments{
    width:100%;
    max-width:100%;
    margin-left:0!important;
    margin-right:0!important;
    padding-left:0!important;
    padding-right:0!important;
    scroll-padding-left:0;
    overscroll-behavior-x:contain;
    overscroll-behavior-y:auto;
    contain:layout paint;
    touch-action:pan-x pan-y;
  }

  .residences .res-card,
  .gallery .gallery-grid .g,
  .showcase .show-img,
  .mini-gallery .mg-grid .g,
  .others .other-card,
  .booking-apartment-card{
    max-width:84vw;
  }
}


/* =========================================================
   Policy pages + footer legal links + cookie settings
   ========================================================= */

.footer-policy-links{
  display:flex;
  align-items:center;
  justify-content:center;
  flex-wrap:wrap;
  gap:.55rem;
  margin-top:1.4rem;
  padding-top:1.2rem;
  border-top:1px solid var(--rule-light);
  color:var(--ink-soft);
  font-size:.72rem;
  letter-spacing:.12em;
  text-transform:uppercase;
}

.footer-policy-links a,
.footer-policy-links button{
  color:var(--ink-soft);
  background:transparent;
  border:0;
  padding:0;
  font:inherit;
  letter-spacing:inherit;
  text-transform:inherit;
  cursor:pointer;
  text-decoration:none;
}

.footer-policy-links a:hover,
.footer-policy-links button:hover{
  color:var(--ink);
}

.policy-page{
  background:var(--paper);
}

.policy-hero{
  min-height:auto;
  padding:10rem 3rem 4rem;
  background:var(--paper);
  border-bottom:1px solid var(--rule-light);
}

.policy-hero .container{
  max-width:980px;
}

.policy-hero h1{
  max-width:900px;
  margin:1rem 0 1.2rem;
  font-size:clamp(3.2rem,8vw,7rem);
  line-height:.92;
}

.policy-hero p{
  max-width:760px;
  color:var(--ink-soft);
  font-size:clamp(1rem,1.8vw,1.22rem);
  line-height:1.9;
}

.policy-actions{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:.8rem;
  margin-top:2rem;
}

.policy-actions a,
.policy-actions button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:44px;
  padding:.85rem 1.1rem;
  border:1px solid var(--ink);
  color:var(--ink);
  background:transparent;
  text-decoration:none;
  font-family:var(--font-main);
  font-size:.65rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  cursor:pointer;
}

.policy-actions a:hover,
.policy-actions button:hover{
  background:var(--ink);
  color:var(--white);
}

.policy-shell{
  padding:4rem 3rem 5rem;
}

.policy-container{
  max-width:980px;
}

.policy-section{
  padding:2rem 0;
  border-bottom:1px solid var(--rule-light);
}

.policy-section:first-child{
  padding-top:0;
}

.policy-section h2{
  font-family:var(--font-main);
  color:var(--ink);
  font-size:1.05rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  margin-bottom:1rem;
  font-weight:500;
}

.policy-section p{
  color:var(--ink-soft);
  line-height:1.9;
  max-width:860px;
}

.cookie-consent{
  position:fixed;
  left:1.25rem;
  right:1.25rem;
  bottom:1.25rem;
  z-index:1200;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1.2rem;
  max-width:1120px;
  margin:0 auto;
  padding:1.1rem;
  background:rgba(255,255,255,.96);
  border:1px solid var(--rule);
  box-shadow:0 24px 80px rgba(0,0,0,.18);
  opacity:0;
  transform:translateY(1.5rem);
  pointer-events:none;
  transition:opacity .25s ease,transform .25s ease;
  backdrop-filter:blur(12px);
}

.cookie-consent.visible{
  opacity:1;
  transform:translateY(0);
  pointer-events:auto;
}

.cookie-consent-copy{
  max-width:620px;
}

.cookie-consent-copy strong{
  display:block;
  color:var(--ink);
  font-family:var(--font-main);
  font-size:.78rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  margin-bottom:.35rem;
}

.cookie-consent-copy p{
  margin:0;
  color:var(--ink-soft);
  font-size:.88rem;
  line-height:1.7;
}

.cookie-consent-actions,
.cookie-panel-actions{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:.55rem;
  flex-wrap:wrap;
}

.cookie-btn{
  min-height:42px;
  border:1px solid var(--ink);
  padding:.75rem .9rem;
  background:transparent;
  color:var(--ink);
  font-family:var(--font-main);
  font-size:.62rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  cursor:pointer;
  white-space:nowrap;
}

.cookie-btn.solid{
  background:var(--ink);
  color:var(--white);
}

.cookie-btn:hover{
  background:var(--ink);
  color:var(--white);
}

.cookie-modal{
  position:fixed;
  inset:0;
  z-index:1250;
  display:none;
}

.cookie-modal.open{
  display:block;
}

.cookie-modal-backdrop{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.45);
}

.cookie-panel{
  position:absolute;
  left:50%;
  top:50%;
  width:min(92vw,620px);
  max-height:min(82vh,720px);
  overflow:auto;
  transform:translate(-50%,-50%);
  background:var(--paper);
  color:var(--ink);
  border:1px solid var(--rule);
  box-shadow:0 35px 100px rgba(0,0,0,.3);
  padding:2rem;
}

.cookie-panel-close{
  position:absolute;
  top:.8rem;
  right:.8rem;
  width:38px;
  height:38px;
  border:1px solid var(--rule);
  background:transparent;
  color:var(--ink);
  font-size:1.4rem;
  line-height:1;
  cursor:pointer;
}

.cookie-panel h2{
  font-family:var(--font-display);
  font-size:clamp(2rem,5vw,3.6rem);
  font-weight:400;
  line-height:.95;
  margin:.7rem 2.4rem 1rem 0;
}

.cookie-panel p{
  color:var(--ink-soft);
  line-height:1.75;
  margin-bottom:1.4rem;
}

.cookie-options{
  display:grid;
  gap:.8rem;
  margin:1.4rem 0;
}

.cookie-option{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  padding:1rem;
  border:1px solid var(--rule-light);
  background:var(--paper-2);
}

.cookie-option span{
  display:grid;
  gap:.25rem;
}

.cookie-option strong{
  color:var(--ink);
  font-family:var(--font-main);
  font-size:.7rem;
  letter-spacing:.16em;
  text-transform:uppercase;
}

.cookie-option small{
  color:var(--ink-soft);
  line-height:1.55;
}

.cookie-option input{
  width:20px;
  height:20px;
  flex:0 0 auto;
  accent-color:var(--ink);
}

.cookie-option.disabled{
  opacity:.76;
}

body.cookie-lock{
  overflow:hidden;
}

@media(max-width:760px){
  .footer-policy-links{
    flex-direction:row;
    gap:.45rem;
    font-size:.64rem;
    line-height:1.8;
    padding-bottom:.4rem;
  }

  .policy-hero{
    padding:8rem 1.4rem 3rem;
  }

  .policy-shell{
    padding:3rem 1.4rem 4rem;
  }

  .policy-actions{
    align-items:stretch;
  }

  .policy-actions a,
  .policy-actions button{
    width:100%;
  }

  .cookie-consent{
    left:.8rem;
    right:.8rem;
    bottom:.8rem;
    flex-direction:column;
    align-items:stretch;
    padding:1rem;
  }

  .cookie-consent-actions{
    justify-content:stretch;
  }

  .cookie-btn{
    flex:1 1 100%;
    width:100%;
  }

  .cookie-panel{
    width:calc(100vw - 1.2rem);
    max-height:calc(100vh - 1.2rem);
    padding:1.35rem;
  }

  .cookie-option{
    align-items:flex-start;
  }

  .cookie-panel-actions{
    justify-content:stretch;
  }
}


/* =========================================================
   Residences desktop mosaic
   Desktop only: stagger the residence cards into a mosaic rhythm.
   Tablet/mobile keep the existing layout and carousel behavior.
   ========================================================= */
@media(min-width:981px){
  .residences .res-grid{
    grid-template-columns:repeat(12,minmax(0,1fr));
    grid-auto-flow:row;
    gap:2.8rem 1.5rem;
    align-items:start;
  }

  .residences .res-card{
    display:block;
    min-width:0;
    margin-top:0;
  }

  .residences .res-card .img{
    aspect-ratio:auto;
    width:100%;
    margin-bottom:1rem;
  }

  .residences .res-card.a1{
    grid-column:1 / span 4;
    margin-top:0;
  }

  .residences .res-card.a1 .img{
    aspect-ratio:4 / 5;
  }

  .residences .res-card.a2{
    grid-column:5 / span 4;
    margin-top:1.8rem;
  }

  .residences .res-card.a2 .img{
    aspect-ratio:4 / 5;
  }

  .residences .res-card.a3{
    grid-column:9 / span 4;
    margin-top:.8rem;
  }

  .residences .res-card.a3 .img{
    aspect-ratio:5 / 6;
  }

  .residences .res-card.a4{
    grid-column:1 / span 4;
    margin-top:0;
  }

  .residences .res-card.a4 .img{
    aspect-ratio:1.18;
  }

  .residences .res-card.a5{
    grid-column:5 / span 4;
    margin-top:1.5rem;
  }

  .residences .res-card.a5 .img{
    aspect-ratio:4 / 5;
  }

  .residences .res-card.a6{
    grid-column:9 / span 4;
    margin-top:0;
  }

  .residences .res-card.a6 .img{
    aspect-ratio:1.08;
  }

  .residences .res-card.a7{
    grid-column:2 / span 4;
    margin-top:1rem;
  }

  .residences .res-card.a7 .img{
    aspect-ratio:3 / 4;
  }

  .residences .res-card.a8{
    grid-column:6 / span 6;
    margin-top:1.8rem;
  }

  .residences .res-card.a8 .img{
    aspect-ratio:1.45;
  }
}

/* =========================================================
   Story island mosaic
   Desktop: mosaic aligned with the concept text.
   Mobile: horizontal carousel, matching the rest of the site.
   ========================================================= */
.story-image.story-island-frame{
  aspect-ratio:auto;
  min-height:620px;
  background:none;
  display:flex;
  align-items:center;
  width:100%;
  max-width:100%;
}

.story-island-mosaic{
  width:100%;
  display:grid;
  grid-template-columns:1.08fr .88fr .94fr;
  grid-template-rows:170px 145px 210px;
  gap:.9rem;
}

.island-shot{
  position:relative;
  overflow:hidden;
  background-size:cover;
  background-position:center;
  min-width:0;
  min-height:0;
  filter:saturate(.92) contrast(.98);
}

.island-shot::after{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,rgba(15,17,21,.02),rgba(15,17,21,.16));
  pointer-events:none;
}

.island-shot-1{
  grid-column:1 / span 2;
  grid-row:1 / span 2;
  background-image:url('/assets/images/rhodes/rhodes%20(1).jpg');
}

.island-shot-2{
  grid-column:3;
  grid-row:1;
  background-image:url('/assets/images/rhodes/rhodes%20(2).jpg');
}

.island-shot-3{
  grid-column:3;
  grid-row:2 / span 2;
  background-image:url('/assets/images/rhodes/rhodes%20(3).jpg');
}

.island-shot-4{
  grid-column:1;
  grid-row:3;
  background-image:url('/assets/images/rhodes/rhodes%20(4).jpg');
}

.island-shot-5{
  grid-column:2;
  grid-row:3;
  background-image:url('/assets/images/rhodes/rhodes%20(5).jpg');
}

@media(max-width:980px){
  .story-image.story-island-frame{
    min-height:0;
  }

  .story-island-mosaic{
    grid-template-rows:180px 150px 210px;
  }
}

@media(max-width:760px){
  .story-image.story-island-frame{
    overflow:hidden;
    display:block;
  }

  .story-island-mosaic{
    display:flex;
    overflow-x:auto;
    overflow-y:hidden;
    gap:1rem;
    scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
    width:100%;
    max-width:100%;
    overscroll-behavior-x:contain;
    touch-action:pan-x pan-y;
    contain:layout paint;
    padding-bottom:1.25rem;
  }

  .story-island-mosaic::-webkit-scrollbar{
    display:none;
  }

  .story-island-mosaic::after{
    content:'';
    flex:0 0 .4rem;
  }

  .story-island-mosaic .island-shot{
    grid-column:auto!important;
    grid-row:auto!important;
    flex:0 0 min(84vw,380px);
    max-width:84vw;
    aspect-ratio:4/5;
    scroll-snap-align:start;
    scroll-snap-stop:always;
  }
}

/* =========================================================
   Admin intake toggles + live status
   ========================================================= */
.admin-intake-panel .panel-head.compact{
  align-items:center;
  gap:1.5rem;
  margin-bottom:.85rem;
}

.admin-intake-panel p{
  margin-top:.35rem;
  max-width:620px;
  color:var(--ink-soft);
  font-size:.9rem;
  line-height:1.6;
}

.admin-toggle{
  display:inline-flex!important;
  grid-template-columns:none!important;
  align-items:center;
  gap:.75rem;
  cursor:pointer;
  white-space:nowrap;
  color:var(--ink)!important;
  letter-spacing:.12em!important;
}

.admin-toggle input{
  position:absolute;
  opacity:0;
  pointer-events:none;
}

.admin-toggle-switch{
  position:relative;
  width:52px;
  height:28px;
  border:1px solid var(--rule);
  background:#d8d3ca;
  transition:background .2s ease,border-color .2s ease;
}

.admin-toggle-switch::after{
  content:"";
  position:absolute;
  top:3px;
  left:3px;
  width:20px;
  height:20px;
  background:var(--white);
  border:1px solid rgba(15,17,21,.12);
  box-shadow:0 5px 14px rgba(15,17,21,.14);
  transition:transform .2s ease;
}

.admin-toggle input:checked + .admin-toggle-switch{
  background:var(--ink);
  border-color:var(--ink);
}

.admin-toggle input:checked + .admin-toggle-switch::after{
  transform:translateX(24px);
}

.admin-toggle input:disabled + .admin-toggle-switch{
  opacity:.55;
}

.admin-live-status{
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  color:var(--ink-soft);
  font-size:.72rem;
  letter-spacing:.16em;
  text-transform:uppercase;
}

.admin-live-status .fa{
  font-size:.46rem;
  color:#1f5c38;
}

.admin-live-status.offline .fa{
  color:#8b1e1e;
}

@media(max-width:720px){
  .admin-intake-panel .panel-head.compact{
    align-items:flex-start;
    flex-direction:column;
  }

  .admin-toggle{
    white-space:normal;
  }
}

/* =========================================================
   Admin popup manager + public scheduled popups
   ========================================================= */
.admin-popup-panel .panel-head.compact,
.admin-popup-list-panel .panel-head{
  align-items:center;
  gap:1.5rem;
}

.admin-popup-panel p,
.admin-popup-card p{
  margin-top:.35rem;
  color:var(--ink-soft);
  font-size:.9rem;
  line-height:1.65;
}

.admin-popup-form{
  display:grid;
  gap:1rem;
}

.admin-popup-form.compact{
  margin-top:1rem;
  padding-top:1rem;
  border-top:1px solid var(--rule-light);
}

.admin-popup-options,
.admin-popup-actions{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:.8rem;
}

.admin-check{
  display:inline-flex!important;
  align-items:center;
  grid-template-columns:none!important;
  gap:.5rem;
  width:auto!important;
  color:var(--ink-soft)!important;
  font-size:.72rem!important;
  letter-spacing:.14em!important;
  text-transform:uppercase;
}

.admin-check input{
  width:18px!important;
  height:18px;
  accent-color:var(--ink);
}

.admin-popup-list{
  display:grid;
  gap:1.1rem;
}

.admin-popup-card{
  display:grid;
  grid-template-columns:minmax(180px,260px) minmax(0,1fr);
  gap:1.2rem;
  padding:1rem;
  border:1px solid var(--rule-light);
  background:var(--paper-2);
}

.admin-popup-card-preview{
  min-height:180px;
  background:var(--paper);
  border:1px solid var(--rule-light);
  overflow:hidden;
}

.admin-popup-card-preview img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.admin-popup-no-image,
.admin-empty-state{
  min-height:180px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:.65rem;
  color:var(--mute);
  text-align:center;
  letter-spacing:.12em;
  text-transform:uppercase;
  font-size:.72rem;
}

.admin-popup-no-image .fa,
.admin-empty-state .fa{
  font-size:1.8rem;
  opacity:.45;
}

.admin-popup-card-body{
  min-width:0;
}

.admin-popup-card-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:1rem;
  border-bottom:1px solid var(--rule-light);
  padding-bottom:1rem;
  margin-bottom:1rem;
}

.admin-popup-card h3{
  margin:0;
  color:var(--ink);
  font-family:var(--font-main);
  font-size:1rem;
  letter-spacing:.12em;
  text-transform:uppercase;
}

.admin-popup-card p{
  max-width:820px;
  overflow-wrap:anywhere;
}

.admin-popup-meta{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(150px,1fr));
  gap:.85rem;
  margin:0 0 1rem;
}

.admin-popup-meta div{
  padding:.75rem;
  background:var(--paper);
  border:1px solid var(--rule-light);
  min-width:0;
}

.admin-popup-meta dt{
  color:var(--mute);
  font-size:.62rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  margin-bottom:.35rem;
}

.admin-popup-meta dd{
  margin:0;
  color:var(--ink-soft);
  overflow-wrap:anywhere;
  line-height:1.55;
}

.admin-popup-edit summary{
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  cursor:pointer;
  color:var(--ink);
  font-size:.7rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  margin-bottom:.5rem;
}

.admin-popup-actions{
  margin-top:1rem;
  padding-top:1rem;
  border-top:1px solid var(--rule-light);
}

.admin-popup-actions form{
  margin:0;
}

.admin-popup-actions button,
.admin-popup-form button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.55rem;
}

.admin-popup-actions button.danger{
  border-color:#8b1e1e;
  color:#8b1e1e;
}

.admin-popup-actions button.danger:hover{
  background:#8b1e1e;
  color:var(--white);
}

.theveil-popup-root{
  position:fixed;
  inset:0;
  z-index:1400;
  display:none;
}

.theveil-popup-root.open{
  display:block;
}

.theveil-popup-backdrop{
  position:absolute;
  inset:0;
  background:rgba(15,17,21,.56);
  backdrop-filter:blur(6px);
}

.theveil-popup-panel{
  position:absolute;
  left:50%;
  top:50%;
  width:min(92vw,760px);
  max-height:min(88dvh,820px);
  overflow:auto;
  transform:translate(-50%,-50%);
  background:var(--paper);
  color:var(--ink);
  border:1px solid rgba(255,255,255,.28);
  box-shadow:0 36px 110px rgba(0,0,0,.34);
}

.theveil-popup-image{
  width:100%;
  max-height:48dvh;
  object-fit:cover;
  display:block;
  background:var(--paper-2);
}

.theveil-popup-content{
  padding:clamp(1.35rem,3vw,2.35rem);
}

.theveil-popup-content h2{
  margin:0 2.5rem 1rem 0;
  font-family:var(--font-display);
  font-weight:400;
  font-size:clamp(2.25rem,7vw,5.2rem);
  line-height:.92;
  letter-spacing:-.04em;
}

.theveil-popup-content p{
  color:var(--ink-soft);
  line-height:1.85;
  font-size:clamp(.98rem,1.5vw,1.08rem);
  white-space:pre-line;
}

.theveil-popup-actions{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:.7rem;
  margin-top:1.35rem;
}

.theveil-popup-link,
.theveil-popup-close-inline{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:44px;
  padding:.9rem 1.05rem;
  border:1px solid var(--ink);
  background:var(--ink);
  color:var(--white);
  text-decoration:none;
  font-family:var(--font-main);
  font-size:.64rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  cursor:pointer;
}

.theveil-popup-close-inline{
  background:transparent;
  color:var(--ink);
}

.theveil-popup-link:hover,
.theveil-popup-close-inline:hover{
  background:transparent;
  color:var(--ink);
}

.theveil-popup-close-inline:hover{
  background:var(--ink);
  color:var(--white);
}

.theveil-popup-x{
  position:absolute;
  top:.9rem;
  right:.9rem;
  width:42px;
  height:42px;
  border:1px solid rgba(15,17,21,.18);
  background:rgba(251,250,247,.92);
  color:var(--ink);
  font-size:1.35rem;
  line-height:1;
  cursor:pointer;
  z-index:2;
}

body.theveil-popup-lock{
  overflow:hidden;
}

@media(max-width:760px){
  .admin-popup-card{
    grid-template-columns:1fr;
  }

  .admin-popup-card-preview{
    min-height:220px;
  }

  .admin-popup-card-head{
    flex-direction:column;
  }

  .theveil-popup-panel{
    width:min(94vw,520px);
    max-height:84dvh;
  }

  .theveil-popup-image{
    max-height:38dvh;
  }

  .theveil-popup-actions{
    align-items:stretch;
  }

  .theveil-popup-link,
  .theveil-popup-close-inline{
    width:100%;
  }
}

/* =========================================================
   Admin apartments view switch
   ========================================================= */
.admin-head-with-tools{
  align-items:flex-end;
}

.admin-head-actions{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:.85rem;
  flex-wrap:wrap;
}

.admin-view-switch{
  display:inline-flex;
  align-items:center;
  gap:.35rem;
  background:var(--white);
  border:1px solid var(--rule);
  padding:.25rem;
}

.admin-view-button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.45rem;
  min-height:2.55rem;
  border:1px solid transparent;
  background:transparent;
  color:var(--ink-soft);
  padding:.62rem .82rem;
  font-family:var(--font-main);
  font-size:.65rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  cursor:pointer;
  transition:.2s ease;
}

.admin-view-button:hover,
.admin-view-button.is-active{
  border-color:var(--ink);
  background:var(--ink);
  color:var(--white);
}

.admin-apartments-view.is-grid{
  grid-template-columns:repeat(auto-fit,minmax(360px,1fr));
}

.admin-apartments-view.is-list{
  grid-template-columns:1fr;
}

.admin-apartments-view.is-list .admin-apartment-card{
  grid-template-columns:minmax(220px,280px) 1fr;
  align-items:stretch;
}

.admin-apartments-view.is-list .admin-apartment-card .thumb{
  min-height:190px;
}

@media(max-width:760px){
  .admin-head-actions{
    width:100%;
    justify-content:flex-start;
  }

  .admin-view-switch,
  .admin-head-actions .admin-button{
    width:100%;
  }

  .admin-view-button,
  .admin-head-actions .admin-button{
    flex:1;
  }

  .admin-apartments-view.is-list .admin-apartment-card{
    grid-template-columns:1fr;
  }

  .admin-apartments-view.is-list .admin-apartment-card .thumb{
    min-height:220px;
  }
}
.admin-help-text{margin:0;color:var(--ink-soft);font-size:.92rem;line-height:1.65;letter-spacing:normal;text-transform:none;}
.admin-toggle-field{display:grid;gap:.45rem;font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:var(--mute);}
.admin-toggle-group{display:grid;grid-template-columns:1fr 1fr;border:1px solid var(--rule);background:#fff;overflow:hidden;}
.admin-toggle-group label{display:block!important;margin:0!important;letter-spacing:normal!important;text-transform:none!important;color:var(--ink)!important;font-size:.78rem!important;}
.admin-toggle-group input{position:absolute;opacity:0;pointer-events:none;}
.admin-toggle-group span{display:flex;align-items:center;justify-content:center;min-height:48px;padding:.75rem .65rem;border-right:1px solid var(--rule);cursor:pointer;transition:.2s ease;}
.admin-toggle-group label:last-child span{border-right:0;}
.admin-toggle-group input:checked+span{background:var(--ink);color:var(--white);}

/* =========================================================
   Booking transfer option + estimate breakdown
   ========================================================= */
.booking-transfer-block{
  border:1px solid var(--rule);
  background:rgba(255,255,255,.58);
  padding:1.1rem;
  display:grid;
  gap:1rem;
}

.booking-transfer-block.is-hidden{
  display:none!important;
}

.booking-transfer-head{
  display:grid;
  gap:.35rem;
}

.booking-transfer-head small{
  color:var(--ink-soft);
  line-height:1.55;
}

.booking-transfer-toggle{
  display:block!important;
  letter-spacing:normal!important;
  text-transform:none!important;
  color:var(--ink)!important;
  font-size:.92rem!important;
}

.booking-transfer-toggle input{
  position:absolute;
  opacity:0;
  pointer-events:none;
}

.booking-transfer-toggle span{
  border:1px solid var(--rule);
  background:var(--paper);
  display:inline-flex;
  align-items:center;
  gap:.65rem;
  min-height:46px;
  padding:.85rem 1rem;
  cursor:pointer;
  transition:background .2s ease,color .2s ease,border-color .2s ease;
}

.booking-transfer-toggle input:checked+span{
  background:var(--ink);
  border-color:var(--ink);
  color:var(--white);
}

.booking-transfer-fields[hidden]{
  display:none!important;
}

.booking-parking-price-note,
.booking-parking-availability-note{
  display:block;
  color:var(--ink-soft);
  line-height:1.55;
}

.booking-parking-price-note{
  color:var(--ink);
  font-weight:600;
}

.booking-parking-availability-note i{
  margin-right:.35rem;
}

.estimate-breakdown{
  display:grid;
  gap:.42rem;
  margin:.25rem 0;
}

.estimate-breakdown:empty{
  display:none;
}

.estimate-breakdown-row{
  display:flex;
  justify-content:space-between;
  gap:1rem;
  border-top:1px solid rgba(15,17,21,.09);
  padding-top:.42rem;
  color:var(--ink-soft);
  font-size:.86rem;
  line-height:1.45;
}

.estimate-breakdown-row strong{
  font-size:.86rem;
  font-weight:400;
  color:var(--ink);
  white-space:nowrap;
}

/* Transfer fields need full-width selects, because route names can be long. */
.booking-transfer-fields .row{
  grid-template-columns:1fr;
  gap:.85rem;
}

.booking-transfer-fields .field,
.booking-transfer-fields select{
  min-width:0;
  max-width:100%;
}

.booking-transfer-fields select{
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  padding-right:2.4rem;
}

/* =========================================================
   Discount display for booking cards and estimates
   ========================================================= */
.booking-card-body .booking-price-line{
  margin-top:auto;
  display:flex;
  align-items:baseline;
  flex-wrap:wrap;
  gap:.35rem;
  color:var(--ink);
  font-weight:400;
}

.booking-card-body .booking-price-line strong{
  margin-top:0;
  font-weight:400;
}

.booking-price-old{
  color:var(--mute);
  text-decoration:line-through;
  text-decoration-thickness:1px;
}

.booking-offer-badge{
  display:inline-flex;
  align-items:center;
  gap:.35rem;
  width:max-content;
  max-width:100%;
  border:1px solid rgba(15,17,21,.16);
  padding:.28rem .45rem;
  color:var(--ink-soft);
  font-size:.64rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  line-height:1.35;
}

.estimate-breakdown-row.discount-row strong{
  color:#7f1d1d;
}

.admin-help{
  margin:0;
  color:var(--ink-soft);
  font-size:.86rem;
  line-height:1.6;
}

/* =========================================================
   Booking consent and rules page refinements
   ========================================================= */
.booking-consent{
  display:grid!important;
  grid-template-columns:auto 1fr;
  align-items:flex-start;
  gap:.75rem;
  padding:1rem;
  border:1px solid var(--rule);
  background:rgba(255,255,255,.64);
  color:var(--ink-soft)!important;
  font-size:.84rem!important;
  line-height:1.65;
  letter-spacing:normal!important;
  text-transform:none!important;
}

.booking-consent input{
  width:1.05rem;
  height:1.05rem;
  margin-top:.2rem;
  accent-color:var(--ink);
}

.booking-consent a{
  color:var(--ink);
  text-decoration:underline;
  text-underline-offset:.22em;
}

.policy-section p + p{
  margin-top:.8rem;
}

.policy-section a{
  color:var(--ink);
  text-decoration:underline;
  text-underline-offset:.22em;
}


/* =========================================================
   Admin fixed sidebar navigation
   ========================================================= */
:root{
  --admin-sidebar-width:276px;
  --admin-sidebar-collapsed-width:76px;
}

.admin-body{
  background:var(--paper);
  min-height:100vh;
  padding-left:var(--admin-sidebar-width);
  transition:padding-left .24s ease;
}

.admin-body.admin-sidebar-collapsed{
  padding-left:var(--admin-sidebar-collapsed-width);
}

.admin-sidebar{
  position:fixed;
  inset:0 auto 0 0;
  z-index:120;
  width:var(--admin-sidebar-width);
  height:100vh;
  height:100dvh;
  display:flex;
  flex-direction:column;
  background:rgba(255,255,255,.96);
  border-right:1px solid var(--rule);
  box-shadow:14px 0 45px rgba(15,17,21,.045);
  transition:width .24s ease;
  overflow:hidden;
}

.admin-sidebar-collapsed .admin-sidebar{
  width:var(--admin-sidebar-collapsed-width);
}

.admin-sidebar-head{
  min-height:86px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:.85rem;
  padding:1.15rem 1rem 1.05rem 1.15rem;
  border-bottom:1px solid var(--rule);
}

.admin-sidebar .admin-brand{
  min-width:0;
  display:flex;
  align-items:center;
  gap:.75rem;
  color:var(--ink);
  text-decoration:none;
  letter-spacing:.18em;
  text-transform:uppercase;
}

.admin-brand-mark{
  width:40px;
  height:40px;
  min-width:40px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:1px solid var(--ink);
  font-size:.78rem;
  line-height:1;
  letter-spacing:.16em;
  text-indent:.16em;
}

.admin-brand-text{
  display:flex;
  flex-direction:column;
  gap:.1rem;
  min-width:0;
  font-size:.95rem;
  line-height:1.1;
  white-space:nowrap;
  transition:opacity .18s ease,transform .18s ease,width .18s ease;
}

.admin-brand-text small{
  display:block;
  font-size:.55rem;
  color:var(--mute);
  letter-spacing:.34em;
  line-height:1.2;
}

.admin-sidebar-toggle{
  width:34px;
  height:34px;
  min-width:34px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:1px solid var(--rule);
  background:transparent;
  color:var(--ink);
  cursor:pointer;
  transition:background .2s ease,color .2s ease,border-color .2s ease,transform .2s ease;
}

.admin-sidebar-toggle:hover,
.admin-sidebar-toggle:focus{
  background:var(--ink);
  color:var(--white);
  border-color:var(--ink);
  outline:none;
}

.admin-sidebar-toggle .fa{
  transition:transform .24s ease;
}

.admin-sidebar-collapsed .admin-sidebar-toggle .fa{
  transform:rotate(180deg);
}

.admin-sidebar-nav{
  position:static;
  inset:auto;
  z-index:auto;
  width:auto;
  height:auto;
  flex:1 1 auto;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
  align-items:stretch;
  gap:.35rem;
  padding:1rem .8rem;
  margin:0;
  color:var(--ink);
  background:transparent;
  border:0;
  mix-blend-mode:normal;
  backdrop-filter:none;
  overflow-y:auto;
  overflow-x:hidden;
  -webkit-overflow-scrolling:touch;
}

.admin-sidebar-nav a{
  min-height:44px;
  display:flex;
  align-items:center;
  gap:.75rem;
  padding:.75rem .85rem;
  color:var(--ink-soft);
  text-decoration:none;
  border:1px solid transparent;
  font-size:.7rem;
  letter-spacing:.18em;
  line-height:1.25;
  text-transform:uppercase;
  white-space:nowrap;
  transition:background .2s ease,color .2s ease,border-color .2s ease;
}

.admin-sidebar-nav a:hover,
.admin-sidebar-nav a:focus,
.admin-sidebar-nav a.is-active{
  color:var(--ink);
  background:rgba(15,17,21,.035);
  border-color:var(--rule);
  outline:none;
}

.admin-sidebar-nav a .fa{
  width:1.15rem;
  min-width:1.15rem;
  text-align:center;
  font-size:.96rem;
  line-height:1;
  opacity:.82;
}

.admin-sidebar-nav a span{
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  transition:opacity .18s ease,transform .18s ease,width .18s ease;
}

.admin-sidebar-logout{
  margin-top:auto;
}

.admin-sidebar-collapsed .admin-sidebar-head{
  padding-left:.9rem;
  padding-right:.9rem;
  justify-content:center;
  flex-direction:column;
  gap:.65rem;
}

.admin-sidebar-collapsed .admin-brand-text,
.admin-sidebar-collapsed .admin-sidebar-nav a span{
  width:0;
  opacity:0;
  transform:translateX(-8px);
  pointer-events:none;
}

.admin-sidebar-collapsed .admin-sidebar .admin-brand,
.admin-sidebar-collapsed .admin-sidebar-nav a{
  justify-content:center;
  gap:0;
}

.admin-sidebar-collapsed .admin-sidebar-nav{
  padding:.85rem .55rem;
}

.admin-sidebar-collapsed .admin-sidebar-nav a{
  padding:.75rem .5rem;
}

.admin-sidebar-collapsed .admin-sidebar-logout{
  margin-top:auto;
}

.admin-main{
  max-width:1240px;
  margin:0 auto;
  padding:3rem 2rem 5rem;
  transition:max-width .24s ease,padding .24s ease;
}

@media(max-width:980px){
  :root{
    --admin-sidebar-width:238px;
    --admin-sidebar-collapsed-width:68px;
  }

  .admin-sidebar-head{
    min-height:78px;
  }

  .admin-brand-mark{
    width:36px;
    height:36px;
    min-width:36px;
    font-size:.7rem;
  }

  .admin-sidebar-toggle{
    width:32px;
    height:32px;
    min-width:32px;
  }

  .admin-sidebar-nav a{
    min-height:42px;
    padding:.7rem .75rem;
    letter-spacing:.14em;
    font-size:.66rem;
  }
}

@media(max-width:760px){
  .admin-body{
    padding-left:var(--admin-sidebar-collapsed-width);
  }

  .admin-body:not(.admin-sidebar-collapsed){
    padding-left:var(--admin-sidebar-width);
  }

  .admin-main{
    padding:2rem 1rem 4rem;
  }
}

/* Stronger sidebar brand overrides: avoids legacy .admin-brand span rules leaking in. */
.admin-sidebar .admin-brand .admin-brand-mark{
  display:inline-flex;
  width:40px;
  height:40px;
  min-width:40px;
  margin-top:0;
  color:var(--ink);
  font-size:.78rem;
  letter-spacing:.16em;
}

.admin-sidebar .admin-brand .admin-brand-text{
  display:flex;
  margin-top:0;
  color:var(--ink);
  font-size:.95rem;
  letter-spacing:.18em;
}

.admin-sidebar .admin-brand .admin-brand-text small{
  color:var(--mute);
}

@media(max-width:980px){
  .admin-sidebar .admin-brand .admin-brand-mark{
    width:36px;
    height:36px;
    min-width:36px;
    font-size:.7rem;
  }
}

/* Brand logo replacement */
.brand{
  display:inline-flex;
  align-items:center;
  line-height:1;
}
.brand-logo{
  display:block;
  width:auto;
  height:34px;
  max-width:200px;
  object-fit:contain;
}
nav:not(.scrolled) .brand-logo{
  filter:invert(1);
}
nav.scrolled .brand-logo,
footer .brand-logo{
  filter:none;
}
footer .brand-logo{
  height:40px;
  max-width:220px;
}
@media(max-width:520px){
  .brand-logo{
    height:24px;
    max-width:145px;
  }
  footer .brand-logo{
    height:30px;
    max-width:170px;
  }
}

/* Header contrast before scroll */
@media(min-width:981px){
  nav:not(.scrolled):not(.open){
    color:var(--ink);
    mix-blend-mode:normal;
  }

  nav:not(.scrolled):not(.open) .brand-logo{
    filter:none;
  }

  nav:not(.scrolled):not(.open) .nav-booking{
    border-color:rgba(15,17,21,.32);
  }

  nav:not(.scrolled):not(.open) .language-select{
    border-color:rgba(15,17,21,.32);
    background:rgba(251,250,247,.10);
  }

  nav:not(.scrolled):not(.open) .language-select:hover,
  nav:not(.scrolled):not(.open) .language-select:focus{
    background:rgba(251,250,247,.22);
  }
}

/* Admin logo additions */
.admin-login-logo{display:inline-flex;align-items:center;justify-content:center;justify-self:center;width:100%;text-decoration:none;line-height:1;}
.admin-login-logo img{display:block;width:auto;height:48px;max-width:190px;object-fit:contain;}
.admin-sidebar .admin-brand .admin-brand-mark img{display:block;width:30px;height:30px;object-fit:contain;}
@media(max-width:980px){.admin-login-logo img{height:42px;max-width:170px;}.admin-sidebar .admin-brand .admin-brand-mark img{width:27px;height:27px;}}

.admin-table form{
  margin:0;
}

.admin-table button.danger{
  background:transparent;
  border-color:#8b1e1e;
  color:#8b1e1e;
}

.admin-table button.danger:hover{
  background:#8b1e1e;
  color:var(--white);
}

/* Admin requests table: give the booking grid more usable desktop space. */
.admin-requests-page .admin-main{
  max-width:min(1540px,calc(100vw - var(--admin-sidebar-width) - 48px));
  padding-left:2.5rem;
  padding-right:2.5rem;
}

.admin-sidebar-collapsed.admin-requests-page .admin-main{
  max-width:min(1540px,calc(100vw - var(--admin-sidebar-collapsed-width) - 48px));
}

.admin-requests-table{
  min-width:1180px;
}

.admin-requests-table th,
.admin-requests-table td{
  padding-left:1.15rem;
  padding-right:1.15rem;
  overflow-wrap:normal;
  word-break:normal;
}

.admin-requests-table th:nth-child(1),
.admin-requests-table td:nth-child(1){
  width:58px;
  white-space:nowrap;
}

.admin-requests-table th:nth-child(2),
.admin-requests-table td:nth-child(2){
  min-width:235px;
}

.admin-requests-table td:nth-child(2) small{
  overflow-wrap:anywhere;
}

.admin-requests-table th:nth-child(3),
.admin-requests-table td:nth-child(3){
  min-width:130px;
}

.admin-requests-table th:nth-child(4),
.admin-requests-table td:nth-child(4){
  min-width:195px;
  white-space:nowrap;
}

.admin-requests-table th:nth-child(5),
.admin-requests-table td:nth-child(5){
  width:82px;
  white-space:nowrap;
}

.admin-requests-table th:nth-child(6),
.admin-requests-table td:nth-child(6),
.admin-requests-table th:nth-child(7),
.admin-requests-table td:nth-child(7){
  min-width:110px;
  white-space:nowrap;
}

.admin-requests-table th:nth-child(8),
.admin-requests-table td:nth-child(8){
  min-width:112px;
  white-space:nowrap;
}

.admin-requests-table th:nth-child(9),
.admin-requests-table td:nth-child(9){
  min-width:96px;
}

.admin-requests-table .status-pill{
  white-space:nowrap;
}

.admin-requests-table th:nth-child(10),
.admin-requests-table td:nth-child(10){
  min-width:138px;
  white-space:nowrap;
}

@media(max-width:980px){
  .admin-requests-page .admin-main{
    max-width:none;
    padding-left:1rem;
    padding-right:1rem;
  }
}
