/* La Volée — nature retreat, Normandy.
   Direction: Op-art monochrome held in restraint → crisp gallery/print on warm paper,
   one fine-line "contour" optical motif, single forest-green accent.
   Metaphor: vintage matchbook → small-caps struck labels, striking-strip rules,
   numbered panels, compact tactile composition. Real photography leads. */

:root{
  --paper:#f4f1e9;        /* warm paper canvas */
  --paper-2:#ece7da;      /* slightly deeper paper */
  --ink:#1c1b17;          /* near-black ink (NOT a charcoal hero bg) */
  --ink-soft:#4a473e;
  --line:#cfc8b6;         /* hairline on paper */
  --green:#446744;        /* real brand green */
  --green-deep:#2f4a30;
  --green-leaf:#94c794;   /* logo leaf */
  --coral:#cf2e2e;        /* real brand red — used as the single "struck match" accent, sparingly */
  --white:#ffffff;
  --maxw:1160px;
  --gap:clamp(1.1rem,3vw,2rem);
  --r:3px;                /* matchbook = sharp, tiny radius */
  --shadow:0 1px 0 var(--line), 0 14px 34px -22px rgba(28,27,23,.5);
  --fast:.45s cubic-bezier(.2,.7,.2,1);
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;background:var(--paper);color:var(--ink);
  font-family:"Spectral",Georgia,serif;font-size:clamp(16px,1.05vw,18px);
  line-height:1.65;-webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit}
h1,h2,h3,h4{font-family:"Archivo",system-ui,sans-serif;font-weight:800;line-height:1.04;
  letter-spacing:-.015em;margin:0;overflow-wrap:break-word}
p{overflow-wrap:break-word}

/* small-caps struck label (matchbook) */
.label{font-family:"Archivo",sans-serif;font-weight:700;text-transform:uppercase;
  letter-spacing:.26em;font-size:.66rem;color:var(--green);display:inline-flex;align-items:center;gap:.6em}
.label::before{content:"";width:26px;height:2px;background:var(--coral);display:inline-block}
.label.num::before{content:counter(panel,decimal-leading-zero);width:auto;height:auto;
  background:none;color:var(--coral);font-variant-numeric:tabular-nums;letter-spacing:0}

.skip{position:absolute;left:-999px;top:0;background:var(--ink);color:var(--paper);
  padding:.7em 1.1em;z-index:200;border-radius:0 0 var(--r) 0}
.skip:focus{left:0}

:focus-visible{outline:3px solid var(--green);outline-offset:3px}

.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:clamp(1.1rem,5vw,2.6rem)}
section{padding-block:clamp(3.2rem,7vw,6rem)}
.lead{font-size:clamp(1.12rem,1.7vw,1.4rem);color:var(--ink-soft);max-width:62ch}

/* ===== contour / op-art hairline motif (the one optical element) ===== */
.contour{
  background-image:repeating-linear-gradient(115deg,
     transparent 0 9px, rgba(68,103,68,.10) 9px 10px);
}
.strike{height:6px;background:
   repeating-linear-gradient(90deg,var(--coral) 0 9px,var(--paper) 9px 16px);
   border-block:1px solid var(--ink);opacity:.9}

/* ===== HEADER ===== */
.site-head{position:sticky;top:0;z-index:100;background:rgba(244,241,233,.86);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav{max-width:var(--maxw);margin-inline:auto;display:flex;align-items:center;gap:1rem;
  padding:.7rem clamp(1.1rem,5vw,2.6rem);min-width:0}
.brand{display:flex;align-items:center;gap:.7rem;text-decoration:none;flex:0 0 auto}
.brand svg, .brand img{height:34px;width:auto}
.brand .bw{filter:none}
.nav-links{margin-left:auto;display:flex;gap:.2rem;flex-wrap:wrap;align-items:center;min-width:0}
.nav-links a{font-family:"Archivo",sans-serif;font-weight:600;font-size:.82rem;
  text-decoration:none;color:var(--ink-soft);padding:.5em .7em;border-radius:var(--r);
  text-transform:uppercase;letter-spacing:.06em;transition:color .2s,background .2s;white-space:nowrap}
.nav-links a:hover{color:var(--ink);background:var(--paper-2)}
.nav-links a[aria-current="page"]{color:var(--green);box-shadow:inset 0 -2px 0 var(--coral)}
.nav-cta{background:var(--ink)!important;color:var(--paper)!important}
.nav-cta:hover{background:var(--green)!important}
.burger{display:none;margin-left:auto;background:none;border:1.5px solid var(--ink);
  border-radius:var(--r);padding:.45rem .6rem;cursor:pointer;font:inherit;color:var(--ink)}

@media (max-width:820px){
  .burger{display:block}
  .nav-links{position:fixed;inset:0 0 0 auto;width:min(78vw,320px);background:var(--paper);
    flex-direction:column;align-items:flex-start;gap:.1rem;padding:5rem 1.4rem 2rem;
    border-left:1px solid var(--line);transform:translateX(100%);transition:transform var(--fast);
    box-shadow:-30px 0 60px -30px rgba(0,0,0,.4);overflow-y:auto}
  .nav-links.open{transform:none}
  .nav-links a{width:100%;font-size:1rem;padding:.8em .6em;border-bottom:1px solid var(--line)}
  .nav-cta{margin-top:.6rem;text-align:center}
}

/* ===== BUTTONS ===== */
.btn{display:inline-flex;align-items:center;gap:.6em;font-family:"Archivo",sans-serif;
  font-weight:700;text-transform:uppercase;letter-spacing:.08em;font-size:.8rem;
  text-decoration:none;padding:.92em 1.5em;border-radius:var(--r);border:1.5px solid var(--ink);
  background:var(--ink);color:var(--paper);transition:transform .2s,background .2s,color .2s;cursor:pointer}
.btn:hover{background:var(--green);border-color:var(--green);transform:translateY(-2px)}
.btn.ghost{background:transparent;color:var(--ink)}
.btn.ghost:hover{background:var(--ink);color:var(--paper)}

/* ===== HERO ===== */
.hero{position:relative;background:var(--paper)}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:0;align-items:stretch;min-width:0}
.hero-copy{padding:clamp(2.4rem,6vw,5rem) clamp(1.1rem,5vw,3rem);display:flex;
  flex-direction:column;justify-content:center;gap:1.3rem;min-width:0;position:relative}
