:root{
  --rose:#F2A7B8;--rose-deep:#E07C97;--blush:#FDE8EF;
  --lav:#D6C9F0;--lav-deep:#A98FD8;
  --peach:#FFD6C0;--mint:#B8E8D4;--mint-deep:#5DB896;
  --coral:#F5A89A;--cream:#FFF8F5;--nude:#F2E8E3;
  --nude-dark:#E2D5CE;--text:#3A2D35;--text-mid:#7A6570;
  --text-soft:#B09AA5;--white:#FFFFFF;
  --r-sm:10px;--r-md:16px;--r-lg:22px;--r-xl:28px;
  --sh-soft:0 2px 12px rgba(160,100,120,.10);
  --sh-card:0 4px 20px rgba(160,100,120,.13);
  --sh-float:0 8px 32px rgba(160,100,120,.20);
  --nav-h:68px;--top-h:62px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-tap-highlight-color:transparent}
body{font-family:'DM Sans',sans-serif;background:var(--cream);color:var(--text);min-height:100dvh;overflow-x:hidden;-webkit-font-smoothing:antialiased}

/* ── TOPBAR ── */
.mob-topbar{position:fixed;top:0;left:0;right:0;height:var(--top-h);background:var(--white);border-bottom:1.5px solid var(--nude);display:flex;align-items:center;padding:0 16px;gap:10px;z-index:200;box-shadow:0 2px 12px rgba(160,100,120,.07)}
.mob-logo{flex:1;display:flex;align-items:center}
.mob-logo img{height:44px;width:auto;object-fit:contain}
.mob-topbar-actions{display:flex;gap:8px}
.mob-icon-btn{width:38px;height:38px;border-radius:12px;border:1.5px solid var(--nude);background:var(--white);display:flex;align-items:center;justify-content:center;font-size:17px;cursor:pointer;position:relative;transition:background .18s;user-select:none}
.mob-icon-btn:active{background:var(--blush)}
.mob-icon-btn .dot{position:absolute;top:6px;right:6px;width:8px;height:8px;background:var(--rose-deep);border-radius:50%;border:2px solid var(--white)}
.mob-view-switch{flex-shrink:0;font-size:11px;font-weight:700;color:var(--rose-deep);background:var(--blush);border:1.5px solid var(--rose);border-radius:20px;padding:6px 12px;cursor:pointer;user-select:none;margin-right:8px;white-space:nowrap}
.mob-view-switch:active{background:var(--rose)}

/* ── BOTTOM NAV ── */
.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:var(--nav-h);background:var(--white);border-top:1.5px solid var(--nude);display:flex;align-items:flex-start;padding-top:10px;z-index:200;box-shadow:0 -4px 20px rgba(160,100,120,.10)}
.nav-tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;cursor:pointer;padding:2px 0;user-select:none;position:relative}
.nav-tab-icon{font-size:22px;line-height:1;transition:transform .2s}
.nav-tab.active .nav-tab-icon{transform:scale(1.15)}
.nav-tab-label{font-size:10px;font-weight:600;color:var(--text-soft);transition:color .15s}
.nav-tab.active .nav-tab-label{color:var(--rose-deep)}
.nav-tab-badge{position:absolute;top:-2px;right:calc(50% - 20px);background:var(--rose-deep);color:var(--white);font-size:9px;font-weight:700;padding:1px 5px;border-radius:20px;border:2px solid var(--white)}

/* ── FAB ── */
.fab{position:fixed;bottom:calc(var(--nav-h) + 14px);right:18px;width:54px;height:54px;background:linear-gradient(135deg,var(--rose-deep),var(--lav-deep));border-radius:18px;display:flex;align-items:center;justify-content:center;font-size:26px;color:var(--white);box-shadow:0 6px 20px rgba(224,124,151,.40);cursor:pointer;z-index:190;transition:transform .2s;user-select:none}
.fab:active{transform:scale(0.93)}

/* ── SCREENS ── */
.screens{padding-top:var(--top-h);padding-bottom:calc(var(--nav-h) + 16px);min-height:100dvh}
.screen{display:none}.screen.active{display:block}

/* ── SCROLL CONTENT ── */
.scroll-content{padding:14px 14px 8px;display:flex;flex-direction:column;gap:12px}

