/* ============================================================
   REVENDA CALLANDRA — SISTEMA VISUAL
   Editorial premium de enxoval + painéis B2B densos.
   Display: Bricolage Grotesque · UI: Hanken Grotesk
   ============================================================ */
:root{
  /* tinta & papéis */
  --ink:#221C18; --ink-2:#473D34; --ink-3:#74675A;
  --cream:#F7F1E7; --cream-2:#F1E7D7; --paper:#FFFFFF;
  /* marca — teal oficial Callandra */
  --clay:#0E8FAD; --clay-deep:#0A6F88; --clay-12:#DDF0F5; --clay-24:#B3DEE8;
  --teal:#0E8FAD; --teal-deep:#0A6F88; --teal-ink:#0B5567;
  --sage:#5C8C84; --sage-12:#E0ECEA;
  --gold:#BC8C38; --gold-12:#F1E3C7;
  /* linhas */
  --line:#E7DCCB; --line-2:#EFE7D8; --line-ink:#332B24;
  /* status */
  --ok:#4C7A52; --ok-12:#DCEBDD; --warn:#A9762A; --warn-12:#F3E6CE;
  --danger:#B23A3A; --danger-12:#F2D9D6; --info:#3C6E8C; --info-12:#D9E6EE;
  /* sombra & raio */
  --sh-sm:0 1px 2px rgba(34,28,24,.06), 0 1px 3px rgba(34,28,24,.05);
  --sh-md:0 4px 14px rgba(34,28,24,.08), 0 1px 3px rgba(34,28,24,.05);
  --sh-lg:0 18px 50px rgba(34,28,24,.18), 0 4px 14px rgba(34,28,24,.10);
  --r-sm:8px; --r-md:13px; --r-lg:20px; --r-xl:28px;
  --ff-disp:"Bricolage Grotesque", serif;
  --ff-ui:"Hanken Grotesk", system-ui, sans-serif;
  --ff-brand:"Cormorant Garamond", "Playfair Display", Georgia, serif;
  --maxw:1240px;
  /* assinatura editorial — reaproveitada em todos os painéis escuros */
  --clay-bright:#46BEDB;
  --panel-dark:
    radial-gradient(940px 480px at 88% -12%, rgba(14,143,173,.30), transparent 58%),
    radial-gradient(640px 440px at 0% 118%, rgba(188,140,56,.16), transparent 55%),
    linear-gradient(158deg, #1a1511 0%, #241d18 52%, #2d241c 100%);
  --grain:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
/* utilidades compartilhadas de painel escuro editorial.
   O painel precisa de position:relative + isolation:isolate; os pseudos ficam em z-index:-1. */
.dark-grain::after{content:""; position:absolute; inset:0; z-index:-1; pointer-events:none;
  opacity:.05; mix-blend-mode:overlay; background-image:var(--grain)}
.dark-glyph::before{position:absolute; z-index:-1; font-family:var(--ff-disp); font-weight:800;
  letter-spacing:-.05em; color:transparent; -webkit-text-stroke:1.5px rgba(247,241,231,.06);
  pointer-events:none; user-select:none; line-height:1}
@keyframes rcUp{from{opacity:0; transform:translateY(24px)} to{opacity:1; transform:none}}
@keyframes rcFade{to{opacity:1}}
@media (prefers-reduced-motion:reduce){
  .hero-copy>*,.hero-tile,.hero-badge,.cadastro-art>*,.page-head h1{animation:none !important; opacity:1 !important}
}
*{box-sizing:border-box}
html,body{margin:0}
body{
  font-family:var(--ff-ui); background:var(--cream); color:var(--ink);
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  font-size:15px; line-height:1.5;
}
#root{min-height:100vh}
h1,h2,h3,h4{font-family:var(--ff-disp); font-weight:800; letter-spacing:-.02em; margin:0; line-height:1.04;}
a{color:inherit; text-decoration:none}
button{font-family:inherit; cursor:pointer}
::selection{background:var(--clay-24)}
.tnum{font-variant-numeric:tabular-nums lining-nums}

/* layout helpers */
.wrap{max-width:var(--maxw); margin:0 auto; padding:0 28px}
.wrap-wide{max-width:1440px; margin:0 auto; padding:0 28px}
.row{display:flex; align-items:center; gap:12px}
.row-between{display:flex; align-items:center; justify-content:space-between; gap:12px}
.col{display:flex; flex-direction:column}
.grow{flex:1}
.muted{color:var(--ink-3)}
.wrap-text{text-wrap:pretty}
.divider{height:1px; background:var(--line); border:0; margin:0}

/* kicker / titles */
.kicker{font-family:var(--ff-ui); font-weight:700; font-size:12px; letter-spacing:.14em;
  text-transform:uppercase; color:var(--clay); margin-bottom:8px}
.sect-head{display:flex; align-items:flex-end; justify-content:space-between; gap:20px; margin-bottom:20px}
.sect-title{font-size:clamp(26px,3vw,34px); letter-spacing:-.025em}
.sect-actions{display:flex; gap:10px; align-items:center}

/* ---------------- BOTÕES ---------------- */
.btn{display:inline-flex; align-items:center; justify-content:center; gap:9px;
  border:1px solid transparent; border-radius:999px; padding:11px 20px;
  font-weight:700; font-size:14.5px; letter-spacing:-.01em; line-height:1;
  transition:transform .12s ease, background .15s, box-shadow .15s, border-color .15s;
  white-space:nowrap}
.btn:active{transform:translateY(1px)}
.btn-sm{padding:8px 14px; font-size:13px; gap:7px}
.btn-lg{padding:15px 28px; font-size:16px}
.btn-full{width:100%}
.btn-primary{background:var(--clay); color:#fff; box-shadow:var(--sh-sm)}
.btn-primary:hover{background:var(--clay-deep); box-shadow:var(--sh-md)}
.btn-ink{background:var(--ink); color:var(--cream)}
.btn-ink:hover{background:#000}
.btn-ghost{background:transparent; color:var(--ink); border-color:var(--line)}
.btn-ghost:hover{background:var(--paper); border-color:var(--ink-3)}
.btn-soft{background:var(--clay-12); color:var(--clay-deep)}
.btn-soft:hover{background:var(--clay-24)}
.btn-quiet{background:transparent; color:var(--ink-2); padding-left:10px; padding-right:10px}
.btn-quiet:hover{color:var(--clay); background:var(--clay-12)}
.btn:disabled{opacity:.45; cursor:not-allowed; transform:none}
.icon-btn{display:inline-flex; align-items:center; justify-content:center; width:36px; height:36px;
  border-radius:10px; border:1px solid transparent; background:transparent; color:var(--ink-2)}
.icon-btn:hover{background:var(--cream-2); color:var(--ink)}

/* ---------------- BADGES ---------------- */
.badge{display:inline-flex; align-items:center; gap:6px; padding:4px 10px; border-radius:999px;
  font-size:12px; font-weight:700; letter-spacing:.01em; line-height:1.3; white-space:nowrap}
.badge-dot{width:6px; height:6px; border-radius:50%; background:currentColor}
.badge-neutral{background:var(--cream-2); color:var(--ink-2)}
.badge-ok{background:var(--ok-12); color:var(--ok)}
.badge-warn{background:var(--warn-12); color:var(--warn)}
.badge-danger{background:var(--danger-12); color:var(--danger)}
.badge-info{background:var(--info-12); color:var(--info)}
.badge-gold{background:var(--gold-12); color:var(--gold)}

/* ---------------- CARD ---------------- */
.card{background:var(--paper); border:1px solid var(--line); border-radius:var(--r-md);
  box-shadow:var(--sh-sm)}
.card-pad{padding:22px}
.card-hover{transition:box-shadow .18s, transform .18s, border-color .18s}
.card-hover:hover{box-shadow:var(--sh-md); border-color:var(--clay-24); transform:translateY(-2px)}

/* ---------------- CAMPOS ---------------- */
.field{display:flex; flex-direction:column; gap:7px; width:100%}
.field-label{font-size:13px; font-weight:700; color:var(--ink-2)}
.req{color:var(--clay); margin-left:3px; font-style:normal}
.field-hint{font-size:12.5px; color:var(--ink-3)}
.field-error{font-size:12.5px; color:var(--danger); font-weight:600}
.input{width:100%; background:var(--paper); border:1.5px solid var(--line);
  border-radius:10px; padding:11px 13px; font-size:14.5px; font-family:inherit; color:var(--ink);
  transition:border-color .15s, box-shadow .15s}
.input::placeholder{color:#B7AC9C}
.input:focus{outline:none; border-color:var(--clay); box-shadow:0 0 0 3px var(--clay-12)}
.select-wrap{position:relative}
.select{appearance:none; padding-right:38px; cursor:pointer}
.select-caret{position:absolute; right:13px; top:50%; transform:translateY(-50%); color:var(--ink-3); pointer-events:none}

/* ---------------- MODAL ---------------- */
.modal-scrim{position:fixed; inset:0; background:rgba(34,28,24,.42); backdrop-filter:blur(3px);
  display:flex; align-items:center; justify-content:center; padding:24px; z-index:200; animation:fade .15s ease}
.modal{background:var(--paper); border-radius:var(--r-lg); box-shadow:var(--sh-lg); width:100%;
  max-height:88vh; display:flex; flex-direction:column; animation:pop .18s cubic-bezier(.2,.9,.3,1)}
.modal-head{display:flex; align-items:center; justify-content:space-between; padding:20px 22px 14px}
.modal-head h3{font-size:21px}
.modal-body{padding:0 22px 8px; overflow:auto}
.modal-foot{padding:16px 22px 20px; display:flex; gap:10px; justify-content:flex-end; border-top:1px solid var(--line-2); margin-top:14px}
@keyframes fade{from{opacity:0}to{opacity:1}}
@keyframes pop{from{opacity:0; transform:translateY(12px) scale(.98)}to{opacity:1; transform:none}}

/* ---------------- TOAST ---------------- */
.toast-host{position:fixed; bottom:24px; right:24px; display:flex; flex-direction:column; gap:10px; z-index:300}
.toast{display:flex; align-items:center; gap:10px; background:var(--ink); color:var(--cream);
  padding:13px 18px; border-radius:12px; box-shadow:var(--sh-lg); font-weight:600; font-size:14px;
  animation:slideIn .25s cubic-bezier(.2,.9,.3,1); max-width:360px}
.toast-ok{border-left:3px solid #6FB87A}
.toast-danger{border-left:3px solid #E08A86}
.toast svg{flex-shrink:0}
@keyframes slideIn{from{opacity:0; transform:translateX(20px)}to{opacity:1; transform:none}}

/* ---------------- PLACEHOLDER PRODUTO ---------------- */
.prod-img{position:relative; width:100%; overflow:hidden; background:var(--cream-2); border-radius:var(--r-sm)}
.prod-img-svg{position:absolute; inset:0; width:100%; height:100%; display:block}
.prod-img-photo{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block}
.prod-img-fold{position:absolute; inset:0;
  background:radial-gradient(120% 90% at 80% 0%, rgba(255,255,255,.22), transparent 55%),
             linear-gradient(180deg, transparent 55%, rgba(34,28,24,.16));
  mix-blend-mode:multiply}
.prod-img-cat{position:absolute; top:10px; left:10px; background:rgba(255,255,255,.86); color:var(--ink);
  font-size:11px; font-weight:800; letter-spacing:.04em; text-transform:uppercase; padding:4px 9px; border-radius:999px;
  backdrop-filter:blur(4px)}
.prod-img-ph{position:absolute; bottom:9px; right:10px; color:rgba(255,255,255,.78); font-size:10px;
  font-weight:600; letter-spacing:.05em; text-transform:uppercase}

/* ---------------- STAT ---------------- */
.stat{background:var(--paper); border:1px solid var(--line); border-radius:var(--r-md); padding:18px 20px}
.stat-value{font-family:var(--ff-disp); font-weight:800; font-size:30px; letter-spacing:-.025em; line-height:1; color:var(--ink)}
.stat-label{font-size:13px; color:var(--ink-3); margin-top:8px; font-weight:600}
.stat-sub{font-size:12px; margin-top:6px; font-weight:600}
.stat-ok .stat-value{color:var(--ok)} .stat-gold .stat-value{color:var(--gold)}
.stat-clay .stat-value{color:var(--clay)} .stat-danger .stat-value{color:var(--danger)}

/* ---------------- AVATAR ---------------- */
.avatar{display:inline-flex; align-items:center; justify-content:center; border-radius:50%;
  background:var(--ink); color:var(--cream); font-family:var(--ff-disp); font-weight:800; flex-shrink:0}

/* ---------------- EMPTY ---------------- */
.empty{display:flex; flex-direction:column; align-items:center; text-align:center; gap:6px; padding:48px 24px}
.empty-ico{width:56px; height:56px; border-radius:16px; background:var(--cream-2); color:var(--ink-3);
  display:flex; align-items:center; justify-content:center; margin-bottom:6px}
.empty-title{font-weight:800; font-family:var(--ff-disp); font-size:18px}
.empty-sub{color:var(--ink-3); font-size:14px; max-width:340px}

/* ---------------- TABELA ---------------- */
.tbl{width:100%; border-collapse:collapse; font-size:14px}
.tbl th{text-align:left; font-size:11.5px; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-3);
  font-weight:800; padding:0 14px 10px; border-bottom:1px solid var(--line)}
.tbl td{padding:13px 14px; border-bottom:1px solid var(--line-2); vertical-align:middle}
.tbl tr:last-child td{border-bottom:0}
.tbl tbody tr{transition:background .12s}
.tbl tbody tr:hover{background:var(--cream)}
.tbl .num{text-align:right; font-variant-numeric:tabular-nums}

/* utilidades de espaçamento */
.mt-0{margin-top:0}.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}.mt-4{margin-top:32px}
.mb-2{margin-bottom:16px}.mb-3{margin-bottom:24px}
.gap-1{gap:8px}.gap-2{gap:16px}.gap-3{gap:24px}
.grid{display:grid}
@media (max-width:880px){
  .wrap,.wrap-wide{padding:0 18px}
  .sect-title{font-size:23px}
}
