/* ============================================================
   MaisonPlus — design tokens & global styles
   Brand red #ED1C24 · Geologica · clean premium furniture retail
   ============================================================ */
@font-face{font-family:'Geologica';src:url('fonts/Geologica-Regular.ttf') format('truetype');font-weight:400;font-display:swap}
@font-face{font-family:'Geologica';src:url('fonts/Geologica-Medium.ttf') format('truetype');font-weight:500;font-display:swap}
@font-face{font-family:'Geologica';src:url('fonts/Geologica-SemiBold.ttf') format('truetype');font-weight:600;font-display:swap}
@font-face{font-family:'Geologica';src:url('fonts/Geologica-Bold.ttf') format('truetype');font-weight:700;font-display:swap}
@font-face{font-family:'Geologica';src:url('fonts/Geologica-Black.ttf') format('truetype');font-weight:900;font-display:swap}

:root{
  /* brand */
  --red:#ED1C24;
  --red-dark:#C41019;
  --red-darker:#9e0d14;
  --red-tint:#FFF1F1;
  --red-tint-2:#FFE3E3;

  /* ink + neutrals */
  --ink:#1a1714;
  --ink-2:#403a34;
  --muted:#736c64;
  --muted-2:#a39a8f;
  --line:#e9e3da;
  --line-2:#f1ece4;
  --bg:#ffffff;
  --bg-2:#f7f3ee;
  --bg-3:#efe8df;
  --cream:#f7f2ea;       /* warm soft surface */
  --cream-2:#f0e8dc;
  --ink-warm:#231d17;    /* warm near-black for dark sections */
  --gold:#C99A3F;       /* star rating / accent */
  --green:#1F9D55;      /* in-stock / success */
  --green-tint:#E8F7EE;

  /* type */
  --sans:'Geologica',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --display:'Bricolage Grotesque','Geologica',system-ui,sans-serif;
  --fw-r:400;--fw-m:500;--fw-sb:600;--fw-b:700;--fw-bl:900;

  /* radius */
  --r-sm:8px;--r-md:12px;--r-lg:18px;--r-xl:26px;--r-full:999px;

  /* shadow */
  --sh-1:0 1px 2px rgba(20,20,25,.05);
  --sh-2:0 6px 22px rgba(20,20,25,.08);
  --sh-3:0 18px 50px rgba(20,20,25,.14);

  /* layout */
  --maxw:1480px;
  --ease:cubic-bezier(.2,.8,.2,1);
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;font-family:var(--sans);color:var(--ink);background:var(--bg);
  font-weight:400;line-height:1.5;font-size:15px;overflow-x:clip;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,select,textarea{font-family:inherit;font-size:15px}
ul{margin:0;padding:0;list-style:none}
h1,h2,h3,h4,h5{margin:0;line-height:1.1;font-weight:900;letter-spacing:-.01em}
/* editorial display identity: elegant serif for big headings, Geologica for UI */
h1.display,h2.display,.hero-content h1,.sec-head h2,.about-hero h1{
  font-family:var(--display);font-weight:700;letter-spacing:-.02em;line-height:1.02;
}
.serif{font-family:var(--display);font-weight:700;letter-spacing:-.02em}
p{margin:0}
:focus-visible{outline:2px solid var(--red);outline-offset:2px}
::selection{background:var(--red);color:#fff}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 40px}

/* scrollbars (carousels) */
.noscroll::-webkit-scrollbar{display:none}
.noscroll{scrollbar-width:none}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-weight:600;font-size:14px;line-height:1;border-radius:var(--r-full);
  padding:14px 26px;transition:.16s var(--ease);white-space:nowrap;border:1.5px solid transparent}
.btn:active{transform:scale(.98)}
.btn-red{background:var(--red);color:#fff}
.btn-red:hover{background:var(--red-dark)}
.btn-ink{background:var(--ink);color:#fff}
.btn-ink:hover{background:#000}
.btn-out{border-color:var(--line);background:#fff;color:var(--ink)}
.btn-out:hover{border-color:var(--ink);background:var(--ink);color:#fff}
.btn-ghost{background:var(--bg-2);color:var(--ink)}
.btn-ghost:hover{background:var(--bg-3)}
.btn-sm{padding:10px 18px;font-size:13px}
.btn-lg{padding:17px 34px;font-size:15px}
.btn-block{width:100%}
.btn:disabled{opacity:.45;cursor:not-allowed}

/* pills / badges */
.badge{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:700;
  letter-spacing:.04em;text-transform:uppercase;padding:5px 10px;border-radius:var(--r-sm);line-height:1}
.badge-red{background:var(--red);color:#fff}
.badge-ink{background:var(--ink);color:#fff}
.badge-sale{background:var(--red);color:#fff}
.badge-new{background:var(--ink);color:#fff}
.badge-out{background:#fff;color:var(--ink);border:1.5px solid var(--line)}

.eyebrow{font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--red)}

/* form fields */
.field{display:block}
.field>label{display:block;font-size:12.5px;font-weight:600;color:var(--ink-2);margin-bottom:7px}
.inp{width:100%;border:1.5px solid var(--line);border-radius:var(--r-md);padding:13px 15px;
  background:#fff;color:var(--ink);transition:.16s var(--ease)}
.inp::placeholder{color:var(--muted-2)}
.inp:focus{outline:none;border-color:var(--red);box-shadow:0 0 0 4px var(--red-tint)}
.inp.err{border-color:var(--red)}
select.inp{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%236b6b6f' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:40px}

/* card */
.card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg)}

/* utility */
.muted{color:var(--muted)}
.strike{text-decoration:line-through;color:var(--muted-2);font-weight:500}
.divider{height:1px;background:var(--line);border:0;margin:0}

/* generic enter animation, gated for reduced motion handled inline */
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

/* simple section heading */
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:26px}
.sec-head h2{font-size:33px}
.sec-head .eyebrow+h2{margin-top:6px}
.sec-link{font-weight:600;font-size:14px;color:var(--ink);display:inline-flex;gap:6px;align-items:center;border-bottom:2px solid transparent;padding-bottom:2px}
.sec-link:hover{border-color:var(--red);color:var(--red)}

@media(max-width:768px){
  .wrap{padding:0 20px}
  .sec-head h2{font-size:26px}
  body{font-size:14.5px}
}
