/* ================================================================
   TouAgendando — design system compartilhado (paleta da landing)
   ================================================================ */
:root{
  --ink:#0E2B27; --ink-2:#123833; --paper:#F7F3EA; --paper-2:#FEFCF7;
  --honey:#E19A38; --honey-deep:#C97F20; --clay:#C46A4A;
  --mist:#5F7A72; --cream:#EDE6D6; --cream-dim:#B8C4BC;
  --line:rgba(14,43,39,.14); --line-dark:rgba(237,230,214,.16);
  --shadow:0 1px 2px rgba(14,43,39,.06), 0 12px 32px -12px rgba(14,43,39,.22);
  --ok:#2E7D5B; --warn:#B7791F; --danger:#C0392B; --info:#2B6CB0;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Hanken Grotesk',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  background:var(--paper);color:var(--ink);-webkit-font-smoothing:antialiased;line-height:1.55}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:'Fraunces',Georgia,serif;font-weight:500;letter-spacing:-.01em;line-height:1.15}
.serif{font-family:'Fraunces',Georgia,serif}
.wrap{max-width:1120px;margin:0 auto;padding:0 24px}
.muted{color:var(--mist)}
.small{font-size:.88rem}
.center{text-align:center}
.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}
.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}
.ml-1{margin-left:.4rem}
.row{display:flex;gap:1rem;flex-wrap:wrap}
.row.between{justify-content:space-between;align-items:center}
.grid{display:grid;gap:1.25rem}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
@media(max-width:820px){.grid-2,.grid-3{grid-template-columns:1fr}}

/* ---------- Botões ---------- */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-weight:600;font-size:1rem;
  padding:.7rem 1.3rem;border-radius:999px;border:1px solid transparent;cursor:pointer;
  transition:transform .15s ease,box-shadow .15s ease,background .15s ease;line-height:1}