.hero-copy::after{content:"";position:absolute;inset:0;z-index:-1;opacity:.5}
.hero h1{font-size:clamp(2.5rem,6.4vw,5rem);letter-spacing:-.03em}
.hero h1 em{font-style:normal;color:var(--green);display:block}
.hero-media{position:relative;min-height:clamp(320px,52vh,640px);overflow:hidden;
  border-left:1px solid var(--ink)}
.hero-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-media figcaption{position:absolute;left:0;bottom:0;background:var(--ink);color:var(--paper);
  font-family:"Archivo",sans-serif;font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;
  padding:.5em .9em}
.hero-cta{display:flex;gap:.8rem;flex-wrap:wrap}
.hero-meta{display:flex;flex-wrap:wrap;gap:1.4rem;margin-top:.4rem;border-top:1px solid var(--line);padding-top:1.1rem}
.hero-meta div{min-width:0}
.hero-meta b{display:block;font-family:"Archivo",sans-serif;font-size:1.5rem;font-weight:800;color:var(--green);overflow-wrap:break-word}
.hero-meta span{font-size:.78rem;color:var(--ink-soft);letter-spacing:.04em}

@media (max-width:820px){
  .hero-grid{grid-template-columns:1fr}
  .hero-media{min-height:300px;border-left:none;border-top:1px solid var(--ink);order:-1}
}

/* ===== PROOF STRIP ===== */
.proof{background:var(--ink);color:var(--paper)}
.proof .wrap{display:flex;flex-wrap:wrap;gap:1rem 2.2rem;align-items:center;justify-content:center;
  padding-block:1.1rem;text-align:center}
.proof span{font-family:"Archivo",sans-serif;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:.55em;min-width:0;overflow-wrap:break-word}
.proof span b{color:var(--green-leaf)}
.proof .dot{color:var(--coral)}

/* ===== GENERIC PANEL HEADER ===== */
.panel-head{counter-increment:panel;display:flex;flex-direction:column;gap:.8rem;margin-bottom:2.2rem;max-width:64ch}
.panel-head h2{font-size:clamp(1.8rem,4vw,2.9rem)}

/* ===== SPLIT (image + text) ===== */
.split{display:grid;grid-template-columns:1fr 1fr;gap:var(--gap);align-items:center}
.split.rev .split-media{order:2}
.split-media{position:relative;border:1px solid var(--ink);box-shadow:var(--shadow);min-width:0}
.split-media img{aspect-ratio:4/3;object-fit:cover;width:100%}
.split-body{min-width:0}
.split-body h3{font-size:clamp(1.4rem,2.6vw,2rem);margin-bottom:.7rem}
@media (max-width:780px){
  .split{grid-template-columns:1fr;gap:1.4rem}
  .split.rev .split-media{order:0}
}

/* ===== CARD GRID ===== */
.grid{display:grid;gap:1.2rem}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-2{grid-template-columns:repeat(2,1fr)}
.cols-4{grid-template-columns:repeat(4,1fr)}
.card{background:var(--white);border:1px solid var(--line);border-radius:var(--r);
  overflow:hidden;box-shadow:var(--shadow);min-width:0;display:flex;flex-direction:column}
