/* ===== La Perruche Rouge — global styles ===== */
:root{
  --cream:#FBF4E6; --sand:#F4E8D3; --ink:#2A1A10; --ink-soft:#6E5847;
  --red:#C5362A; --red-deep:#9C2417; --coral:#E07A3E; --gold:#E0A23A;
  --teal:#147F78; --teal-light:#2BA89F; --green:#16301E; --wood:#34210F;
  --line:rgba(42,26,16,.13);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:84px}
body{margin:0;background:var(--cream);color:var(--ink);font-family:'Manrope',system-ui,sans-serif;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img{max-width:100%}
[hidden]{display:none!important}
::selection{background:var(--red);color:#fff}

/* ===== keyframes (from mockup, verbatim) ===== */
@keyframes kb{0%{transform:scale(1.05) translateY(0)}100%{transform:scale(1.18) translateY(-2%)}}
@keyframes petalfall{0%{transform:translateY(-12vh) translateX(0) rotate(0deg);opacity:0}8%{opacity:.75}50%{transform:translateY(50vh) translateX(40px) rotate(180deg)}100%{transform:translateY(112vh) translateX(-30px) rotate(360deg);opacity:0}}
@keyframes wavemove{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
@keyframes bob{0%,100%{transform:translateY(0);opacity:.9}50%{transform:translateY(9px);opacity:.4}}
@keyframes spinslow{from{transform:rotate(0)}to{transform:rotate(360deg)}}

/* ===== reveal on scroll (gated by .js so no-JS keeps content visible) ===== */
.js [data-reveal]{opacity:0;transform:translateY(30px);transition:opacity .9s cubic-bezier(.16,.7,.3,1),transform .9s cubic-bezier(.16,.7,.3,1);will-change:opacity,transform}
.js [data-reveal].revealed{opacity:1;transform:none}

/* ===== hover/interaction states (ported from mockup JS handlers) ===== */
.btn-red{will-change:transform}
.btn-red:hover{transform:translateY(-2px);box-shadow:0 20px 44px -12px rgba(197,54,42,.95)!important}
.btn-red:active{transform:translateY(0)}
.btn-ghost:hover{background:rgba(255,255,255,.18)!important;border-color:#fff!important}
.zoom-card:hover [data-zoom],.gal-fig:hover [data-zoom]{transform:scale(1.07)!important}
.gal-fig:hover [data-cap],.gal-fig:focus-within [data-cap]{opacity:1!important}
.nav-link:hover{opacity:1!important;color:var(--nav-fg)}

/* ===== language switch ===== */
.lang-btn{border:none;cursor:pointer;font-family:inherit;font-weight:700;font-size:.74rem;letter-spacing:.06em;padding:6px 12px;border-radius:999px;transition:background .3s,color .3s,opacity .3s;background:transparent;color:var(--nav-fg);opacity:.8}
.lang-btn:hover{opacity:1}
.lang-btn.is-active{background:var(--red);color:#fff;opacity:1}

/* ===== mobile nav toggle ===== */
.nav-toggle{display:none;flex-direction:column;gap:5px;align-items:center;justify-content:center;width:44px;height:44px;background:transparent;border:none;cursor:pointer;padding:8px;flex:none}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--nav-fg);border-radius:2px;transition:transform .3s ease,opacity .2s ease}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ===== skip link (a11y) ===== */
.skip-link{position:absolute;left:-9999px;top:0;z-index:100;background:var(--red);color:#fff;padding:10px 16px;border-radius:0 0 6px 0;font-weight:700;font-size:.85rem;text-decoration:none}
.skip-link:focus{left:0}

/* ===== focus visibility (a11y) ===== */
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--coral);outline-offset:3px;border-radius:4px}
#contactForm input:focus,#contactForm textarea:focus,#contactForm select:focus{border-color:var(--coral)!important;outline-offset:1px}

/* ===== honeypot (hidden from humans) ===== */
.hp-field{position:absolute!important;left:-9999px!important;width:1px;height:1px;opacity:0;pointer-events:none}

/* form status colors */
#formStatus.is-error{color:#FFC3B8}
#formStatus.is-ok{color:#9FE6CF}
#contactForm[aria-busy="true"] #submitBtn{opacity:.7;cursor:progress}
#contactForm input.invalid,#contactForm textarea.invalid{border-color:#E0796E!important}

/* ===== responsive: tablet & mobile nav ===== */
@media (max-width:880px){
  .nav-toggle{display:flex}
  .nav-menu{position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;gap:14px;background:var(--cream);padding:22px clamp(18px,4vw,46px) 28px;box-shadow:0 22px 44px -22px rgba(42,26,16,.45);transform:translateY(-14px);opacity:0;visibility:hidden;transition:opacity .3s ease,transform .3s ease,visibility .3s}
  .nav-menu.open{opacity:1;visibility:visible;transform:none}
  .nav-menu .nav-link{color:var(--ink)!important;opacity:1;font-size:1.02rem;padding:8px 0;border-bottom:1px solid var(--line)}
  .langbox{border-color:var(--line)!important;align-self:flex-start}
  .nav-menu .lang-btn{color:var(--ink)}
  .nav-menu .lang-btn.is-active{color:#fff}
  .nav-cta{align-self:flex-start;text-align:center}
}

/* slightly tighter hero CTA stacking on very small screens */
@media (max-width:420px){
  #hero .btn-red,#hero .btn-ghost{width:100%;justify-content:center}
}

/* Reduced-motion: per the client's explicit choice, this site plays the full animation set for
   everyone — exactly like the Claude Design mockup — and does NOT suppress motion under
   prefers-reduced-motion. Content is still never left invisible (JS reveals everything, with a
   safety timeout). To restore an accessible calmer mode, re-add a prefers-reduced-motion block. */