.btn-primary{background:var(--honey);color:#2B1B05;box-shadow:0 8px 22px -10px rgba(225,154,56,.7)}
.btn-primary:hover{transform:translateY(-2px)}
.btn-dark{background:var(--ink);color:var(--cream)}
.btn-dark:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{background:rgba(14,43,39,.04)}
.btn-danger{background:transparent;color:var(--danger);border-color:rgba(192,57,43,.4)}
.btn-danger:hover{background:rgba(192,57,43,.08)}
.btn-sm{padding:.45rem .9rem;font-size:.86rem}
.btn-block{width:100%;justify-content:center}
.btn[disabled]{opacity:.5;cursor:not-allowed}

/* ---------- Cards ---------- */
.card{background:var(--paper-2);border:1px solid var(--line);border-radius:18px;padding:24px;box-shadow:var(--shadow)}
.card h3{margin-bottom:.35rem}
.card + .card{margin-top:1.25rem}

/* ---------- Forms ---------- */
label{display:block;font-weight:600;font-size:.9rem;margin-bottom:.35rem}
.field{margin-bottom:1.1rem}
.hint{font-size:.82rem;color:var(--mist);margin-top:.3rem}
input[type=text],input[type=email],input[type=password],input[type=tel],input[type=number],
input[type=date],input[type=time],select,textarea{
  width:100%;padding:.7rem .85rem;border:1px solid var(--line);border-radius:12px;
  background:#fff;font:inherit;color:var(--ink);transition:border-color .15s,box-shadow .15s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--honey);
  box-shadow:0 0 0 3px rgba(225,154,56,.18)}
textarea{min-height:90px;resize:vertical}
.check{display:flex;align-items:center;gap:.55rem}
.check input{width:auto}
.inline-fields{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem}

/* ---------- Badges / status ---------- */
.badge{display:inline-flex;align-items:center;gap:.35rem;font-size:.76rem;font-weight:700;
  padding:.25rem .6rem;border-radius:999px;letter-spacing:.02em}
.badge.open{background:rgba(95,122,114,.15);color:var(--mist)}
.badge.confirmed{background:rgba(46,125,91,.15);color:var(--ok)}
.badge.warn{background:rgba(183,121,31,.15);color:var(--warn)}
.badge.info{background:rgba(43,108,176,.13);color:var(--info)}
.badge.cancelled{background:rgba(192,57,43,.12);color:var(--danger)}
.badge.done{background:rgba(14,43,39,.1);color:var(--ink)}

/* ---------- Flash ---------- */
.flash{padding:.85rem 1.1rem;border-radius:12px;margin-bottom:1rem;font-weight:500;font-size:.95rem}
.flash.success{background:rgba(46,125,91,.12);color:var(--ok);border:1px solid rgba(46,125,91,.3)}
.flash.error{background:rgba(192,57,43,.1);color:var(--danger);border:1px solid rgba(192,57,43,.3)}
.flash.info{background:rgba(43,108,176,.1);color:var(--info);border:1px solid rgba(43,108,176,.3)}

/* ---------- Tabelas ---------- */
table{width:100%;border-collapse:collapse}
th,td{text-align:left;padding:.7rem .6rem;border-bottom:1px solid var(--line);font-size:.94rem}
th{font-size:.78rem;text-transform:uppercase;letter-spacing:.05em;color:var(--mist);font-weight:700}
tr:last-child td{border-bottom:none}

/* ---------- Auth (card centralizado) ---------- */
.auth-shell{min-height:100vh;display:grid;place-items:center;padding:2rem 1rem;
  background:radial-gradient(700px 420px at 85% -10%,rgba(225,154,56,.1),transparent 60%),var(--paper)}
.auth-card{width:100%;max-width:420px;background:var(--paper-2);border:1px solid var(--line);
  border-radius:22px;padding:2.2rem;box-shadow:var(--shadow)}
.auth-brand{display:flex;align-items:center;gap:.55rem;font-family:'Fraunces';font-weight:600;
  font-size:1.3rem;margin-bottom:1.5rem;color:var(--ink)}
.auth-brand svg{width:26px;height:26px}
.auth-alt{text-align:center;margin-top:1.3rem;font-size:.92rem;color:var(--mist)}
.auth-alt a{color:var(--honey-deep);font-weight:600}
.credit{text-align:center;margin-top:1.4rem;font-size:.78rem;color:var(--mist);line-height:1.5}
.credit .ver{opacity:.7}
.credit a{color:var(--honey-deep);font-weight:600}

/* ---------- Painel (professor / admin) ---------- */
.app-shell{display:grid;grid-template-columns:250px 1fr;min-height:100vh}
.sidebar{background:var(--ink);color:var(--cream-dim);padding:1.5rem 1.1rem;display:flex;flex-direction:column}
.sidebar .brand{display:flex;align-items:center;gap:.55rem;color:var(--cream);font-family:'Fraunces';
  font-weight:600;font-size:1.25rem;margin-bottom:1.8rem}
.sidebar .brand svg{width:24px;height:24px}
.sidebar nav a{display:flex;align-items:center;gap:.6rem;padding:.6rem .75rem;border-radius:10px;
  color:var(--cream-dim);font-weight:500;font-size:.96rem;margin-bottom:.2rem;transition:background .15s,color .15s}
.sidebar nav a:hover{background:rgba(237,230,214,.07);color:var(--cream)}
.sidebar nav a.active{background:rgba(225,154,56,.16);color:var(--honey)}
.sidebar .nav-group{font-size:.68rem;text-transform:uppercase;letter-spacing:.08em;
  color:var(--cream-dim);opacity:.6;font-weight:700;margin:1rem .75rem .35rem}
.sidebar .nav-footer{border-top:1px solid var(--line-dark);padding-top:.8rem;margin-top:.4rem}
.sidebar .nav-footer a{display:block;color:var(--cream-dim);font-size:.9rem;padding:.35rem .75rem;
  border-radius:8px;transition:background .15s,color .15s}
.sidebar .nav-footer a:hover{background:rgba(237,230,214,.07);color:var(--honey)}
.sidebar .spacer{flex:1}
.sidebar .who{font-size:.82rem;color:var(--cream-dim);border-top:1px solid var(--line-dark);padding-top:1rem}
.sidebar .who b{color:var(--cream);display:block}
.main{padding:2rem 2.4rem;overflow-x:hidden}
.page-head{display:flex;justify-content:space-between;align-items:flex-end;gap:1rem;margin-bottom:1.6rem;flex-wrap:wrap}
.page-head h1{font-size:1.9rem}
.page-head p{color:var(--mist);margin-top:.2rem}
@media(max-width:860px){
  .app-shell{grid-template-columns:1fr}
  .sidebar{flex-direction:row;flex-wrap:wrap;align-items:center;gap:.4rem;padding:1rem}
  .sidebar .brand{margin-bottom:0;margin-right:1rem}
  .sidebar nav{display:flex;flex-wrap:wrap;gap:.2rem}
  .sidebar .nav-group{display:none}
  .sidebar .spacer,.sidebar .who,.sidebar .nav-footer{display:none}
  .main{padding:1.4rem 1.1rem}
}

/* ---------- Stat cards ---------- */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:1.6rem}
.stat{background:var(--paper-2);border:1px solid var(--line);border-radius:16px;padding:1.1rem 1.2rem}
.stat .k{font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;color:var(--mist);font-weight:700}
.stat .v{font-family:'Fraunces';font-size:1.9rem;margin-top:.2rem}
.stat .v.honey{color:var(--honey-deep)}