.card .ph{aspect-ratio:3/2;overflow:hidden;border-bottom:1px solid var(--line)}
.card .ph img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.card:hover .ph img{transform:scale(1.05)}
.card .body{padding:1.2rem 1.25rem 1.4rem;display:flex;flex-direction:column;gap:.5rem;flex:1}
.card h3{font-size:1.18rem}
.card p{font-size:.92rem;color:var(--ink-soft);margin:0}
.card .price{font-family:"Archivo",sans-serif;font-weight:800;color:var(--green);font-size:1.05rem;margin-top:auto;overflow-wrap:break-word}
@media (max-width:880px){.cols-3,.cols-4{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.cols-2,.cols-3,.cols-4{grid-template-columns:1fr}}

/* ===== FEATURE LIST (matchbook ticks) ===== */
.ticks{list-style:none;margin:0;padding:0;display:grid;gap:.7rem}
.ticks li{position:relative;padding-left:1.7rem;overflow-wrap:break-word}
.ticks li::before{content:"";position:absolute;left:0;top:.55em;width:9px;height:9px;
  background:var(--coral);transform:rotate(45deg)}

/* ===== BANNER (photo with wash) ===== */
.banner{position:relative;color:var(--paper);overflow:hidden;border-block:1px solid var(--ink)}
.banner img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.banner::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(28,27,23,.82),rgba(28,27,23,.45))}
.banner .wrap{position:relative;z-index:2;padding-block:clamp(3rem,7vw,5.5rem);max-width:var(--maxw)}
.banner h2{font-size:clamp(1.8rem,4.4vw,3.2rem);max-width:18ch}
.banner p{max-width:54ch;color:#eee;margin:1rem 0 1.6rem}
.banner .label{color:var(--green-leaf)}
.banner .btn{background:var(--paper);color:var(--ink);border-color:var(--paper)}
.banner .btn:hover{background:var(--green);color:var(--paper);border-color:var(--green)}

/* ===== TESTIMONIALS ===== */
.quotes{display:grid;grid-template-columns:repeat(2,1fr);gap:1.2rem}
.quote{background:var(--paper-2);border:1px solid var(--line);border-left:4px solid var(--coral);
  border-radius:var(--r);padding:1.6rem;min-width:0}
.quote p{font-size:1.05rem;font-style:italic;margin:0 0 .8rem}
.quote cite{font-family:"Archivo",sans-serif;font-style:normal;font-weight:700;font-size:.78rem;
  letter-spacing:.12em;text-transform:uppercase;color:var(--green)}
@media (max-width:680px){.quotes{grid-template-columns:1fr}}

/* ===== GALLERY (masonry-ish) ===== */
.masonry{columns:3;column-gap:.9rem}
.masonry figure{margin:0 0 .9rem;break-inside:avoid;border:1px solid var(--ink);
  box-shadow:var(--shadow);background:var(--white)}
.masonry img{width:100%;display:block}
@media (max-width:880px){.masonry{columns:2}}
@media (max-width:520px){.masonry{columns:1}}

/* ===== PAGE HEADER (subpages) ===== */
.page-head{background:var(--paper-2);border-bottom:1px solid var(--ink)}
.page-head .wrap{padding-block:clamp(2.6rem,6vw,4.4rem)}
.page-head h1{font-size:clamp(2.2rem,5.5vw,4rem)}
.page-head .lead{margin-top:1rem}

/* ===== CONTACT ===== */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--gap)}
.contact-list{list-style:none;margin:0;padding:0;display:grid;gap:1.3rem}
.contact-list li{display:flex;flex-direction:column;gap:.2rem;border-bottom:1px solid var(--line);padding-bottom:1.1rem;min-width:0}
.contact-list .k{font-family:"Archivo",sans-serif;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--green)}
.contact-list .v{font-size:1.05rem;overflow-wrap:break-word}
.contact-list a{color:var(--ink);text-decoration:none;box-shadow:inset 0 -1px 0 var(--green)}
@media (max-width:780px){.contact-grid{grid-template-columns:1fr}}

/* ===== FOOTER ===== */
.site-foot{background:var(--ink);color:var(--paper);margin-top:0}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2rem;padding-block:clamp(2.6rem,5vw,3.6rem)}
.foot-top h4{font-family:"Archivo",sans-serif;font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--green-leaf);margin-bottom:1rem}
.foot-top .brand svg, .foot-top .brand img{height:40px}
.foot-top p{color:#cbc6ba;font-size:.92rem;max-width:36ch}
.foot-links{list-style:none;margin:0;padding:0;display:grid;gap:.55rem}
.foot-links a{color:#cbc6ba;text-decoration:none;font-size:.92rem}
.foot-links a:hover{color:var(--paper)}
.foot-bar{border-top:1px solid rgba(255,255,255,.14);padding-block:1.2rem;display:flex;
  flex-wrap:wrap;gap:.6rem 1.4rem;justify-content:space-between;align-items:center}
.foot-bar p{margin:0;font-size:.78rem;color:#9c988d;letter-spacing:.04em}
@media (max-width:720px){.foot-top{grid-template-columns:1fr;gap:1.6rem}}

/* logo recolour for dark footer (invert near-black ink glyphs to paper) */
.on-dark .brand svg .st3,.on-dark .brand svg .st1{fill:#f4f1e9!important}

/* ===== reveal animation ===== */
.reveal{opacity:0;transform:translateY(22px)}
.reveal.in{opacity:1;transform:none;transition:opacity .7s ease,transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}
@media (prefers-reduced-motion:reduce){
  .reveal,.reveal.in{opacity:1!important;transform:none!important;transition:none!important}
  .card .ph img,.nav-links{transition:none!important}
  *{scroll-behavior:auto!important}
}
