:root{
  --bege:#F3EAD8; --bege-2:#EFE3CC; --rosa:#F6D9DE; --rosa-2:#F2C6CE;
  --dourado:#C9A227; --dourado-2:#A8851A; --texto:#3D3528; --muted:#8A7F6C;
  --branco:#FFFDF8; --linha:#E4D8BF; --ok:#3F7D52; --erro:#B4453C; --aviso:#B8860B;
  --sombra:0 2px 14px rgba(120,90,40,.10);
}
*{box-sizing:border-box}
body{margin:0;font-family:'Segoe UI',Roboto,Helvetica,Arial,sans-serif;background:var(--bege);color:var(--texto);font-size:15px}
a{color:var(--dourado-2);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3{font-weight:600;color:var(--texto)}
.muted{color:var(--muted)}

/* topbar */
.topbar{background:linear-gradient(120deg,var(--dourado),var(--dourado-2));color:#fff;padding:12px 22px;display:flex;align-items:center;justify-content:space-between;box-shadow:var(--sombra)}
.topbar .brand{font-size:18px;font-weight:700;letter-spacing:.3px;color:#fff;display:flex;align-items:center;gap:10px}
.topbar .brand .dot{width:12px;height:12px;border-radius:50%;background:var(--rosa)}
.topbar .userbox{font-size:13px;color:#fff;display:flex;gap:14px;align-items:center}
.topbar .userbox a{color:#fff}
.badge-role{background:var(--rosa);color:var(--texto);padding:2px 10px;border-radius:20px;font-size:11px;font-weight:600;text-transform:capitalize}

/* layout */
.shell{display:flex;min-height:calc(100vh - 50px)}
.side{width:208px;background:var(--branco);border-right:1px solid var(--linha);padding:14px 0}
.side a{display:block;padding:9px 22px;color:var(--texto);font-size:14px;border-left:3px solid transparent}
.side a:hover{background:var(--bege-2);text-decoration:none}
.side a.active{border-left-color:var(--dourado);background:var(--rosa);font-weight:600}
.side .grp{font-size:11px;text-transform:uppercase;color:var(--muted);padding:14px 22px 4px;letter-spacing:.5px}
.main{flex:1;padding:24px 30px;max-width:1200px}

/* cards */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin:16px 0}
.card{background:var(--branco);border:1px solid var(--linha);border-radius:12px;padding:16px 18px;box-shadow:var(--sombra)}
.card .k{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.4px}
.card .v{font-size:26px;font-weight:700;margin-top:4px;color:var(--dourado-2)}
.panel{background:var(--branco);border:1px solid var(--linha);border-radius:12px;padding:18px 20px;margin:16px 0;box-shadow:var(--sombra)}
.panel h2{margin:0 0 12px;font-size:17px;border-bottom:2px solid var(--rosa);padding-bottom:8px}

/* tabelas */
table{width:100%;border-collapse:collapse;font-size:14px}
th,td{text-align:left;padding:9px 10px;border-bottom:1px solid var(--linha)}
th{background:var(--bege-2);color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.3px}
tr:hover td{background:var(--bege-2)}

/* form */
label{display:block;font-size:13px;color:var(--muted);margin:8px 0 3px}
input,select,textarea{width:100%;padding:9px 11px;border:1px solid var(--linha);border-radius:8px;background:var(--branco);font-size:14px;color:var(--texto)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--dourado)}
.row{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px}
.btn{display:inline-block;background:var(--dourado);color:#fff;border:none;padding:10px 18px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer}
.btn:hover{background:var(--dourado-2);text-decoration:none}
.btn.sec{background:var(--rosa);color:var(--texto)}
.btn.sm{padding:5px 10px;font-size:12px}
.btn.ghost{background:transparent;border:1px solid var(--dourado);color:var(--dourado-2)}

/* status pills */
.pill{padding:3px 10px;border-radius:20px;font-size:12px;font-weight:600;display:inline-block}
.st-reservado{background:#Ede3c8;color:#8a6d1a}
.st-confirmado{background:#d8ecdd;color:var(--ok)}
.st-em_atendimento{background:#d6e4f5;color:#2f5f99}
.st-concluido{background:#cfe8d6;color:var(--ok)}
.st-faltou{background:#f6dada;color:var(--erro)}
.st-cancelado{background:#eee;color:#888}
.flash-ok{background:#d8ecdd;color:var(--ok);padding:10px 14px;border-radius:8px;margin:10px 0}
.flash-erro{background:#f6dada;color:var(--erro);padding:10px 14px;border-radius:8px;margin:10px 0}

/* login + site */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--bege),var(--rosa))}
.login-card{background:var(--branco);border-radius:18px;padding:36px 34px;width:380px;box-shadow:0 10px 40px rgba(120,90,40,.18)}
.login-card h1{text-align:center;font-size:22px;margin:0 0 4px;color:var(--dourado-2)}
.login-card .sub{text-align:center;color:var(--muted);font-size:13px;margin-bottom:20px}

.hero{background:linear-gradient(135deg,var(--bege) 60%,var(--rosa));padding:70px 20px;text-align:center}
.hero h1{font-size:38px;max-width:780px;margin:0 auto 14px}
.hero p{font-size:18px;color:var(--muted);max-width:620px;margin:0 auto 26px}
.section{max-width:1080px;margin:0 auto;padding:40px 20px}
.spec-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}
.spec{background:var(--branco);border:1px solid var(--linha);border-radius:14px;padding:22px;box-shadow:var(--sombra)}
.spec h3{color:var(--dourado-2);margin:0 0 8px}
.bignum{font-size:34px;font-weight:800;color:var(--dourado-2)}
.footer{background:var(--texto);color:#e8ddc6;text-align:center;padding:26px;font-size:13px}
@media(max-width:780px){.side{display:none}.main{padding:16px}}