/* ---------- Barra do dono (professor vendo a própria página) ---------- */
.owner-bar{background:var(--honey);color:#2B1B05;display:flex;align-items:center;
  justify-content:center;gap:1rem;padding:.55rem 1rem;font-size:.9rem;font-weight:600;flex-wrap:wrap}
.owner-bar .btn{background:var(--ink);color:var(--cream);padding:.35rem .8rem}
.owner-bar .btn:hover{transform:translateY(-1px)}

/* ---------- Vitrine pública (hero de perfil) ---------- */
.store-header{background:var(--ink);color:var(--cream);position:relative;overflow:hidden;
  padding:1.4rem 0 2.2rem;border-bottom:1px solid var(--line-dark)}
.store-header::after{content:"";position:absolute;inset:0;pointer-events:none;background:
  radial-gradient(600px 340px at 88% -20%, rgba(225,154,56,.18), transparent 60%),
  radial-gradient(480px 320px at -8% 120%, rgba(196,106,74,.12), transparent 62%)}
.store-header .wrap{position:relative;z-index:2}
.store-topbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding-bottom:1.2rem;margin-bottom:1.2rem;border-bottom:1px solid var(--line-dark);flex-wrap:wrap}

.store-hero{display:flex;align-items:center;gap:1.3rem}
.store-avatar{width:96px;height:96px;border-radius:50%;background:var(--honey);color:#2B1B05;
  display:grid;place-items:center;font-family:'Fraunces';font-size:2.6rem;font-weight:600;flex:none;overflow:hidden;
  box-shadow:0 0 0 3px rgba(225,154,56,.35), 0 12px 30px -10px rgba(0,0,0,.5)}
.store-avatar img{width:100%;height:100%;object-fit:cover;display:block}
.store-hero-info{min-width:0}
.store-hero-info h1{color:var(--cream);font-size:clamp(1.6rem,4vw,2.2rem);line-height:1.1}
.store-tagline{color:var(--cream);opacity:.9;margin-top:.35rem;max-width:36rem;font-size:1.05rem}
.store-meta{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:.7rem;font-size:.88rem}
.store-pill{display:inline-flex;align-items:center;gap:.3rem;background:rgba(237,230,214,.1);
  border:1px solid var(--line-dark);color:var(--cream-dim);padding:.25rem .7rem;border-radius:999px}