/* ── GREETING ── */
.greeting{padding:16px 16px 4px}
.greeting h1{font-family:'DM Serif Display',serif;font-size:21px;color:var(--text);line-height:1.2}
.greeting h1 em{color:var(--rose-deep);font-style:italic}
.greeting p{font-size:12px;color:var(--text-soft);margin-top:3px}

/* ── BANNER ── */
.banner{background:linear-gradient(135deg,#FDEEF5 0%,#EDE4F5 55%,#E4F5F0 100%);border:1.5px solid rgba(242,167,184,.25);border-radius:var(--r-xl);padding:14px 16px;display:flex;align-items:center;gap:12px;box-shadow:var(--sh-soft)}
.banner-icon{font-size:26px;animation:bloom 2.5s ease infinite alternate;flex-shrink:0}
@keyframes bloom{from{transform:scale(1) rotate(-4deg)}to{transform:scale(1.1) rotate(4deg)}}
.banner-text h2{font-family:'DM Serif Display',serif;font-size:14px;color:var(--text);margin-bottom:2px;line-height:1.25}
.banner-text p{font-size:11px;color:var(--text-mid);line-height:1.4}
.banner-streak{flex-shrink:0;background:var(--white);border-radius:var(--r-md);padding:8px 12px;text-align:center;border:1.5px solid rgba(242,167,184,.25)}
.banner-streak .snum{font-family:'DM Serif Display',serif;font-size:18px;color:var(--rose-deep);display:block;line-height:1}
.banner-streak .slabel{font-size:9px;color:var(--text-soft);font-weight:700;letter-spacing:.5px}

/* ── KPI ROW ── */
.kpi-row{display:flex;gap:10px;overflow-x:auto;padding:0 14px 4px;scrollbar-width:none;-webkit-overflow-scrolling:touch}
.kpi-row::-webkit-scrollbar{display:none}
.kpi-card{flex-shrink:0;width:148px;background:var(--white);border-radius:var(--r-lg);padding:14px 14px 12px;border:1.5px solid var(--nude);box-shadow:var(--sh-soft)}
.kpi-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.kpi-icon{width:32px;height:32px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:15px}
.kpi-icon.rose{background:var(--blush)}.kpi-icon.lav{background:#EDE4F5}.kpi-icon.mint{background:#E0F5EC}.kpi-icon.peach{background:#FEEEE9}
.kpi-badge{font-size:10px;font-weight:700;padding:2px 7px;border-radius:20px}
.kpi-badge.up{background:#E0F5EC;color:var(--mint-deep)}.kpi-badge.same{background:var(--nude);color:var(--text-soft)}
.kpi-value{font-family:'DM Serif Display',serif;font-size:24px;color:var(--text);line-height:1;margin-bottom:2px}
.kpi-label{font-size:11px;color:var(--text-soft);font-weight:500}
.kpi-sub{font-size:10px;color:var(--text-soft);margin-top:6px;padding-top:7px;border-top:1.5px solid var(--nude);line-height:1.4}

/* ── CARD ── */
.card{background:var(--white);border-radius:var(--r-xl);border:1.5px solid var(--nude);box-shadow:var(--sh-soft);overflow:hidden}
.card-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 12px;border-bottom:1.5px solid var(--nude)}
.card-title{font-family:'DM Serif Display',serif;font-size:15px;color:var(--text)}
.card-title em{color:var(--rose-deep);font-style:italic}
.card-action{font-size:11px;font-weight:600;color:var(--rose-deep);background:var(--blush);padding:5px 12px;border-radius:20px;cursor:pointer;white-space:nowrap;border:none}
.card-action:active{background:var(--rose);color:var(--white)}

/* ── STATUS ── */
.status-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:12px}
.status-pill{background:var(--nude);border-radius:var(--r-md);padding:11px 12px;display:flex;align-items:center;gap:8px;cursor:pointer}
.status-pill:active{background:var(--blush)}
.sp-emoji{font-size:18px}
.sp-num{font-family:'DM Serif Display',serif;font-size:20px;color:var(--text);line-height:1}
.sp-label{font-size:9px;color:var(--text-soft);font-weight:700;letter-spacing:.4px}

/* ── FILTER SECTION (date tabs + period chips) ── */
.filter-section{padding:10px 14px 0;display:flex;flex-direction:column;gap:8px}
.date-tabs{display:flex;background:var(--nude);border-radius:var(--r-md);padding:3px}
.date-tab{flex:1;text-align:center;padding:7px 0;font-size:12px;font-weight:600;color:var(--text-soft);border-radius:calc(var(--r-md) - 3px);cursor:pointer;transition:all .18s;user-select:none}
.date-tab.active{background:var(--white);color:var(--rose-deep);box-shadow:var(--sh-soft)}
.chips-row{display:flex;gap:6px;overflow-x:auto;scrollbar-width:none}
.chips-row::-webkit-scrollbar{display:none}
.chip{flex-shrink:0;padding:5px 12px;border-radius:20px;font-size:11px;font-weight:600;border:1.5px solid var(--nude);background:var(--white);color:var(--text-mid);cursor:pointer;transition:all .15s;user-select:none;white-space:nowrap}
.chip.active{background:var(--blush);border-color:var(--rose);color:var(--rose-deep)}
.chip:active{transform:scale(.95)}

/* ── DAY NAV (agenda dia) ── */
.day-nav{display:flex;align-items:center;justify-content:space-between;padding:10px 14px 0}
.day-nav-btn{width:32px;height:32px;border-radius:10px;border:1.5px solid var(--nude);background:var(--white);color:var(--rose-deep);font-size:16px;cursor:pointer;flex-shrink:0}
.day-nav-btn:active{background:var(--blush)}
.day-nav-label{font-size:13px;font-weight:700;color:var(--text);text-transform:capitalize}

/* ── CALENDAR (agenda mês) ── */
.cal-nav{display:flex;align-items:center;justify-content:space-between;padding:10px 14px 0}
.cal-weekdays{display:grid;grid-template-columns:repeat(7,1fr);padding:10px 14px 0;text-align:center}
.cal-weekdays span{font-size:10px;font-weight:700;color:var(--text-soft)}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;padding:8px 12px 14px}
.cal-day{aspect-ratio:1;border-radius:12px;border:1.5px solid var(--nude);background:var(--white);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;cursor:pointer;font-size:12px;color:var(--text);position:relative}
.cal-day:active{background:var(--blush)}
.cal-day.empty{border:none;cursor:default;background:transparent}
.cal-day.today{border-color:var(--rose-deep);font-weight:700}
.cal-day.selected{background:var(--rose-deep);border-color:var(--rose-deep);color:var(--white)}
.cal-day-dot{width:5px;height:5px;border-radius:50%;background:var(--rose-deep)}
.cal-day.selected .cal-day-dot{background:var(--white)}
.cal-day-count{font-size:8px;color:var(--text-soft)}
.cal-day.selected .cal-day-count{color:rgba(255,255,255,.8)}

/* ── APPT LIST ── */
.appt-list{padding:8px 12px 12px;display:flex;flex-direction:column;gap:7px}
.appt-item{display:flex;align-items:center;gap:10px;padding:11px 12px;border-radius:var(--r-md);border:1.5px solid var(--nude);background:var(--white);cursor:pointer;position:relative;overflow:hidden}
.appt-item::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;border-radius:4px 0 0 4px}
.appt-item.s-done::before{background:#A98FD8}
.appt-item.s-inprog::before{background:#4D8FD8}
.appt-item.s-confirm::before{background:#5DB896}
.appt-item.s-waiting::before{background:#D8A820}
.appt-item.s-cancel::before{background:#D86050}
.appt-item:active{background:var(--nude)}
.appt-time-col{text-align:center;width:40px;flex-shrink:0}
.appt-time{font-size:12px;font-weight:700;color:var(--text)}
.appt-dur{font-size:10px;color:var(--text-soft)}
.appt-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}
.appt-dot.done{background:#A98FD8}.appt-dot.inprog{background:#4D8FD8}.appt-dot.confirm{background:#5DB896}.appt-dot.waiting{background:#D8A820}.appt-dot.cancel{background:#D86050}
.appt-info{flex:1;min-width:0}
.appt-client{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.appt-service{font-size:11px;color:var(--text-mid);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.appt-status-tag{flex-shrink:0;font-size:10px;font-weight:700;padding:3px 8px;border-radius:20px;border:none;cursor:pointer}
.appt-delete-btn{flex-shrink:0;width:26px;height:26px;border:none;background:none;font-size:13px;cursor:pointer;opacity:.6}
.appt-delete-btn:active{opacity:1}
.tag-done{background:#EDE4F5;color:#7044C8}.tag-inprog{background:#E0EDFA;color:#2561A8}
.tag-confirm{background:#E0F5EC;color:#2D7A50}.tag-waiting{background:#FFF4E0;color:#9A6A00}
.tag-cancel{background:#FDEAE8;color:#C83424}

/* ── TEAM ── */
.team-list{padding:8px 12px 12px;display:flex;flex-direction:column;gap:7px}
.team-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--r-md);background:var(--nude);cursor:pointer}
.team-item:active{background:var(--blush)}
.team-av{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:var(--white);flex-shrink:0}
.team-online{width:9px;height:9px;border-radius:50%;border:2px solid var(--white);flex-shrink:0}
.team-name{font-size:13px;font-weight:600;color:var(--text)}
.team-role{font-size:11px;color:var(--text-soft)}
.team-count{margin-left:auto;flex-shrink:0;font-size:11px;font-weight:700;color:var(--rose-deep);background:var(--blush);padding:3px 9px;border-radius:20px}

/* ── META / PROGRESS ── */
.meta-section{padding:12px 16px 16px;display:flex;flex-direction:column;gap:14px}
.meta-lbl{font-size:11px;color:var(--text-soft);font-weight:500;margin-bottom:5px}
.meta-header{display:flex;align-items:baseline;gap:5px;margin-bottom:7px}
.meta-val{font-family:'DM Serif Display',serif;font-size:22px;color:var(--text);line-height:1}
.meta-of{font-size:12px;color:var(--text-soft)}
.prog-bar{height:9px;background:var(--nude);border-radius:20px;overflow:hidden;margin-bottom:4px}
.prog-fill{height:100%;border-radius:20px;background:linear-gradient(to right,var(--rose),var(--lav-deep));position:relative;overflow:hidden;transition:width 1s ease}
.prog-fill::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.35),transparent);animation:shim 2s infinite}
@keyframes shim{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}
.prog-pct{font-size:11px;font-weight:700;color:var(--rose-deep)}

/* ── CLIENTES ── */
.search-bar{display:flex;align-items:center;gap:9px;background:var(--white);border:1.5px solid var(--nude);border-radius:var(--r-md);padding:0 14px;margin:14px 14px 0;height:44px;box-shadow:var(--sh-soft)}
.search-bar input{flex:1;border:none;outline:none;background:transparent;font-family:'DM Sans',sans-serif;font-size:13px;color:var(--text)}
.search-bar input::placeholder{color:var(--text-soft)}
.client-list{padding:10px 14px;display:flex;flex-direction:column;gap:8px}
.client-item{display:flex;align-items:center;gap:11px;padding:13px 14px;background:var(--white);border-radius:var(--r-lg);border:1.5px solid var(--nude);box-shadow:var(--sh-soft);cursor:pointer}
.client-item:active{background:var(--nude)}
.cli-av{width:42px;height:42px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:700;color:var(--white)}
.cli-name{font-size:14px;font-weight:600;color:var(--text)}
.cli-last{font-size:10px;color:var(--text-soft)}
.cli-service{font-size:11px;color:var(--text-mid)}
.cli-spent{font-family:'DM Serif Display',serif;font-size:15px;color:var(--rose-deep)}
.cli-visits{font-size:10px;color:var(--text-soft);text-align:right}
.cli-delete-btn{flex-shrink:0;width:26px;height:26px;border:none;background:none;font-size:13px;cursor:pointer;opacity:.6}
.cli-delete-btn:active{opacity:1}

/* ── FINANCEIRO ── */
.fin-hero{margin:14px 14px 0;background:linear-gradient(135deg,var(--rose-deep),var(--lav-deep));border-radius:var(--r-xl);padding:20px 20px 18px;color:var(--white);box-shadow:var(--sh-float)}
.fin-hero-lbl{font-size:11px;opacity:.8;margin-bottom:4px}
.fin-hero-val{font-family:'DM Serif Display',serif;font-size:32px;line-height:1;margin-bottom:14px}
.fin-hero-row{display:flex;gap:10px}
.fin-mini{flex:1;background:rgba(255,255,255,.18);border-radius:var(--r-md);padding:9px 10px}
.fin-mini-lbl{font-size:9px;opacity:.8}
.fin-mini-val{font-size:16px;font-weight:700}
.pay-list{padding:8px 12px 12px;display:flex;flex-direction:column;gap:7px}
.pay-item{display:flex;align-items:center;gap:10px;padding:11px 12px;border-radius:var(--r-md);background:var(--nude);cursor:pointer}
.pay-item:active{background:var(--blush)}
.pay-icon{width:34px;height:34px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.pay-name{font-size:13px;font-weight:600;color:var(--text)}
.pay-desc{font-size:11px;color:var(--text-soft)}
.pay-amount{margin-left:auto;font-size:14px;font-weight:700;color:var(--mint-deep)}
.pay-amount.out{color:var(--coral)}

/* ── PERIOD FILTER BAR (for financeiro) ── */
.fin-filter{padding:12px 14px 0}
.fin-filter-label{font-size:10px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--text-soft);margin-bottom:6px}

/* ── EMPTY / LOADING ── */
.empty-state{text-align:center;padding:24px 16px;font-size:13px;color:var(--text-soft)}

/* ── NOTIFICAÇÕES ── */
.notif-item{display:flex;align-items:flex-start;gap:9px;padding:11px 14px;font-size:11px;line-height:1.5;border-bottom:1px solid var(--nude);cursor:pointer}
.notif-item:last-child{border-bottom:none}
.notif-item:active{background:var(--blush)}
.notif-icon{font-size:15px;flex-shrink:0}
.notif-text strong{display:block;font-weight:700;margin-bottom:1px;font-size:12px;color:var(--text)}
.notif-text span{color:var(--text-mid)}

/* ── LOGIN ── */
.login-screen{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:24px;background:linear-gradient(160deg,var(--blush) 0%,var(--cream) 55%)}
.login-card{width:100%;max-width:340px;background:var(--white);border-radius:var(--r-xl);box-shadow:var(--sh-float);padding:32px 26px;text-align:center}
.login-card img{height:56px;margin-bottom:18px}
.login-card h1{font-family:'DM Serif Display',serif;font-size:19px;margin-bottom:4px}
.login-card p{font-size:12px;color:var(--text-soft);margin-bottom:22px}
.login-form{display:flex;flex-direction:column;gap:12px;text-align:left}
.form-label{font-size:11px;font-weight:700;color:var(--text-mid);margin-bottom:5px;display:block}
.form-input,.form-select{width:100%;border:1.5px solid var(--nude);background:var(--cream);border-radius:var(--r-md);padding:11px 13px;font-size:14px;font-family:'DM Sans',sans-serif;color:var(--text);outline:none}
.form-input:focus,.form-select:focus{border-color:var(--rose)}
.form-btn{margin-top:6px;background:linear-gradient(135deg,var(--rose-deep),var(--lav-deep));color:var(--white);border:none;border-radius:var(--r-md);padding:13px;font-size:14px;font-weight:700;font-family:'DM Sans',sans-serif;cursor:pointer}
.form-btn:active{opacity:.85}
.form-error{font-size:12px;color:#C83424;min-height:16px;text-align:center}
.login-hint{margin-top:16px;font-size:10px;color:var(--text-soft);line-height:1.5}

/* ── MODAL ── */
.modal-overlay{position:fixed;inset:0;background:rgba(58,45,53,.45);display:none;align-items:flex-end;justify-content:center;z-index:500}
.modal-overlay.active{display:flex}
.modal{width:100%;max-width:480px;background:var(--white);border-radius:24px 24px 0 0;padding:20px 20px calc(20px + env(safe-area-inset-bottom));max-height:88vh;overflow-y:auto;animation:slideUp .25s ease both}
@keyframes slideUp{from{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}
.modal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.modal-title{font-family:'DM Serif Display',serif;font-size:17px}
.modal-close{width:32px;height:32px;border-radius:10px;border:1.5px solid var(--nude);background:var(--white);font-size:15px;cursor:pointer;color:var(--text-soft)}
.form-group{display:flex;flex-direction:column;gap:12px}
.form-row{display:flex;gap:10px}
.form-row .form-group-item{flex:1}

/* ── ANIMATIONS ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.card,.banner{animation:fadeUp .35s ease both}
.card:nth-child(2){animation-delay:.05s}.card:nth-child(3){animation-delay:.1s}.card:nth-child(4){animation-delay:.15s}.card:nth-child(5){animation-delay:.2s}

::-webkit-scrollbar{width:4px}::-webkit-scrollbar-thumb{background:var(--rose);border-radius:10px}
