/* ===== Terrapots Mauritius — shared styles ===== */
:root{
  --paper:#F6F3EC;        /* warm off-white page */
  --panel:#ECE8DE;        /* slightly deeper panel */
  --card:#FBFAF6;         /* product tile / card */
  --ink:#2E2B25;          /* primary text */
  --muted:#6E6A60;        /* secondary text */
  --hair:#DCD7CA;         /* hairlines */
  --accent:#8A8475;       /* quiet accent */
  --maxw:1080px;
  --space:clamp(2rem,6vw,5rem);
  --font-display:"Cormorant Garamond",Georgia,serif;
  --font-body:"Jost","Helvetica Neue",Arial,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--font-body);
  font-weight:300;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}

/* ---- type ---- */
h1,h2,h3{font-family:var(--font-display);font-weight:500;line-height:1.15;letter-spacing:.01em}
.eyebrow{font-family:var(--font-body);font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;color:var(--accent);font-weight:400}
.lede{font-size:1.05rem;color:var(--muted);max-width:42ch}

/* ---- layout helpers ---- */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:clamp(1.25rem,5vw,3rem)}
.section{padding-block:var(--space)}
.center{text-align:center}
.muted{color:var(--muted)}

/* ---- header / nav ---- */
.site-head{position:sticky;top:0;z-index:20;background:rgba(246,243,236,.88);backdrop-filter:blur(8px);border-bottom:1px solid var(--hair)}
.site-head .wrap{display:flex;align-items:center;justify-content:space-between;padding-block:1rem}
.brand{display:flex;flex-direction:column;line-height:1}
.brand b{font-family:var(--font-display);font-size:1.35rem;font-weight:600;letter-spacing:.14em}
.brand span{font-size:.55rem;letter-spacing:.42em;color:var(--muted);margin-top:4px}
.nav{display:flex;gap:1.6rem;font-size:.82rem;letter-spacing:.04em}
.nav a{color:var(--muted);transition:color .2s}
.nav a:hover,.nav a[aria-current="page"]{color:var(--ink)}
.nav-toggle{display:none;background:none;border:0;font-size:1.4rem;color:var(--ink);cursor:pointer}

/* ---- buttons ---- */
.btn{display:inline-block;font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;padding:.85em 1.8em;border:1px solid var(--ink);border-radius:2px;transition:background .25s,color .25s}
.btn:hover{background:var(--ink);color:var(--paper)}
.btn-ghost{border-color:var(--hair);color:var(--muted)}
.btn-ghost:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}