.store-ig{display:inline-flex;align-items:center;gap:.4rem;background:rgba(225,154,56,.14);
  border:1px solid rgba(225,154,56,.4);color:var(--honey);padding:.25rem .7rem;border-radius:999px;font-weight:600;transition:background .15s}
.store-ig:hover{background:rgba(225,154,56,.24)}
@media(max-width:560px){
  .store-hero{flex-direction:column;align-items:flex-start;gap:1rem}
  .store-avatar{width:80px;height:80px;font-size:2.1rem}
}

/* ---------- Sobre (perfil) ---------- */
.profile-about h2{font-size:1.35rem;margin-bottom:.5rem}
.profile-about .about-text{white-space:pre-line;color:var(--ink);line-height:1.6}
.creds{margin-top:1rem;border-top:1px solid var(--line);padding-top:1rem}
.creds-title{font-size:.76rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--mist);margin-bottom:.6rem}
.creds ul{list-style:none;display:flex;flex-direction:column;gap:.5rem}
.creds li{display:flex;gap:.6rem;align-items:flex-start;font-size:1rem;color:var(--ink)}
.creds li svg{flex:none;margin-top:2px;color:var(--honey-deep)}
.session-card{background:var(--paper-2);border:1px solid var(--line);border-radius:16px;padding:1.1rem 1.2rem;
  display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}
.session-card .when{font-family:'Fraunces';font-size:1.15rem}
.session-card .meta{color:var(--mist);font-size:.9rem;margin-top:.15rem}
.seats-line{display:flex;gap:4px;margin-top:.5rem}
.seat{width:10px;height:10px;border-radius:50%;background:rgba(14,43,39,.14)}
.seat.filled{background:var(--honey)}
.day-group{margin-bottom:1.8rem}
.day-label{font-size:.8rem;text-transform:uppercase;letter-spacing:.06em;color:var(--mist);
  font-weight:700;margin-bottom:.7rem;padding-bottom:.4rem;border-bottom:1px solid var(--line)}

/* ---------- PIX ---------- */
.pix-box{text-align:center}
.pix-qr{width:220px;height:220px;margin:0 auto 1rem;border:1px solid var(--line);border-radius:14px;padding:8px;background:#fff}
.pix-code{word-break:break-all;font-family:ui-monospace,monospace;font-size:.8rem;background:#fff;
  border:1px solid var(--line);border-radius:10px;padding:.8rem;margin:.6rem 0}
.timer{font-family:'Fraunces';font-size:1.4rem;color:var(--honey-deep)}

/* ---------- OTP ---------- */
.otp-input{letter-spacing:.5em;text-align:center;font-size:1.4rem;font-family:'Fraunces'}

/* ---------- Calendário ---------- */
.cal-nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}
.cal-nav h2{text-align:center;flex:1}
.cal-legend{display:flex;gap:.6rem;margin-bottom:1rem;flex-wrap:wrap}
.calendar{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;background:var(--line);
  border:1px solid var(--line);border-radius:14px;padding:6px;overflow:hidden}
