*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent;}
html,body{height:100%;}
body{font-family:'Jost',sans-serif;background:#f0ebe6;color:#2a1f1f;}
button{font-family:inherit;cursor:pointer;}
input,textarea,select{font-family:inherit;}
::-webkit-scrollbar{width:5px;height:5px;}
::-webkit-scrollbar-thumb{background:#d4c4bc;border-radius:4px;}

#layout{display:flex;min-height:100vh;}

/* SIDEBAR */
#sidebar{width:240px;flex-shrink:0;background:#fff;border-right:1px solid #f0ebe8;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;padding:32px 0 24px;}
.sidebar-logo{font-family:'Cormorant Garamond',serif;font-size:18px;letter-spacing:5px;color:#3d2b2b;font-weight:600;padding:0 28px;margin-bottom:40px;}
.sidebar-nav{flex:1;display:flex;flex-direction:column;gap:4px;padding:0 12px;}
.sidebar-btn{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:14px;border:none;background:transparent;color:#b0a0a0;font-size:14px;font-weight:600;transition:all .2s;text-align:left;width:100%;}
.sidebar-btn svg{flex-shrink:0;}
.sidebar-btn:hover{background:#faf6f4;color:#3d2b2b;}
.sidebar-btn.active{background:#f5e8e8;color:#8b6060;}
.sidebar-footer{padding:0 28px;}
.sidebar-profile{display:flex;align-items:center;gap:12px;}
.sidebar-avatar{width:40px;height:40px;border-radius:50%;background:#c9a0a0;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;}
.sidebar-uname{font-size:14px;font-weight:600;color:#2a1f1f;}
.sidebar-urole{font-size:11px;color:#b0a0a0;}

/* MAIN */
#main{flex:1;display:flex;flex-direction:column;min-width:0;}

/* TOPBAR mobile */
#topbar{display:none;justify-content:space-between;align-items:center;padding:16px 20px;background:#fff;border-bottom:1px solid #f0ebe8;position:sticky;top:0;z-index:30;}
.topbar-logo{font-family:'Cormorant Garamond',serif;font-size:18px;letter-spacing:4px;color:#3d2b2b;font-weight:600;}
.topbar-avatar{width:34px;height:34px;border-radius:50%;background:#c9a0a0;display:flex;align-items:center;justify-content:center;font-size:16px;}

/* BOTTOM NAV mobile */
#bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid #f0ebe8;justify-content:space-around;padding:10px 0 20px;z-index:40;}
.bnav-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:4px 16px;border:none;background:none;color:#c0b0b0;transition:all .2s;}
.bnav-btn.active{color:#8b6060;}
.bnav-icon{width:38px;height:34px;display:flex;align-items:center;justify-content:center;border-radius:10px;transition:all .2s;}
.bnav-btn.active .bnav-icon{background:#f5e8e8;}
.bnav-label{font-size:9px;font-weight:700;letter-spacing:.5px;text-transform:capitalize;}

/* SCREENS */
.screen{display:none;flex:1;}
.screen.active{display:block;}
.page-content{padding:40px 48px;max-width:1100px;}

/* PAGE HEADER */
.page-eyebrow{font-size:11px;font-weight:700;color:#b0a0a0;letter-spacing:2px;text-transform:uppercase;margin-bottom:6px;}
.page-title{font-family:'Cormorant Garamond',serif;font-size:42px;font-weight:300;color:#2a1f1f;}
.page-title em{font-style:italic;font-weight:700;}
.page-divider{width:56px;height:2px;background:linear-gradient(90deg,#c9a0a0,transparent);border-radius:2px;margin:12px 0 32px;}

/* STATS */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:40px;}
.stat-card{background:#fff;border-radius:20px;padding:24px;box-shadow:0 2px 16px rgba(0,0,0,.05);}
.stat-card.purple{background:#eeedf8;}
.stat-card-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px;}
.stat-badge{font-size:9px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:#b0a0a0;}
.stat-card.purple .stat-badge{color:#9b8ab8;}
.stat-num{font-size:36px;font-weight:800;color:#2a1f1f;}
.stat-sub{font-size:12px;font-weight:600;color:#c9a0a0;margin-top:4px;}
.stat-card.purple .stat-sub{color:#9b8ab8;}
.stat-hint{font-size:11px;color:#bbb;margin-top:6px;}

/* SECTION */
.section-hdr{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;}
.section-title{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:600;color:#2a1f1f;}
.link-btn{background:none;border:none;font-size:11px;font-weight:700;color:#9b8ab8;letter-spacing:1px;}

/* APPT TABLE */
.appt-table{width:100%;border-collapse:collapse;}
.appt-table th{text-align:left;font-size:10px;font-weight:700;color:#b0a0a0;letter-spacing:1px;text-transform:uppercase;padding:12px 16px;border-bottom:2px solid #f0ebe8;}
.appt-table td{padding:14px 16px;border-bottom:1px solid #f5f2f0;vertical-align:middle;font-size:14px;}
.appt-table tr:last-child td{border-bottom:none;}
.appt-table tr:hover td{background:#faf7f5;}
.appt-svc-pill{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600;}
.empty-state{text-align:center;padding:48px 20px;color:#ccc;font-size:14px;}

/* TOMORROW */
.tomorrow-card{background:#6b4f4f;border-radius:20px;padding:28px;color:#fff;display:inline-block;min-width:260px;margin-top:8px;}
.tomorrow-badge{font-size:10px;font-weight:700;letter-spacing:2px;color:#d4a0a0;text-transform:uppercase;margin-bottom:8px;}
.tomorrow-svc{font-size:26px;font-weight:700;font-family:'Cormorant Garamond',serif;}
.tomorrow-slots{margin-top:10px;font-size:13px;color:#d4a0a0;}

/* CALENDAR */
.cal-toolbar{display:flex;align-items:center;gap:16px;margin-bottom:24px;flex-wrap:wrap;}
.toggle-group{display:flex;background:#f0ebe8;border-radius:14px;padding:3px;}
.toggle-btn{padding:8px 20px;border-radius:11px;border:none;background:transparent;color:#aaa;font-weight:600;font-size:13px;transition:all .2s;}
.toggle-btn.active{background:#fff;color:#3d2b2b;box-shadow:0 1px 4px rgba(0,0,0,.1);}
.cal-nav-group{display:flex;align-items:center;gap:8px;}
.cal-nav-btn{background:none;border:none;font-size:22px;color:#3d2b2b;line-height:1;padding:0 4px;}
.cal-range{font-size:16px;font-weight:700;color:#2a1f1f;}
.today-btn{background:none;border:none;font-size:12px;font-weight:700;color:#9b8ab8;}
.filter-chips{display:flex;gap:8px;flex-wrap:wrap;}
.chip{padding:6px 14px;border-radius:20px;border:none;background:#f5f0ee;color:#aaa;font-size:12px;font-weight:600;display:flex;align-items:center;gap:6px;transition:all .2s;}
.chip.active{background:#e0ddd8;color:#3d2b2b;}
.chip-dot{width:8px;height:8px;border-radius:50%;display:inline-block;}
.cal-wrap{background:#fff;border-radius:20px;overflow:hidden;box-shadow:0 2px 16px rgba(0,0,0,.05);}
.cal-grid-scroll{overflow-x:auto;}
.cal-grid{min-width:600px;}
.cal-days-hdr{display:grid;grid-template-columns:60px repeat(7,1fr);border-bottom:2px solid #f0ebe8;}
.cal-day-hdr{text-align:center;padding:14px 4px;}
.cal-day-name{font-size:10px;font-weight:700;color:#aaa;text-transform:uppercase;}
.cal-day-num{width:30px;height:30px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:15px;margin-top:4px;color:#2a1f1f;}
.cal-day-num.today{background:#8b6060;color:#fff;}
.cal-row{display:grid;grid-template-columns:60px repeat(7,1fr);min-height:60px;}
.cal-hour-label{font-size:11px;color:#bbb;padding:6px 12px 0 16px;text-align:right;border-right:1px solid #f5f0ee;}
.cal-cell{border-top:1px solid #f5f0ee;border-right:1px solid #f5f0ee;padding:4px;cursor:pointer;min-height:60px;transition:background .15s;}
.cal-cell:hover{background:#faf7f5;}
.cal-appt-block{border-radius:8px;padding:5px 8px;margin-bottom:3px;cursor:pointer;font-size:11px;font-weight:600;line-height:1.3;}
.cal-appt-sname{font-weight:400;opacity:.75;margin-top:1px;}

/* FORM */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px;}
.form-col{display:flex;flex-direction:column;gap:24px;}
.field-label{font-size:11px;font-weight:700;color:#b0a0a0;letter-spacing:1px;text-transform:uppercase;margin-bottom:8px;}
.search-wrap{position:relative;}
.search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:#aaa;pointer-events:none;}
.search-input{width:100%;padding:14px 40px;border-radius:14px;border:1px solid #e8e0dc;background:#fff;font-size:14px;color:#2a1f1f;outline:none;transition:border-color .2s;}
.search-input:focus{border-color:#c9a0a0;}
.clear-btn{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;font-size:16px;color:#aaa;}
.client-dropdown{position:absolute;top:calc(100% + 6px);left:0;right:0;background:#fff;border-radius:14px;box-shadow:0 8px 32px rgba(0,0,0,.12);z-index:200;max-height:220px;overflow-y:auto;display:none;border:1px solid #f0ebe8;}
.client-dropdown.open{display:block;}
.client-item{padding:12px 16px;cursor:pointer;border-bottom:1px solid #f5f0ee;display:flex;align-items:center;gap:12px;}
.client-item:hover{background:#faf7f5;}
.client-item:last-child{border-bottom:none;}
.client-initials-sm{width:34px;height:34px;border-radius:50%;background:#e8e0dc;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#8b6060;flex-shrink:0;}
.client-item-name{font-weight:600;color:#2a1f1f;font-size:13px;}
.client-item-phone{font-size:11px;color:#aaa;}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;}
.svc-btn{padding:18px 8px;border-radius:16px;border:2px solid #f0ebe8;background:#fff;display:flex;flex-direction:column;align-items:center;gap:8px;transition:all .2s;width:100%;}
.svc-btn.active{border-color:var(--c);background:color-mix(in srgb,var(--c) 12%,white);}
.svc-icon{font-size:26px;}
.svc-label{font-size:13px;font-weight:600;color:#aaa;}
.svc-btn.active .svc-label{color:var(--c);}
.dates-row{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;}
.date-btn{min-width:56px;padding:12px 0;border-radius:14px;border:none;background:#f5f0ee;color:#aaa;display:flex;flex-direction:column;align-items:center;gap:4px;flex-shrink:0;transition:all .2s;}
.date-btn.active{background:#fff;color:#2a1f1f;box-shadow:0 0 0 2px #9b8ab8;}
.date-day{font-size:9px;font-weight:700;letter-spacing:1px;text-transform:uppercase;}
.date-num{font-size:18px;font-weight:700;}
.times-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;}
.time-btn{padding:12px;border-radius:12px;border:none;background:#f5f0ee;color:#2a1f1f;font-weight:600;font-size:13px;transition:all .2s;}
.time-btn.active{background:#6b4f4f;color:#fff;}
.obs-textarea{width:100%;padding:14px 16px;border-radius:14px;border:1px solid #e8e0dc;background:#fff;font-size:14px;color:#2a1f1f;resize:vertical;outline:none;min-height:100px;}
.obs-textarea:focus{border-color:#c9a0a0;}
.confirm-btn{padding:16px 48px;border-radius:30px;border:none;background:#8b6060;color:#fff;font-size:15px;font-weight:700;box-shadow:0 4px 20px rgba(139,96,96,.35);transition:all .2s;}
.confirm-btn:hover{background:#7a5252;}
.error-msg{background:#fde8e8;color:#c44;padding:12px 16px;border-radius:12px;font-size:13px;margin-bottom:20px;}

/* CLIENTES */
.clients-toolbar{display:flex;gap:12px;margin-bottom:24px;flex-wrap:wrap;align-items:center;}
.search-bar{position:relative;flex:1;min-width:200px;}
.search-bar input{width:100%;padding:12px 12px 12px 40px;border-radius:14px;border:1px solid #e8e0dc;background:#fff;font-size:14px;color:#2a1f1f;outline:none;}
.search-bar span{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:#aaa;pointer-events:none;}
.tabs-row{display:flex;gap:8px;flex-wrap:wrap;}
.tab-btn{padding:8px 18px;border-radius:20px;border:none;background:#f0ebe8;color:#aaa;font-weight:700;font-size:11px;letter-spacing:1px;text-transform:uppercase;transition:all .2s;}
.tab-btn.active{background:#2a1f1f;color:#fff;}
.clients-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px;}
.client-card{background:#fff;border-radius:16px;padding:18px 20px;display:flex;align-items:center;gap:14px;box-shadow:0 1px 8px rgba(0,0,0,.05);transition:box-shadow .2s;}
.client-card:hover{box-shadow:0 4px 20px rgba(0,0,0,.1);}
.client-initials{width:48px;height:48px;border-radius:50%;background:#e8e0dc;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#8b6060;flex-shrink:0;}
.client-info{flex:1;}
.client-name{font-weight:700;color:#2a1f1f;font-size:15px;}
.client-last{font-size:12px;color:#aaa;margin-top:3px;}
.client-msg-btn{width:36px;height:36px;border-radius:10px;background:#f5f0ee;border:none;font-size:16px;display:flex;align-items:center;justify-content:center;}
.alpha-letter{font-size:12px;font-weight:700;color:#d0c0b8;padding:16px 0 8px;letter-spacing:1px;grid-column:1/-1;}
.add-btn{display:flex;align-items:center;gap:8px;padding:12px 20px;border-radius:14px;border:none;background:#8b6060;color:#fff;font-size:14px;font-weight:600;box-shadow:0 4px 16px rgba(139,96,96,.3);transition:all .2s;white-space:nowrap;}
.add-btn:hover{background:#7a5252;}

/* MODAL */
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.35);z-index:1000;display:none;align-items:center;justify-content:center;padding:20px;}
.overlay.open{display:flex;}
.modal-box{background:#fff;border-radius:20px;padding:28px;width:min(420px,95vw);max-height:85vh;overflow-y:auto;}
.modal-title{font-size:20px;font-weight:600;color:#3d2b2b;margin-bottom:20px;}
.modal-row{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid #f0ebe8;}
.modal-row-label{color:#aaa;font-size:13px;}
.modal-row-val{color:#2a1f1f;font-size:13px;font-weight:500;}
.modal-btns{display:flex;gap:10px;margin-top:24px;}
.btn-primary{flex:1;padding:13px 0;border-radius:30px;background:#8b6060;color:#fff;border:none;font-weight:700;font-size:14px;}
.btn-secondary{flex:1;padding:13px 0;border-radius:30px;background:#f5f0ee;color:#3d2b2b;border:none;font-weight:700;font-size:14px;}
.btn-danger{background:#c44 !important;}
.modal-svc-hdr{display:flex;align-items:center;gap:14px;margin-bottom:20px;}
.modal-svc-icon{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:22px;}
.modal-svc-name{font-weight:700;color:#3d2b2b;font-size:16px;}
.modal-svc-dur{font-size:13px;color:#999;}
.modal-input{width:100%;padding:13px 16px;border-radius:12px;border:1px solid #e8e0dc;background:#f9f6f4;font-size:14px;color:#2a1f1f;outline:none;margin-bottom:14px;}
.modal-select{width:100%;padding:13px 16px;border-radius:12px;border:1px solid #e8e0dc;background:#f9f6f4;font-size:14px;color:#2a1f1f;outline:none;margin-bottom:14px;}

#toast{position:fixed;bottom:32px;left:50%;transform:translateX(-50%);background:#2a1f1f;color:#fff;padding:14px 28px;border-radius:30px;font-size:14px;z-index:9999;box-shadow:0 4px 24px rgba(0,0,0,.2);display:none;white-space:nowrap;}
@keyframes fadeUp{from{opacity:0;transform:translateX(-50%) translateY(12px);}to{opacity:1;transform:translateX(-50%) translateY(0);}}

/* NOVO CLIENT CARD */
.novo-client-card{display:flex;align-items:center;gap:12px;background:#fdf5f5;border:1.5px solid #f0dede;border-radius:14px;padding:14px 16px;}

/* ADMIN BADGE */
.admin-badge{font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:#fff;background:#8b6060;border-radius:20px;padding:3px 12px;margin:0 28px 28px;display:inline-block;}

/* CLIENT HERO */
.client-hero{background:#fff;border-radius:20px;padding:36px 32px;display:flex;align-items:center;justify-content:space-between;gap:24px;box-shadow:0 2px 16px rgba(0,0,0,.05);}
.client-hero-body{flex:1;}
.client-hero-tagline{font-family:'Cormorant Garamond',serif;font-size:32px;font-weight:600;color:#2a1f1f;line-height:1.25;margin-bottom:12px;}
.client-hero-tagline em{font-style:italic;}
.client-hero-sub{font-size:14px;color:#b0a0a0;line-height:1.7;max-width:320px;}
.client-hero-btn{margin-top:24px;padding:14px 36px;}
.client-hero-deco{font-size:72px;line-height:1;flex-shrink:0;filter:drop-shadow(0 4px 12px rgba(0,0,0,.1));}

/* CLIENT SERVICES ROW */
.client-svc-row{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:32px;}
.client-svc-card{background:#fff;border-radius:18px;padding:24px 16px;text-align:center;cursor:pointer;box-shadow:0 1px 8px rgba(0,0,0,.05);transition:all .2s;}
.client-svc-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.1);}
.csvc-icon{width:60px;height:60px;border-radius:18px;display:flex;align-items:center;justify-content:center;font-size:26px;margin:0 auto 14px;}
.csvc-name{font-weight:700;color:#2a1f1f;font-size:16px;margin-bottom:4px;}
.csvc-detail{font-size:12px;color:#b0a0a0;}

/* CLIENT INFO STRIP */
.client-info-strip{display:flex;align-items:center;gap:16px;background:#fff;border-radius:16px;padding:18px 24px;box-shadow:0 1px 8px rgba(0,0,0,.05);flex-wrap:wrap;}
.client-info-item{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:#8b6060;}
.client-info-sep{width:1px;height:20px;background:#f0ebe8;}

/* LOGIN */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:#f0ebe6;}
.login-card{background:#fff;border-radius:24px;padding:40px;width:min(400px,90vw);box-shadow:0 8px 40px rgba(0,0,0,.1);}
.login-logo{font-family:'Cormorant Garamond',serif;font-size:28px;letter-spacing:6px;color:#3d2b2b;font-weight:600;text-align:center;margin-bottom:6px;}
.login-sub{text-align:center;color:#b0a0a0;font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;margin-bottom:32px;}
.login-title{font-size:20px;font-weight:700;color:#2a1f1f;margin-bottom:20px;text-align:center;}
.login-field{margin-bottom:16px;}
.login-toggle{text-align:center;margin-top:20px;font-size:13px;color:#aaa;}
.login-toggle button{background:none;border:none;color:#8b6060;font-weight:700;font-size:13px;cursor:pointer;font-family:inherit;}

@media(max-width:768px){
  #sidebar{display:none;}
  #topbar{display:flex;}
  #bottom-nav{display:flex;}
  .page-content{padding:20px 16px 90px;}
  .form-grid{grid-template-columns:1fr;}
  .page-title{font-size:30px;}
  .client-hero{flex-direction:column;padding:24px 20px;}
  .client-hero-deco{font-size:48px;}
  .client-hero-tagline{font-size:26px;}
  .client-svc-row{grid-template-columns:repeat(3,1fr);gap:10px;}
  .csvc-icon{width:48px;height:48px;font-size:20px;}
  .csvc-name{font-size:13px;}
  .client-info-strip{gap:12px;}
  .client-info-sep{display:none;}
}
@media(min-width:769px) and (max-width:1024px){
  #sidebar{width:200px;}
  .page-content{padding:32px;}
}
