/* Clube Mamãe · Área do Cliente */
:root {
  --rose-50:#FDF1F4; --rose-100:#FADDE4; --rose-200:#F5B7C7; --rose-300:#F088A3;
  --rose-400:#EC6A8B; --rose-500:#E9547A; --rose-600:#D13E66; --rose-900:#4A1322;
  --cream:#FBF7F4; --paper:#F5EFE9; --stone-100:#EEE7E0; --stone-200:#DCD2C9;
  --stone-300:#B8ADA3; --stone-500:#7C736B; --ink:#221C18;
  --terracota:#D9A681; --peach:#F3E2D4; --gold:#D4A45C;
  --success:#4A7C59; --warning:#D89B3F; --error:#C6415A;
  --serif:"Playfair Display", Georgia, serif;
  --sans:"Inter", -apple-system, BlinkMacSystemFont, sans-serif;
  --mono:"JetBrains Mono", ui-monospace, monospace;
  --radius-sm:8px; --radius:14px; --radius-lg:22px; --radius-xl:32px; --pill:999px;
  --shadow-sm:0 1px 2px rgba(34,28,24,.04),0 2px 6px rgba(34,28,24,.04);
  --shadow:0 2px 6px rgba(34,28,24,.05),0 10px 30px rgba(34,28,24,.06);
  --sidebar-w:256px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:var(--sans);color:var(--ink);background:var(--cream);font-size:15px;line-height:1.55;-webkit-font-smoothing:antialiased}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
input,textarea{font-family:inherit}

.eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--stone-500)}
.eyebrow .dot{display:inline-block;width:5px;height:5px;border-radius:50%;background:var(--rose-500);margin:0 8px 1px 0;vertical-align:middle}
.eyebrow.rose{color:var(--rose-500)}