.cal-head{background:transparent;text-align:center;font-size:.74rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.05em;color:var(--mist);padding:.4rem 0}
.cal-cell{background:var(--paper-2);border-radius:8px;min-height:104px;padding:6px;position:relative}
.cal-cell.empty{background:transparent}
.cal-cell.today{outline:2px solid var(--honey);outline-offset:-2px}
.cal-daynum{font-size:.82rem;font-weight:700;color:var(--mist);margin-bottom:4px}
.cal-cell.today .cal-daynum{color:var(--honey-deep)}
.cal-ev{display:block;font-size:.72rem;line-height:1.25;border-radius:6px;padding:3px 5px;
  margin-bottom:4px;border-left:3px solid var(--mist);background:rgba(95,122,114,.1);color:var(--ink);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cal-ev b{font-weight:700}
.cal-ev .cal-count{float:right;opacity:.8;font-weight:600}
.cal-ev.open{border-left-color:var(--mist);background:rgba(95,122,114,.12)}
.cal-ev.confirmed{border-left-color:var(--ok);background:rgba(46,125,91,.14)}
.cal-ev.cancelled{border-left-color:var(--danger);background:rgba(192,57,43,.1);opacity:.7;text-decoration:line-through}
.cal-ev.done{border-left-color:var(--ink);background:rgba(14,43,39,.08)}
.cal-ev:hover{filter:brightness(.97)}
@media(max-width:720px){
  .calendar{gap:3px;padding:3px}
  .cal-cell{min-height:74px;padding:3px}
  .cal-ev .cal-count{display:none}
  .cal-ev{font-size:.64rem}
  .cal-head{font-size:.62rem}
}

/* ---------- Chips de filtro ---------- */
.chips{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1.2rem}
.chip{display:inline-flex;align-items:center;gap:.4rem;font:inherit;font-size:.9rem;font-weight:600;
  padding:.45rem .85rem;border-radius:999px;border:1px solid var(--line);background:var(--paper-2);
  color:var(--ink);cursor:pointer;transition:background .15s,border-color .15s,color .15s}
.chip:hover{border-color:var(--honey)}
.chip.active{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.chip-count{display:inline-grid;place-items:center;min-width:1.3rem;height:1.3rem;padding:0 .35rem;
  border-radius:999px;background:rgba(14,43,39,.1);color:inherit;font-size:.76rem;font-weight:700}
.chip.active .chip-count{background:rgba(237,230,214,.22)}

/* ---------- Compartilhar página ---------- */
.share-link{display:flex;gap:.5rem;align-items:center}
.share-link input{flex:1;min-width:0;background:#fff;font-family:ui-monospace,monospace;font-size:.9rem}
.share-link .btn{flex:none}
.share-qr{border:1px solid var(--line);border-radius:12px;padding:6px;background:#fff}
@media(max-width:640px){
  #compartilhar .grid{grid-template-columns:1fr !important}
}

/* ---------- Foto de perfil / cropper ---------- */
.avatar-preview{width:96px;height:96px;border-radius:50%;overflow:hidden;flex:none;
  background:var(--honey);color:#2B1B05;display:grid;place-items:center;
  font-family:'Fraunces';font-size:2.4rem;font-weight:600;border:2px solid var(--line)}
.avatar-preview img{width:100%;height:100%;object-fit:cover;display:block}
/* Modal próprio (nome NÃO pode ser .cropper-modal — colide com a classe interna do Cropper.js) */
.photo-modal{position:fixed;inset:0;z-index:200;background:rgba(14,43,39,.72);
  display:grid;place-items:center;padding:1rem}
.photo-modal[hidden]{display:none}
.cropper-box{background:var(--paper-2);border-radius:18px;padding:1.4rem;width:100%;max-width:440px;
  box-shadow:var(--shadow)}
.cropper-stage{width:100%;height:320px;background:#0000;border-radius:12px;overflow:hidden}
.cropper-stage img{max-width:100%;display:block}
.cropper-tools{display:flex;align-items:center;gap:.6rem;margin-top:.9rem}
.cropper-tools input[type=range]{flex:1}
/* deixa a área de recorte redonda (só visual) */
.cropper-view-box,.cropper-face{border-radius:50%}

/* ---------- Misc ---------- */
.divider{height:1px;background:var(--line);margin:1.4rem 0}
.empty{text-align:center;padding:3rem 1rem;color:var(--mist)}
.empty .serif{font-size:1.3rem;color:var(--ink);margin-bottom:.4rem}
.list-reset{list-style:none}
footer.site{background:var(--ink);color:var(--cream-dim);padding:2rem 0;margin-top:3rem;font-size:.9rem}
footer.site a{color:var(--cream-dim)}
footer.site a:hover{color:var(--honey)}
:focus-visible{outline:2.5px solid var(--honey);outline-offset:2px;border-radius:6px}
