/* ============================================================================
   Azores Mood — public site design system (Direction D · "Concierge")
   Ported from the approved Direction D mockup. Dark theme default + light.
   ========================================================================== */

:root[data-theme="dark"]{
  --bg:#0A0A0B; --bg-2:#111114; --surf:#15161B; --surf-2:#1C1D24;
  --line:#262830; --line-2:#33363F;
  --ink:#F4F4EE; --ink-2:#9BA0A8; --ink-3:#666B73;
  --ocean:#3D8BE0; --ocean-d:#2A6FD0; --ocean-l:#7BB1F0;
  --earth:#E8A560; --earth-d:#D08438; --earth-l:#F4C896;
  --nature:#5BC785; --nature-d:#3FA565; --nature-l:#94DBB1;
  --grad: radial-gradient(ellipse 70% 60% at 20% 30%, rgba(61,139,224,0.55), transparent 60%),
          radial-gradient(ellipse 60% 50% at 80% 20%, rgba(232,165,96,0.45), transparent 60%),
          radial-gradient(ellipse 80% 70% at 60% 90%, rgba(91,199,133,0.50), transparent 60%);
  --shadow: 0 24px 48px -16px rgba(0,0,0,.6);
}
:root[data-theme="light"]{
  --bg:#F7F5EF; --bg-2:#EFEDE5; --surf:#FFFFFF; --surf-2:#F7F5EF;
  --line:#E2DED2; --line-2:#CFC9B8;
  --ink:#0A0A0B; --ink-2:#4A4F58; --ink-3:#7A8089;
  --ocean:#2A6FD0; --ocean-d:#1E5BB0; --ocean-l:#5B95E0;
  --earth:#C77A2E; --earth-d:#A35F1A; --earth-l:#E8A560;
  --nature:#3FA565; --nature-d:#2A8550; --nature-l:#7BC799;
  --grad: radial-gradient(ellipse 70% 60% at 20% 30%, rgba(42,111,208,0.30), transparent 60%),
          radial-gradient(ellipse 60% 50% at 80% 20%, rgba(199,122,46,0.30), transparent 60%),
          radial-gradient(ellipse 80% 70% at 60% 90%, rgba(63,165,101,0.35), transparent 60%);
  --shadow: 0 24px 48px -16px rgba(40,40,40,.18);
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--bg);color:var(--ink);font-family:"Inter",-apple-system,system-ui,sans-serif;font-size:16px;line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
::selection{background:color-mix(in oklab, var(--ocean) 38%, transparent);color:var(--ink)}
.display{font-family:"Inter Tight",-apple-system,sans-serif;letter-spacing:-.04em;line-height:.92;font-weight:800}
.mono{font-family:"JetBrains Mono",monospace;letter-spacing:.02em}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.wrap{max-width:1380px;margin:0 auto}

/* App bar ------------------------------------------------------------------ */
.appbar{position:sticky;top:0;z-index:50;background:color-mix(in oklab, var(--bg) 75%, transparent);backdrop-filter:blur(20px);border-bottom:1px solid var(--line);height:72px;display:flex;align-items:center;padding:0 32px;gap:48px}
.mark{display:flex;align-items:center;gap:12px}
.mark-svg{width:36px;height:36px;flex:none}
.mark-name{font-family:"Inter Tight";font-weight:800;font-size:17px;letter-spacing:-.02em}
.nav{display:flex;gap:4px;flex:1}
.nav a{padding:10px 14px;font-size:14.5px;font-weight:500;color:var(--ink-2);border-radius:8px;transition:.15s}
.nav a:hover{color:var(--ink);background:var(--surf)}
.nav a.active{color:var(--ink)}
.appbar-right{display:flex;gap:8px;align-items:center}
.icon-btn{width:40px;height:40px;border-radius:10px;background:transparent;border:1px solid var(--line);color:var(--ink-2);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:.15s}
.icon-btn:hover{background:var(--surf);color:var(--ink)}
.pill{padding:10px 18px;border-radius:999px;font-size:14px;font-weight:600;border:1px solid var(--line);color:var(--ink);background:transparent;cursor:pointer;transition:.15s;display:inline-flex;align-items:center;gap:8px}
.pill:hover{background:var(--surf-2);border-color:var(--line-2)}
.pill.solid{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.pill.solid:hover{background:color-mix(in oklab, var(--ink) 90%, var(--ocean) 10%)}
.burger{display:none}

/* HERO --------------------------------------------------------------------- */
.hero-cats{position:relative;padding:56px 32px 72px;overflow:hidden}
.hero-bg{position:absolute;inset:0;background:var(--grad);z-index:0;pointer-events:none}
.hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,color-mix(in oklab,var(--bg) 85%,transparent) 0%,transparent 28%)}
.hero-cats-inner{position:relative;z-index:1;max-width:1380px;margin:0 auto}