.btn{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:14px;padding:11px 20px;border-radius:var(--pill);border:1px solid transparent;cursor:pointer;transition:background .15s,border-color .15s,transform .1s;white-space:nowrap}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--rose-500);color:#fff;box-shadow:0 4px 14px -4px rgba(233,84,122,.45)}
.btn-primary:hover{background:var(--rose-600)}
.btn-ghost{color:var(--ink);border-color:rgba(34,28,24,.15);background:transparent}
.btn-ghost:hover{border-color:var(--ink);background:#fff}
.btn-ink{background:var(--ink);color:var(--cream)}
.btn-ink:hover{background:#000}
.btn-block{width:100%;justify-content:center}
.btn-lg{padding:14px 24px;font-size:15px}
.btn .arr{transition:transform .2s}
.btn:hover .arr{transform:translateX(3px)}

/* FIELD */
.field{margin-bottom:16px}
.field label{display:block;font-size:13px;font-weight:600;margin-bottom:6px;color:var(--stone-500)}
.field input{width:100%;padding:13px 16px;border-radius:10px;border:1px solid var(--stone-200);background:#fff;font-size:15px;outline:none;transition:border-color .15s,box-shadow .15s}
.field input:focus{border-color:var(--rose-500);box-shadow:0 0 0 4px var(--rose-50)}
.field .err{font-size:12.5px;color:var(--error);margin-top:5px;display:none}
.field.has-err input{border-color:var(--error)}
.field.has-err .err{display:block}

/* AUTH */
.auth{min-height:100vh;display:grid;grid-template-columns:1fr 1fr}
.auth-form{display:flex;flex-direction:column;padding:clamp(24px,3vw,48px) clamp(24px,5vw,72px);background:var(--cream)}
.auth-form .top{display:flex;justify-content:space-between;align-items:center;margin-bottom:auto}
.auth-form .brand{display:flex;align-items:center;gap:10px}
.auth-form .brand span{font-family:var(--serif);font-size:18px;font-weight:500}
.auth-form .back{font-size:13px;color:var(--stone-500)}
.auth-form .back:hover{color:var(--ink)}
.auth-form .center{flex:1;display:flex;align-items:center;padding:48px 0;max-width:440px;width:100%;margin:0 auto}
.auth-form .center .inner{width:100%}
.auth-form h1{font-family:var(--serif);font-weight:500;font-size:clamp(32px,3.5vw,44px);line-height:1.1;letter-spacing:-.015em;margin:10px 0 10px}
.auth-form h1 em{font-style:italic;color:var(--rose-500);font-weight:400}
.auth-form p.sub{font-size:15px;color:var(--stone-500);margin:0 0 28px;max-width:38ch}
.auth-foot{font-size:13px;color:var(--stone-500);display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;padding-top:24px}

.auth-visual{position:relative;overflow:hidden;background:linear-gradient(155deg,var(--peach) 0%,var(--terracota) 45%,var(--rose-400) 100%);padding:clamp(24px,3vw,48px);display:flex;flex-direction:column;justify-content:space-between}
.auth-visual::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 20%,rgba(255,255,255,.28),transparent 55%);pointer-events:none}
.auth-visual blockquote{font-family:var(--serif);font-style:italic;font-size:clamp(26px,2.5vw,38px);line-height:1.2;margin:0 0 20px;text-wrap:balance}
.auth-visual blockquote::before{content:"\201C";font-size:60px;line-height:0;vertical-align:-20px;color:rgba(34,28,24,.3);margin-right:3px}
.auth-visual .chip{align-self:flex-start;background:rgba(255,255,255,.65);backdrop-filter:blur(10px);font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;padding:7px 14px;border-radius:999px}
.auth-visual .foot{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:rgba(34,28,24,.5)}

.success-card{background:#fff;border:1px solid var(--stone-100);border-radius:var(--radius-lg);padding:32px 24px;text-align:center;display:none}
.success-card.show{display:block}
.success-card .ico{width:52px;height:52px;border-radius:50%;background:var(--rose-50);margin:0 auto 16px;display:grid;place-items:center;font-size:26px}
.success-card h3{font-family:var(--serif);font-size:21px;font-weight:500;margin:0 0 8px}
.success-card p{font-size:14px;color:var(--stone-500);margin:0 0 16px}
.success-card .em{font-weight:600;color:var(--ink)}

/* APP SHELL */
.app{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh}
.sidebar{background:#fff;border-right:1px solid var(--stone-100);padding:20px 14px;position:sticky;top:0;height:100vh;display:flex;flex-direction:column;overflow-y:auto}
.sidebar .brand{display:flex;align-items:center;gap:9px;padding:4px 6px 20px;color:var(--ink)}
.sidebar .brand span{font-family:var(--serif);font-size:17px;font-weight:500}
.side-sect{margin-bottom:20px}
.side-sect h6{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--stone-300);margin:0 10px 8px;font-weight:500}
.side-link{display:flex;align-items:center;gap:11px;padding:9px 11px;border-radius:10px;font-size:13.5px;font-weight:500;color:var(--stone-500);transition:background .12s,color .12s}
.side-link:hover{background:var(--cream);color:var(--ink)}
.side-link.active{background:var(--ink);color:var(--cream)}
.side-link .ico{font-size:15px;width:20px;flex-shrink:0}
.side-link .count{margin-left:auto;font-size:10.5px;font-weight:700;background:var(--rose-500);color:#fff;border-radius:999px;padding:2px 7px}
.side-user{margin-top:auto;display:flex;align-items:center;gap:10px;padding:10px 11px;border-radius:12px;background:var(--cream);cursor:pointer}
.side-user .av{width:32px;height:32px;border-radius:50%;background:linear-gradient(145deg,var(--peach),var(--terracota));flex-shrink:0;font-family:var(--serif);display:grid;place-items:center;font-size:14px;color:var(--rose-900);font-weight:600}
.side-user .info{min-width:0;flex:1}
.side-user .info strong{font-size:13px;font-weight:600;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.side-user .info span{font-size:11.5px;color:var(--stone-500)}

.main{padding:clamp(20px,3vw,40px) clamp(20px,4vw,48px);min-width:0}
.topbar{display:flex;align-items:center;gap:16px;margin-bottom:28px;flex-wrap:wrap}
.topbar h1{font-family:var(--serif);font-weight:500;font-size:clamp(26px,3vw,40px);line-height:1.1;letter-spacing:-.015em;margin:0;flex:1}
.topbar h1 em{font-style:italic;color:var(--rose-500);font-weight:400}

.welcome{background:linear-gradient(135deg,var(--ink) 0%,#3a2d25 100%);color:var(--cream);border-radius:var(--radius-xl);padding:clamp(24px,3vw,40px);position:relative;overflow:hidden;margin-bottom:32px}
.welcome::before{content:"";position:absolute;right:-100px;top:-100px;width:380px;height:380px;border-radius:50%;background:radial-gradient(circle,var(--rose-500),transparent 65%);opacity:.35}
.welcome::after{content:"";position:absolute;left:-120px;bottom:-160px;width:360px;height:360px;border-radius:50%;background:radial-gradient(circle,var(--terracota),transparent 60%);opacity:.25}
.welcome .inner{position:relative;z-index:1}
.welcome h2{font-family:var(--serif);font-weight:500;font-size:clamp(24px,3vw,38px);line-height:1.15;letter-spacing:-.015em;margin:10px 0 12px;color:var(--cream)}
.welcome h2 em{font-style:italic;color:var(--rose-300);font-weight:400}
.welcome p{font-size:15px;color:rgba(255,255,255,.7);margin:0 0 22px;max-width:46ch}

.sec{margin-bottom:36px}
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:12px;margin-bottom:16px;flex-wrap:wrap}
.sec-head h3{font-family:var(--serif);font-weight:500;font-size:24px;line-height:1.1;letter-spacing:-.01em;margin:6px 0 0}
.sec-head h3 em{font-style:italic;color:var(--rose-500);font-weight:400}
.sec-head a{font-size:13px;color:var(--stone-500);font-weight:500}
.sec-head a:hover{color:var(--rose-500)}

/* PRODUCT CARDS */
.prod-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}
.prod-card{background:#fff;border:1px solid var(--stone-100);border-radius:var(--radius-lg);overflow:hidden;transition:transform .18s,box-shadow .18s,border-color .18s;display:flex;flex-direction:column}
.prod-card:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:var(--stone-200)}
.prod-cover{aspect-ratio:3/4;display:flex;align-items:flex-end;padding:16px;position:relative}
.prod-cover .brand-mark{position:absolute;top:14px;left:14px;font-family:var(--mono);font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.6)}
.prod-cover h4{font-family:var(--serif);font-weight:500;font-size:20px;line-height:1.1;color:var(--cream);text-wrap:balance;letter-spacing:-.01em;position:relative;z-index:1}
.cover-gold{background:linear-gradient(155deg,var(--gold),#9a7230)}
.cover-rose{background:linear-gradient(155deg,var(--rose-400),var(--rose-600))}
.prod-body{padding:14px 16px 16px;flex:1;display:flex;flex-direction:column;gap:4px}
.prod-body .kind{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--stone-500)}
.prod-body h3{font-family:var(--serif);font-weight:500;font-size:16px;line-height:1.2;margin:0}
.prod-body .meta{font-size:12px;color:var(--stone-500);margin-top:auto;padding-top:8px}
.prod-actions{display:flex;gap:8px;padding:0 16px 16px}
.btn-mini{flex:1;padding:8px 10px;border-radius:var(--pill);font-size:12.5px;font-weight:600;background:var(--ink);color:var(--cream);border:none;display:inline-flex;align-items:center;justify-content:center;gap:6px;cursor:pointer;transition:background .15s}
.btn-mini:hover{background:#000}
.btn-mini.ghost{background:transparent;color:var(--ink);border:1px solid var(--stone-200)}
.btn-mini.ghost:hover{border-color:var(--ink);background:var(--cream)}

/* ORDERS TABLE */
.orders-table{background:#fff;border:1px solid var(--stone-100);border-radius:var(--radius-lg);overflow:hidden}
.ot-row{display:grid;grid-template-columns:1.8fr 1.2fr 120px 120px 80px;align-items:center;gap:14px;padding:16px 20px;border-bottom:1px solid var(--stone-100);font-size:14px}
.ot-row:last-child{border-bottom:none}
.ot-head{background:var(--cream);font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--stone-500);font-weight:500;padding:13px 20px}
.ot-produto strong{display:block;font-weight:600;font-size:14px;margin-bottom:2px}
.ot-produto span{font-size:12px;color:var(--stone-500)}
.ot-email{font-size:13px;color:var(--stone-500);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ot-data{font-size:13px;color:var(--stone-500)}
.ot-acao{font-size:13px;color:var(--stone-500);font-weight:500}
.ot-acao:hover{color:var(--rose-500)}

.status-badge{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:600;padding:4px 10px;border-radius:999px}
.status-badge .dot{width:5px;height:5px;border-radius:50%;background:currentColor}
.status-paid{background:rgba(74,124,89,.12);color:var(--success)}
.status-pending{background:rgba(216,155,63,.14);color:var(--warning)}
.status-failed{background:rgba(198,65,90,.12);color:var(--error)}

.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:24px}
.stat-card{background:#fff;border:1px solid var(--stone-100);border-radius:var(--radius-lg);padding:20px}
.stat-card .lbl{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--stone-500);margin-bottom:8px}
.stat-card .val{font-family:var(--serif);font-size:28px;line-height:1;font-weight:500;letter-spacing:-.01em}
.stat-card .val em{font-style:italic;color:var(--rose-500);font-weight:400}
.stat-card .sub{font-size:12px;color:var(--stone-500);margin-top:6px}

.empty{text-align:center;padding:48px 24px;color:var(--stone-500)}
.empty .ico{font-size:40px;margin-bottom:12px}
.empty h3{font-family:var(--serif);font-size:19px;font-weight:500;color:var(--ink);margin:0 0 8px}
.empty p{font-size:14px;margin:0 0 20px}

/* SPINNER */
.spin{width:36px;height:36px;border:3px solid var(--stone-100);border-top-color:var(--rose-500);border-radius:50%;animation:spin .75s linear infinite;margin:0 auto}
@keyframes spin{to{transform:rotate(360deg)}}
.loading-wrap{text-align:center;padding:48px 0}

/* RESPONSIVE */
@media(max-width:900px){
  .auth{grid-template-columns:1fr}
  .auth-visual{display:none}
  .app{grid-template-columns:1fr}
  .sidebar{position:sticky;top:0;height:auto;flex-direction:row;gap:4px;overflow-x:auto;padding:10px 12px;border-right:none;border-bottom:1px solid var(--stone-100)}
  .sidebar .brand{padding:2px 6px}
  .side-sect{margin:0;display:flex;gap:2px}
  .side-sect h6,.side-user{display:none}
  .side-link{white-space:nowrap;font-size:13px;padding:8px 12px}
  .stats-grid{grid-template-columns:1fr 1fr}
  .ot-row{grid-template-columns:1fr 1fr;grid-template-areas:"produto acao" "email status" "data .";gap:6px}
  .ot-head{display:none}
  .ot-row>:nth-child(1){grid-area:produto}
  .ot-row>:nth-child(2){grid-area:email}
  .ot-row>:nth-child(3){grid-area:data}
  .ot-row>:nth-child(4){grid-area:status;justify-self:end}
  .ot-row>:nth-child(5){grid-area:acao;text-align:right}
  .prod-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:520px){
  .stats-grid{grid-template-columns:1fr}
  .prod-grid{grid-template-columns:1fr 1fr}
}