/* ---- hero ---- */
.hero{display:grid;grid-template-columns:1.05fr 1fr;min-height:78vh}
.hero-text{display:flex;flex-direction:column;justify-content:center;gap:1.4rem;padding:clamp(2rem,6vw,5rem)}
.hero-text h1{font-size:clamp(2.6rem,6vw,4.2rem)}
.hero-img{background:var(--panel);position:relative;overflow:hidden}
.hero-img img{width:100%;height:100%;object-fit:cover}
.ph{display:flex;align-items:center;justify-content:center;color:#b3ac9c;font-size:.72rem;letter-spacing:.12em;text-align:center;background:
   repeating-linear-gradient(45deg,#e7e2d6 0 14px,#ece8de 14px 28px)}

/* ---- trust band ---- */
.trust{border-block:1px solid var(--hair);background:var(--card)}
.trust .wrap{display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:space-between;padding-block:1.1rem;font-size:.78rem;letter-spacing:.04em;color:var(--muted)}
.trust span{display:flex;align-items:center;gap:.5rem}
.dot{width:4px;height:4px;border-radius:50%;background:var(--accent);display:inline-block}

/* ---- section heads ---- */
.head-row{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:1.8rem;gap:1rem;flex-wrap:wrap}
.head-row h2{font-size:clamp(1.6rem,3.4vw,2.2rem)}
.head-row a{font-size:.78rem;letter-spacing:.1em;color:var(--muted);border-bottom:1px solid var(--hair);padding-bottom:2px}
.head-row a:hover{color:var(--ink)}

/* ---- finish tiles ---- */
.tiles{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}
.tile figure{aspect-ratio:1;background:var(--panel);border-radius:3px;overflow:hidden}
.tile figure img{width:100%;height:100%;object-fit:cover}
.tile figcaption{margin-top:.7rem;font-size:.9rem;letter-spacing:.02em}
.tile small{color:var(--muted);font-size:.78rem}

/* ---- product grid ---- */
.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem}
.prod figure{aspect-ratio:.84;background:var(--card);border:1px solid var(--hair);border-radius:3px;overflow:hidden}
.prod figure img{width:100%;height:100%;object-fit:cover}
.prod .name{margin-top:.7rem;font-size:.86rem}
.prod .meta{font-size:.8rem;color:var(--muted)}

/* ---- story / split panels ---- */
.split{display:grid;grid-template-columns:1.1fr 1fr;background:var(--panel);border-radius:4px;overflow:hidden}
.split .copy{display:flex;flex-direction:column;justify-content:center;gap:1rem;padding:clamp(2rem,5vw,3.5rem)}
.split .copy h2{font-size:clamp(1.5rem,3vw,2rem)}
.split .pane{min-height:240px;background:var(--card)}
.split .pane img{width:100%;height:100%;object-fit:cover}

/* ---- generic content page ---- */
.page-hero{padding-block:clamp(2.5rem,7vw,4.5rem) clamp(1.5rem,4vw,2.5rem)}
.page-hero h1{font-size:clamp(2.2rem,5vw,3.4rem)}
.prose{max-width:62ch}
.prose p{margin-bottom:1.1rem;color:#403c34}
.prose h3{font-size:1.15rem;margin:2rem 0 .5rem;color:var(--ink)}
.prose .small{font-size:.86rem;color:var(--muted)}

/* ---- stockist card ---- */
.stockist{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid var(--hair);border-radius:4px;overflow:hidden;background:var(--card);margin-top:1.5rem}
.stockist .info{padding:clamp(1.5rem,4vw,2.4rem);display:flex;flex-direction:column;gap:.5rem}
.stockist .info h3{font-family:var(--font-display);font-size:1.5rem}
.stockist .info .row{font-size:.9rem;color:var(--muted)}
.stockist .photo{background:var(--panel);min-height:220px}
.stockist .photo img{width:100%;height:100%;object-fit:cover}
.coming{margin-top:1.4rem;font-size:.9rem;color:var(--muted);font-style:italic}

/* ---- footer ---- */
.site-foot{border-top:1px solid var(--hair);background:var(--card);margin-top:var(--space)}
.site-foot .wrap{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;padding-block:1.6rem;font-size:.78rem;color:var(--muted)}
.site-foot .social{display:flex;gap:1.1rem}
.site-foot a:hover{color:var(--ink)}

/* ---- reveal on scroll ---- */
.reveal{opacity:0;transform:translateY(14px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ---- responsive ---- */
@media(max-width:820px){
  .hero{grid-template-columns:1fr;min-height:auto}
  .hero-img{min-height:46vh;order:-1}
  .split{grid-template-columns:1fr}
  .split .pane{min-height:200px;order:-1}
  .stockist{grid-template-columns:1fr}
  .stockist .photo{order:-1;min-height:180px}
  .grid{grid-template-columns:repeat(2,1fr)}
  .nav{position:fixed;inset:0 0 0 auto;width:min(74vw,300px);background:var(--paper);flex-direction:column;gap:1.4rem;padding:5rem 2rem;border-left:1px solid var(--hair);transform:translateX(100%);transition:transform .3s ease;font-size:1rem}
  .nav.open{transform:none}
  .nav-toggle{display:block;z-index:30}
}
@media(max-width:480px){
  .tiles{grid-template-columns:1fr 1fr}
  .grid{grid-template-columns:1fr 1fr}
  .trust .wrap{justify-content:flex-start;gap:.6rem 1.3rem}
}
