:root{--ink: #182321;--muted: #5b6966;--line: #dbe6e2;--paper: #fbfbf7;--mist: #eef6f3;--lagoon: #007f88;--deep: #064850;--leaf: #36785f;--sun: #f0b35a;--white: #ffffff;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:var(--ink);background:var(--paper)}*{box-sizing:border-box}body{margin:0;min-width:320px;line-height:1.5}a{color:inherit}img{display:block;max-width:100%}.site-header{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:24px;padding:14px clamp(18px,4vw,56px);background:#fbfbf7eb;border-bottom:1px solid var(--line);backdrop-filter:blur(18px)}.brand{display:inline-flex;align-items:center;gap:10px;text-decoration:none}.brand-mark{display:grid;place-items:center;width:40px;height:40px;border-radius:8px;color:var(--white);background:var(--deep);font-weight:800}.brand strong,.brand small{display:block}.brand small{color:var(--muted);font-size:12px}nav{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}nav a,.button,button{min-height:42px;display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:8px;padding:10px 14px;border:1px solid transparent;font-weight:700;text-decoration:none}nav a:hover,.button.secondary{border-color:var(--line);background:var(--white)}.hero .button.secondary{color:var(--deep)}.button.primary,button{color:var(--white);border-color:var(--deep);background:var(--deep)}.hero{min-height:calc(100svh - 70px);display:grid;align-items:end;padding:clamp(28px,6vw,72px);color:var(--white);background:linear-gradient(180deg,#00000014,#000000b8),url(/images/moorea-lagoon-tour.jpg) center / cover}.hero-content{width:min(860px,100%)}.eyebrow{margin:0 0 12px;color:var(--sun);font-weight:800;text-transform:uppercase;font-size:13px}h1,h2,h3,p{margin-top:0}h1{max-width:840px;margin-bottom:18px;font-size:clamp(42px,8vw,86px);line-height:.95;letter-spacing:0}h2{margin-bottom:14px;font-size:clamp(28px,4vw,46px);line-height:1.08;letter-spacing:0}h3{font-size:20px}.lead{max-width:720px;color:inherit;font-size:clamp(18px,2.4vw,23px)}.hero-actions,.actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:28px}.section{padding:clamp(48px,7vw,96px) clamp(18px,4vw,56px)}.section.alt{background:var(--mist)}.section-head{max-width:780px;margin-bottom:28px}.muted{color:var(--muted)}.grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.card{overflow:hidden;border:1px solid var(--line);border-radius:8px;background:var(--white)}.card-body{padding:18px}.card img{width:100%;aspect-ratio:4 / 3;object-fit:cover}.tag-row{display:flex;flex-wrap:wrap;gap:8px;margin:14px 0 0;padding:0;list-style:none}.tag-row li,.pill{border:1px solid var(--line);border-radius:999px;padding:5px 9px;color:var(--deep);background:var(--paper);font-size:13px;font-weight:700}.split{display:grid;grid-template-columns:minmax(0,.95fr) minmax(0,1.05fr);gap:clamp(24px,5vw,72px);align-items:center}.steps{counter-reset:step;display:grid;gap:12px;padding:0;list-style:none}.steps li{counter-increment:step;display:grid;grid-template-columns:42px 1fr;gap:14px;align-items:start}.steps li:before{content:counter(step);display:grid;place-items:center;width:42px;height:42px;border-radius:8px;color:var(--white);background:var(--lagoon);font-weight:900}.booking-panel{padding:22px;border:1px solid var(--line);border-radius:8px;background:var(--white)}form{display:grid;gap:14px}label{display:grid;gap:6px;color:var(--deep);font-weight:800}input,select,textarea{width:100%;min-height:44px;border:1px solid var(--line);border-radius:8px;padding:10px 12px;color:var(--ink);background:var(--paper);font:inherit}textarea{min-height:110px;resize:vertical}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.site-footer{display:flex;justify-content:space-between;gap:24px;padding:30px clamp(18px,4vw,56px);color:var(--white);background:var(--deep)}.site-footer p{margin-bottom:0;color:#ffffffc2}.footer-links{display:flex;flex-direction:column;gap:8px;align-items:flex-end}@media(max-width:820px){.site-header,.site-footer{align-items:flex-start;flex-direction:column}nav,.footer-links{justify-content:flex-start;align-items:flex-start}.hero{min-height:78svh}.grid,.grid.two,.split,.form-grid{grid-template-columns:1fr}}