/* Filter ------------------------------------------------------------------- */
.filter-wrap{position:relative;z-index:2;margin-bottom:48px}
.filter{max-width:1380px;margin:0 auto;background:var(--surf);border:1px solid var(--line-2);border-radius:32px;padding:14px;display:grid;grid-template-columns:1.2fr 1fr 1fr auto;gap:8px;align-items:center;box-shadow:var(--shadow)}
.field{padding:18px 20px;border-radius:22px;cursor:pointer;display:flex;flex-direction:column;gap:6px;transition:.15s;border:1px solid transparent;position:relative}
.field:hover{background:var(--surf-2)}
.field.active{background:var(--surf-2);border-color:var(--line-2)}
.field .f-icon{position:absolute;right:16px;top:50%;transform:translateY(-50%);width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center}
.field .f-icon.ocean{background:color-mix(in oklab, var(--ocean) 22%, transparent);color:var(--ocean-l)}
.field .f-icon.earth{background:color-mix(in oklab, var(--earth) 22%, transparent);color:var(--earth-l)}
.field .f-icon.nature{background:color-mix(in oklab, var(--nature) 22%, transparent);color:var(--nature-l)}
.field .f-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-3);user-select:none}
.field .f-value{font-family:"Inter Tight";font-weight:600;font-size:20px;letter-spacing:-.015em;color:var(--ink)}
.field .f-value.ph{color:var(--ink-3);font-weight:500}
/* Real form controls styled to look like the design tiles */
.field .f-control{appearance:none;-webkit-appearance:none;-moz-appearance:none;width:100%;background:transparent;border:0;outline:none;color:var(--ink);font-family:"Inter Tight";font-weight:600;font-size:20px;letter-spacing:-.015em;padding:0 36px 0 0;margin:0;cursor:pointer;line-height:1.2}
.field select.f-control option{color:#0A0A0B;background:#fff;font-family:"Inter",sans-serif}
.field input[type="date"].f-control{min-height:24px}
.field input[type="date"].f-control::-webkit-calendar-picker-indicator{display:none;-webkit-appearance:none}
.field input[type="date"].f-control::-webkit-inner-spin-button,
.field input[type="date"].f-control::-webkit-clear-button{display:none;-webkit-appearance:none}
.field input[type="date"].f-control::-webkit-datetime-edit{color:var(--ink)}
.filter-cta{height:100%;padding:0 32px;border-radius:22px;background:var(--ink);color:var(--bg);border:0;font-family:"Inter Tight";font-weight:700;font-size:17px;letter-spacing:-.01em;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;transition:.15s;min-height:84px}
.filter-cta:hover{background:linear-gradient(135deg,var(--ocean),var(--nature));color:#fff}
.filter-cta .arrow,.c-count .arrow,.btn-primary .arrow{width:32px;height:32px;border-radius:50%;background:color-mix(in oklab, var(--bg) 25%, transparent);display:flex;align-items:center;justify-content:center;flex:none}

.quick-row{max-width:1380px;margin:14px auto 0;display:flex;align-items:center;gap:10px;padding:0 8px;flex-wrap:wrap}
.quick-label{font-size:12px;color:var(--ink-3);letter-spacing:.04em}
.chip{padding:8px 14px;border-radius:999px;background:var(--surf);border:1px solid var(--line);font-size:13px;color:var(--ink-2);cursor:pointer;transition:.15s;display:flex;align-items:center;gap:6px}
.chip:hover{background:var(--surf-2);color:var(--ink);border-color:var(--line-2)}
.chip .c-dot{width:6px;height:6px;border-radius:50%;background:var(--nature)}

/* Categories grid ---------------------------------------------------------- */
.cats{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:1fr;gap:14px}
.cat{aspect-ratio:1/1;border-radius:24px;padding:24px;position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:space-between;cursor:pointer;transition:transform .25s ease, box-shadow .25s ease;border:1px solid var(--line)}
.cat:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.cat.feat{grid-column:span 2;grid-row:span 2;aspect-ratio:auto}
.cat .c-bg{position:absolute;inset:0;z-index:0}
.cat .c-bg img,.cat .c-bg .ph{width:100%;height:100%;object-fit:cover}
.cat .c-tint{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,transparent 30%,rgba(0,0,0,.85) 100%)}
.cat .c-content{position:relative;z-index:2;display:flex;flex-direction:column;justify-content:space-between;height:100%}
.cat .c-tag{align-self:flex-start;display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border-radius:999px;font-family:"JetBrains Mono";font-size:11px;letter-spacing:.06em;color:#fff;background:rgba(255,255,255,.12);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.18)}
.cat .c-tag .t-dot{width:6px;height:6px;border-radius:50%;background:var(--ocean-l)}
.cat .c-bottom{display:flex;flex-direction:column;gap:8px}
.cat .c-name{font-family:"Inter Tight";font-weight:800;font-size:32px;letter-spacing:-.025em;line-height:.95;color:#fff}
.cat.feat .c-name{font-size:56px}
.cat .c-count{font-size:13px;color:rgba(255,255,255,.7);display:flex;align-items:center;gap:8px}
.cat .c-count .arrow{margin-left:auto;width:36px;height:36px;background:rgba(255,255,255,.15)}
.ph{background:linear-gradient(160deg,#0a3a6b,#1e5fa0 35%,#3D8BE0 70%,#7BB1F0)}

/* Section frame ------------------------------------------------------------ */
section.bay{padding:120px 32px 0;max-width:1380px;margin:0 auto}
.sec-head{margin-bottom:48px}
.sec-title{font-family:"Inter Tight";font-weight:800;font-size:64px;letter-spacing:-.035em;line-height:.95;max-width:1100px}
.sec-title em{font-style:normal;background:linear-gradient(95deg,var(--ocean-l),var(--nature-l));-webkit-background-clip:text;background-clip:text;color:transparent}

/* Experience cards --------------------------------------------------------- */
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.exp{border-radius:24px;background:var(--surf);border:1px solid var(--line);overflow:hidden;cursor:pointer;transition:.2s;display:flex;flex-direction:column}
.exp:hover{transform:translateY(-3px);border-color:var(--line-2);box-shadow:0 20px 40px -16px rgba(0,0,0,.4)}
.exp .img{aspect-ratio:4/3;position:relative;overflow:hidden}
.exp .img img{width:100%;height:100%;object-fit:cover}
.exp .badge{position:absolute;top:16px;left:16px;padding:6px 10px;border-radius:999px;font-family:"JetBrains Mono";font-size:10.5px;letter-spacing:.08em;color:#fff;background:rgba(0,0,0,.55);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.15)}
.exp .save{position:absolute;top:16px;right:16px;width:38px;height:38px;border-radius:50%;background:rgba(0,0,0,.55);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;color:#fff}
.exp .body{padding:22px;display:flex;flex-direction:column;gap:14px;flex:1}
.exp .meta-top{display:flex;justify-content:space-between;align-items:center;font-size:12.5px;color:var(--ink-3);gap:8px}
.exp .meta-top .rating{display:flex;align-items:center;gap:6px;color:var(--ink)}
.exp .meta-top .rating svg{color:var(--earth)}
.exp .name{font-family:"Inter Tight";font-weight:700;font-size:22px;letter-spacing:-.02em;line-height:1.1}
.exp .where{font-size:13.5px;color:var(--ink-2);display:flex;align-items:center;gap:6px}
.exp .meta-bot{display:flex;justify-content:space-between;align-items:center;padding-top:14px;margin-top:auto;border-top:1px solid var(--line)}
.exp .price{display:flex;flex-direction:column;gap:2px}
.exp .price-from{font-size:11px;color:var(--ink-3);letter-spacing:.04em;text-transform:uppercase}
.exp .price-val{font-family:"Inter Tight";font-weight:800;font-size:24px;letter-spacing:-.02em}
.exp .price-val em{font-style:normal;font-size:13px;font-weight:600;color:var(--ink-2)}
.exp .book{padding:10px 14px;border-radius:999px;background:var(--ink);color:var(--bg);font-size:13px;font-weight:600;border:0;cursor:pointer;display:flex;align-items:center;gap:6px}
.exp .book:hover{background:linear-gradient(135deg,var(--ocean),var(--nature));color:#fff}

/* Stats -------------------------------------------------------------------- */
.stats-wrap{max-width:1380px;margin:0 auto;padding:0 32px}
.hero-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:20px;overflow:hidden;margin-top:56px}
.hero-stats .stat{padding:32px 24px;background:var(--bg);display:flex;flex-direction:column;gap:8px}
.stat .num{font-family:"Inter Tight";font-weight:800;font-size:48px;letter-spacing:-.04em;line-height:1}
.stat .num em{font-style:normal;background:linear-gradient(135deg,var(--ocean),var(--nature));-webkit-background-clip:text;background-clip:text;color:transparent}
.stat .lbl{font-size:13px;color:var(--ink-2)}
.stat .delta{font-family:"JetBrains Mono";font-size:11px;color:var(--nature);margin-top:auto}

/* CTA banner --------------------------------------------------------------- */
.cta{margin:140px auto 0;max-width:1380px;border-radius:36px;padding:80px 64px;position:relative;overflow:hidden;border:1px solid var(--line-2);background:var(--surf)}
.cta::before{content:"";position:absolute;inset:0;background:var(--grad);opacity:.7;z-index:0}
.cta::after{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 50% 100%,transparent 20%, var(--surf) 90%);z-index:0}
.cta-inner{position:relative;z-index:1;display:grid;grid-template-columns:1.4fr 1fr;gap:64px;align-items:end}
.cta h2{font-family:"Inter Tight";font-weight:900;font-size:80px;letter-spacing:-.045em;line-height:.92}
.cta h2 .it{font-style:italic;font-weight:500}
.cta-actions{display:flex;flex-direction:column;gap:14px;align-items:flex-start}
.cta-actions p{color:var(--ink-2);font-size:16px;line-height:1.5;margin-bottom:8px;max-width:380px}
.btn-primary{padding:18px 28px;border-radius:999px;background:var(--ink);color:var(--bg);font-family:"Inter Tight";font-weight:700;font-size:17px;border:0;cursor:pointer;display:inline-flex;align-items:center;gap:10px}
.btn-primary:hover{background:linear-gradient(135deg,var(--ocean),var(--nature));color:#fff}
.btn-secondary{padding:18px 28px;border-radius:999px;background:transparent;color:var(--ink);border:1px solid var(--line-2);font-family:"Inter Tight";font-weight:600;font-size:16px;cursor:pointer;display:inline-flex;align-items:center;gap:10px}
.btn-secondary:hover{background:var(--surf-2)}

/* Footer ------------------------------------------------------------------- */
footer.site{margin-top:140px;border-top:1px solid var(--line);padding:64px 32px 48px}
.foot-inner{max-width:1380px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:64px}
.foot-brand .b-name{font-family:"Inter Tight";font-weight:900;font-size:40px;letter-spacing:-.04em;line-height:.95;margin-top:24px}
.foot-brand .b-name .it{font-style:italic;font-weight:500;color:var(--ink-2);font-size:30px}
.foot-brand p{color:var(--ink-2);max-width:340px;margin-top:16px;font-size:14px;line-height:1.55}
.foot-col h4{font-family:"Inter Tight";font-size:13px;font-weight:600;color:var(--ink-3);text-transform:uppercase;letter-spacing:.1em;margin-bottom:18px}
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.foot-col a{font-size:14px;color:var(--ink-2)}
.foot-col a:hover{color:var(--ink)}
.foot-bot{max-width:1380px;margin:64px auto 0;padding-top:24px;border-top:1px solid var(--line);display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;color:var(--ink-3);font-size:12.5px;font-family:"JetBrains Mono"}

/* Page header (listing / generic) ----------------------------------------- */
.page-head{position:relative;padding:72px 32px 0;overflow:hidden}
.page-head .hero-bg{height:340px}
.page-head-inner{position:relative;z-index:1;max-width:1380px;margin:0 auto}
.eyebrow{font-family:"JetBrains Mono";font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);margin-bottom:14px}
.page-title{font-family:"Inter Tight";font-weight:800;font-size:64px;letter-spacing:-.035em;line-height:.95}
.page-sub{color:var(--ink-2);font-size:17px;margin-top:16px;max-width:560px}

/* Filter chips bar (listing) ---------------------------------------------- */
.catbar{display:flex;gap:10px;flex-wrap:wrap;max-width:1380px;margin:36px auto 0;padding:0 32px}
.catbar a{padding:10px 18px;border-radius:999px;background:var(--surf);border:1px solid var(--line);font-size:14px;font-weight:600;color:var(--ink-2);transition:.15s}
.catbar a:hover{border-color:var(--line-2);color:var(--ink)}
.catbar a.active{background:var(--ink);color:var(--bg);border-color:var(--ink)}

.listing{max-width:1380px;margin:0 auto;padding:40px 32px 0}
.listing .features{grid-template-columns:repeat(3,1fr)}
.empty{max-width:1380px;margin:0 auto;padding:80px 32px;text-align:center;color:var(--ink-2)}

/* In-development page ------------------------------------------------------ */
.indev{min-height:70vh;display:flex;align-items:center;justify-content:center;padding:80px 32px;position:relative;overflow:hidden;text-align:center}
.indev .hero-bg{height:100%}
.indev-inner{position:relative;z-index:1;max-width:560px}
.indev-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border-radius:999px;background:var(--surf);border:1px solid var(--line-2);font-family:"JetBrains Mono";font-size:12px;letter-spacing:.08em;color:var(--earth);text-transform:uppercase}
.indev h1{font-family:"Inter Tight";font-weight:800;font-size:56px;letter-spacing:-.04em;line-height:.95;margin:24px 0 16px}
.indev p{color:var(--ink-2);font-size:18px;line-height:1.6;margin-bottom:32px}
.indev .dots{display:flex;gap:8px;justify-content:center;margin-bottom:32px}
.indev .dots span{width:10px;height:10px;border-radius:50%;background:var(--ink-3);animation:indevpulse 1.4s infinite ease-in-out}
.indev .dots span:nth-child(2){animation-delay:.2s}
.indev .dots span:nth-child(3){animation-delay:.4s}
@keyframes indevpulse{0%,100%{opacity:.25;transform:scale(.8)}50%{opacity:1;transform:scale(1)}}

/* ==========================================================================
   Product detail (PDP)
   ========================================================================== */
.pdp{padding:28px 0 0}
.pdp-inner{padding:0 32px}
.pdp-crumbs{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--ink-3);margin-bottom:22px;flex-wrap:wrap}
.pdp-crumbs a{color:var(--ink-2)}
.pdp-crumbs a:hover{color:var(--ink)}
.pdp-crumbs .cur{color:var(--ink)}

/* Gallery ------------------------------------------------------------------ */
.pdp-gallery{display:grid;grid-template-columns:1.55fr .85fr;grid-template-rows:repeat(2,1fr);gap:12px;height:480px;margin-bottom:40px}
.pdp-gallery.single{grid-template-columns:1fr}
.pg-main{grid-row:1 / span 2;position:relative;border-radius:24px;overflow:hidden;border:1px solid var(--line);margin:0}
.pg-main img{width:100%;height:100%;object-fit:cover}
.pg-main .badge{position:absolute;top:18px;left:18px;padding:7px 12px;border-radius:999px;font-family:"JetBrains Mono";font-size:10.5px;letter-spacing:.08em;color:#fff;background:rgba(0,0,0,.55);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.15)}
.pg-thumbs{display:grid;grid-template-rows:1fr 1fr;gap:12px;grid-column:2;grid-row:1 / span 2}
.pg-thumb{padding:0;border:1px solid var(--line);border-radius:20px;overflow:hidden;cursor:pointer;background:none;position:relative;transition:.15s}
.pg-thumb img{width:100%;height:100%;object-fit:cover;transition:.25s}
.pg-thumb:hover img{transform:scale(1.04)}
.pg-thumb.active{border-color:var(--ocean);box-shadow:0 0 0 2px color-mix(in oklab,var(--ocean) 50%,transparent)}

/* Grid layout -------------------------------------------------------------- */
.pdp-grid{display:grid;grid-template-columns:1fr 380px;gap:56px;align-items:start}
.pdp-main{min-width:0}

.pdp-head{padding-bottom:8px}
.pdp-title{font-family:"Inter Tight";font-weight:800;font-size:46px;letter-spacing:-.035em;line-height:1;margin:10px 0 20px}
.pdp-meta{display:flex;flex-wrap:wrap;gap:10px}
.pm{display:inline-flex;align-items:center;gap:7px;padding:8px 14px;border-radius:999px;background:var(--surf);border:1px solid var(--line);font-size:13.5px;color:var(--ink-2)}
.pm svg{color:var(--ink-3)}
.pm.rating{color:var(--ink)}
.pm.rating svg{color:var(--earth)}
.pm.rating .muted{color:var(--ink-3)}

/* Sections ----------------------------------------------------------------- */
.pdp-section{padding:32px 0;border-top:1px solid var(--line)}
.pdp-head + .pdp-section{border-top:0;padding-top:24px}
.pdp-h2{font-family:"Inter Tight";font-weight:800;font-size:26px;letter-spacing:-.02em;margin-bottom:22px;display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.pdp-lead{font-size:16.5px;line-height:1.7;color:var(--ink-2)}
.pdp-lead.sm{font-size:15px;margin-bottom:18px}

.incl-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px 40px}
.incl{list-style:none;display:flex;flex-direction:column;gap:12px}
.incl li{display:flex;align-items:flex-start;gap:11px;font-size:14.5px;color:var(--ink);line-height:1.45}
.incl li svg{flex:none;margin-top:2px}
.incl.yes li svg{color:var(--nature)}
.incl.no li{color:var(--ink-2)}
.incl.no li svg{color:var(--ink-3)}

.timeline{list-style:none;position:relative;padding-left:6px}
.timeline li{position:relative;padding:0 0 22px 28px;font-size:15px;color:var(--ink);line-height:1.5}
.timeline li:last-child{padding-bottom:0}
.timeline li::before{content:"";position:absolute;left:5px;top:7px;bottom:-7px;width:2px;background:var(--line)}
.timeline li:last-child::before{display:none}
.tl-dot{position:absolute;left:0;top:4px;width:12px;height:12px;border-radius:50%;background:var(--bg);border:2px solid var(--ocean)}

.pdp-twocol{display:grid;grid-template-columns:1fr 1fr;gap:40px}
.info-block h3{font-family:"Inter Tight";font-weight:700;font-size:17px;margin-bottom:14px}
.dotlist{list-style:none;display:flex;flex-direction:column;gap:9px}
.dotlist li{position:relative;padding-left:18px;font-size:14.5px;color:var(--ink-2);line-height:1.45}
.dotlist li::before{content:"";position:absolute;left:0;top:9px;width:6px;height:6px;border-radius:50%;background:var(--earth)}

/* Reviews ------------------------------------------------------------------ */
.rev-agg{font-family:"Inter";font-weight:600;font-size:14px;color:var(--ink-2);display:inline-flex;align-items:center;gap:7px}
.rev-agg svg{color:var(--earth)}
.rev-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.rev-card{background:var(--surf);border:1px solid var(--line);border-radius:18px;padding:20px;display:flex;flex-direction:column;gap:12px}
.rev-stars{display:flex;gap:2px}
.rev-stars .on{color:var(--earth)}
.rev-stars .off{color:var(--line-2)}
.rev-text{font-size:14.5px;line-height:1.55;color:var(--ink);font-style:italic}
.rev-by{font-size:13px;font-weight:600;color:var(--ink);margin-top:auto}
.rev-date{color:var(--ink-3);font-weight:400}

/* Map ---------------------------------------------------------------------- */
.pdp-map{border-radius:20px;overflow:hidden;border:1px solid var(--line);height:300px}
.pdp-map iframe{width:100%;height:100%;border:0;display:block;filter:grayscale(.2)}
.map-ph{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--ink-3);background:var(--grad)}
.map-ph span{font-family:"JetBrains Mono";font-size:12px;letter-spacing:.08em;color:var(--ink-2)}

/* Booking card ------------------------------------------------------------- */
.pdp-aside{position:sticky;top:96px}
.book-card{background:var(--surf);border:1px solid var(--line-2);border-radius:24px;padding:24px;box-shadow:var(--shadow)}
.bc-head{display:flex;align-items:baseline;justify-content:space-between;gap:10px;padding-bottom:18px;margin-bottom:18px;border-bottom:1px solid var(--line)}
.bc-label{font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-3)}
.bc-price{font-family:"Inter Tight";font-weight:800;font-size:30px;letter-spacing:-.02em}
.bc-price em{font-style:normal;font-size:13px;font-weight:600;color:var(--ink-2)}
.bc-field{display:flex;flex-direction:column;gap:7px;margin-bottom:14px}
.bc-field > span{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-3);font-weight:600}
.bc-field input,.bc-field select{appearance:none;-webkit-appearance:none;width:100%;background:var(--bg-2);border:1px solid var(--line-2);border-radius:12px;padding:13px 14px;color:var(--ink);font-family:"Inter";font-size:15px;font-weight:600;cursor:pointer}
.bc-field input:focus,.bc-field select:focus{outline:none;border-color:var(--ocean)}
.bc-field select option{color:#0A0A0B;background:#fff}
.bc-field input[type="date"]::-webkit-calendar-picker-indicator{filter:invert(.6)}
:root[data-theme="light"] .bc-field input[type="date"]::-webkit-calendar-picker-indicator{filter:none}

.bc-sub{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-3);font-weight:600;margin:6px 0 10px}
.bc-pax{padding:6px 0}
.pax-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 0}
.pax-info{display:flex;flex-direction:column;gap:1px}
.pax-info strong{font-size:14.5px;font-weight:600}
.pax-info em{font-style:normal;font-size:12.5px;color:var(--ink-3)}
.stepper{display:flex;align-items:center;gap:4px}
.stepper button{width:32px;height:32px;border-radius:9px;border:1px solid var(--line-2);background:var(--bg-2);color:var(--ink);font-size:18px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.15s}
.stepper button:hover{border-color:var(--ocean);color:var(--ocean)}
.st-val{min-width:26px;text-align:center;font-weight:700;font-size:15px}

.bc-extras{border-top:1px solid var(--line);margin-top:14px;padding-top:8px}
.extra-row{display:flex;align-items:center;gap:11px;padding:9px 0;cursor:pointer;font-size:14px}
.extra-row .extra-cb{width:18px;height:18px;accent-color:var(--ocean);cursor:pointer;flex:none}
.extra-name{flex:1;color:var(--ink)}
.extra-price{font-weight:700;font-size:13.5px;color:var(--ink-2)}
.extra-price em{font-style:normal;font-weight:400;color:var(--ink-3);font-size:11px}

.bc-total{display:flex;align-items:center;justify-content:space-between;margin-top:16px;padding-top:16px;border-top:1px solid var(--line)}
.bc-total span{font-size:14px;color:var(--ink-2)}
.bc-total strong{font-family:"Inter Tight";font-weight:800;font-size:28px;letter-spacing:-.02em;background:linear-gradient(135deg,var(--ocean),var(--nature));-webkit-background-clip:text;background-clip:text;color:transparent}
.bc-confirm{display:flex;align-items:center;justify-content:center;width:100%;margin-top:18px;padding:16px;border-radius:14px;background:var(--ink);color:var(--bg);font-family:"Inter Tight";font-weight:700;font-size:16px;cursor:pointer;transition:.15s}
.bc-confirm:hover{background:linear-gradient(135deg,var(--ocean),var(--nature));color:#fff}
.bc-note{display:flex;align-items:center;justify-content:center;gap:7px;margin-top:14px;font-size:12.5px;color:var(--ink-3)}
.bc-note svg{color:var(--nature)}

.pdp-related{padding:48px 0 0;margin-top:40px;border-top:1px solid var(--line)}
.pdp-related .pdp-h2{margin-bottom:28px}

@media (max-width:1100px){
  .pdp-title{font-size:38px}
  .pdp-grid{grid-template-columns:1fr 340px;gap:40px}
}
@media (max-width:900px){
  .pdp-grid{grid-template-columns:1fr;gap:0}
  .pdp-aside{position:static;margin:8px 0 8px}
  .book-card{max-width:520px}
  .rev-grid{grid-template-columns:1fr}
}
@media (max-width:820px){
  .pdp-inner{padding:0 16px}
  .pdp-gallery{grid-template-columns:1fr;grid-template-rows:auto;height:auto}
  .pg-main{height:280px;grid-row:auto}
  .pg-thumbs{grid-column:auto;grid-row:auto;grid-template-rows:none;grid-template-columns:repeat(4,1fr);height:84px}
  .incl-grid,.pdp-twocol{grid-template-columns:1fr;gap:18px}
  .pdp-title{font-size:32px}
}

/* PRR funding bar (footer) ------------------------------------------------- */
.funding-band{margin-top:40px;border-top:1px solid var(--line);padding:26px 32px 6px}
.funding-inner{max-width:1380px;margin:0 auto;display:flex;flex-direction:column;gap:16px}
.funding-desc{font-size:12px;line-height:1.6;color:var(--ink-3);max-width:820px}
.funding-links{display:flex;align-items:center;gap:28px;flex-wrap:wrap}
.funding-bar{display:inline-flex;align-items:center;gap:28px;flex-wrap:wrap}
.funding-bar img{height:42px;width:auto;display:block;opacity:.92;transition:.15s}
.funding-bar img.funding-logo-acores{height:60px}
.funding-bar:hover img{opacity:1}
.funding-portal{font-family:"JetBrains Mono";font-size:12px;letter-spacing:.02em;color:var(--ink-2);border-bottom:1px solid var(--line-2);padding-bottom:2px;transition:.15s}
.funding-portal:hover{color:var(--ocean)}
/* Logos are white wordmarks — invert them on the light theme so they stay legible. */
:root[data-theme="light"] .funding-bar img{filter:invert(1) brightness(.35)}
@media (max-width:820px){
  .funding-band{padding:22px 16px 6px}
  .funding-bar{gap:20px}
  .funding-bar img{height:36px}
  .funding-bar img.funding-logo-acores{height:52px}
}

/* Theme toggle in navbar --------------------------------------------------- */
.theme-toggle{width:40px;height:40px;border-radius:10px;background:transparent;border:1px solid var(--line);color:var(--ink-2);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:.15s}
.theme-toggle:hover{background:var(--surf);color:var(--ink)}
.theme-toggle .sun{display:none}
:root[data-theme="light"] .theme-toggle .sun{display:block}
:root[data-theme="light"] .theme-toggle .moon{display:none}

/* Responsive --------------------------------------------------------------- */
@media (max-width:1100px){
  .sec-title,.page-title{font-size:48px}
  .cta h2{font-size:60px}
  .features{grid-template-columns:repeat(2,1fr)}
  .listing .features{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:820px){
  .appbar{gap:16px;padding:0 18px}
  .nav{display:none}
  .burger{display:flex}
  .hide-sm{display:none}
  .hero-cats{padding:28px 16px 48px}
  .filter{grid-template-columns:1fr 1fr;border-radius:24px}
  .filter-cta{grid-column:span 2;min-height:64px}
  .cats{grid-template-columns:repeat(2,1fr)}
  .cat.feat{grid-column:span 2;grid-row:span 1;aspect-ratio:16/10}
  .cat.feat .c-name{font-size:40px}
  section.bay{padding:72px 16px 0}
  .sec-title,.page-title{font-size:38px}
  .features{grid-template-columns:1fr}
  .stats-wrap{padding:0 16px}
  .hero-stats{grid-template-columns:repeat(2,1fr)}
  .cta{padding:48px 28px;border-radius:28px;margin-top:90px}
  .cta-inner{grid-template-columns:1fr;gap:28px}
  .cta h2{font-size:44px}
  .foot-inner{grid-template-columns:1fr 1fr;gap:36px}
  .page-head,.catbar,.listing{padding-left:16px;padding-right:16px}
  .listing .features{grid-template-columns:1fr}
  .indev h1{font-size:40px}
}
