:root{--blue:#2147b7;--blue-dark:#173a9d;--blue-soft:#edf2ff;--ink:#303a59;--muted:#8492aa;--line:#e4e8ef;--surface:#fff;--background:#f3f6f9;--sidebar:250px;--shadow:0 10px 24px rgba(35,58,111,.07)}
*{box-sizing:border-box}
html{min-height:100%}
body{margin:0;min-height:100vh;background:var(--background);color:var(--ink);font-family:"Segoe UI",Arial,sans-serif;font-size:14px}
a{color:inherit}
button,input,select,textarea{font:inherit}
.app-shell{min-height:100vh}
.sidebar{position:fixed;inset:0 auto 0 0;width:var(--sidebar);z-index:20;background:#fff;border-right:1px solid #edf0f5;overflow-y:auto}
.brand{height:80px;display:flex;align-items:center;padding:12px 10px;text-decoration:none;border-bottom:1px solid #f0f2f6}
.brand img{display:block;width:84px;height:auto;object-fit:contain}
.sidebar-toggle{position:absolute;right:20px;top:34px;width:18px;display:grid;gap:3px}
.sidebar-toggle i{display:block;height:2px;background:#7b8ba5;border-radius:2px}
.nav{padding:0 0 26px;margin-top:0}
.nav-link{min-height:39px;display:flex;align-items:center;gap:12px;padding:8px 18px;color:#171a22;text-decoration:none;border-radius:0 4px 4px 0;transition:.15s ease}
.nav-link:hover{background:#f3f6ff;color:var(--blue)}
.nav-link.active{background:var(--blue);color:#fff;font-weight:600}
.nav-icon{width:18px;flex:0 0 18px;color:var(--blue);font-size:9px;font-weight:800;text-align:center;letter-spacing:-.4px}
.nav-link.active .nav-icon{color:#fff}
.main{min-height:100vh;margin-left:var(--sidebar);display:flex;flex-direction:column}
.topbar{height:122px;display:flex;align-items:flex-start;justify-content:space-between;padding:15px 16px 0 27px;background:var(--blue);color:#fff;border-bottom:1px solid rgba(255,255,255,.12)}
.home-button{width:42px;height:42px;display:grid;place-items:center;border-radius:5px}
.home-button:hover{background:rgba(255,255,255,.1)}
.home-button img{width:34px;height:34px;object-fit:contain}
.topbar-user{display:flex;align-items:center;gap:8px}
.avatar{width:34px;height:34px;display:grid;place-items:center;border:3px solid rgba(255,255,255,.88);border-radius:50%;background:#ffbd45;color:#173a9d;font-weight:800}
.user-copy{display:grid;line-height:1.15}.user-copy strong{font-size:13px}.user-copy small{font-size:10px;color:#dbe4ff}
.topbar-user form{margin:0}.topbar-logout{border:0;background:transparent;color:#fff;padding:8px;cursor:pointer;font-weight:600}.topbar-logout:hover{text-decoration:underline}
.content{position:relative;z-index:2;flex:1;margin-top:-42px;padding:0 15px 12px}
footer{padding:10px 15px 32px;color:var(--blue);font-size:12px;font-weight:600}
.dashboard-stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:35px}
.dashboard-stat{min-height:103px;padding:16px 20px;background:#fff;border-radius:5px;box-shadow:var(--shadow);display:flex;justify-content:space-between;gap:12px}
.dashboard-stat>div{display:flex;flex-direction:column}.dashboard-stat span:first-child{text-transform:uppercase;color:#8090aa;font-size:11px;font-weight:700}.dashboard-stat strong{font-size:17px;margin:4px 0 16px}.dashboard-stat small{color:#365ecb;font-size:12px}
.stat-icon{width:43px;height:43px;flex:0 0 43px;display:grid;place-items:center;border-radius:50%;color:#fff!important;font-size:14px!important;font-weight:800}
.patients .stat-icon{background:#f25229}.doctors .stat-icon{background:#ffc528}.appointments .stat-icon{background:#32bf96}.revenue .stat-icon{background:#45afbe}
.dashboard-grid{display:grid;grid-template-columns:minmax(0,2fr) minmax(330px,1fr);gap:15px}
.dashboard-panel,.card{background:#fff;border-radius:7px;box-shadow:var(--shadow)}
.dashboard-panel{min-height:455px;overflow:hidden}
.panel-header{min-height:75px;display:flex;align-items:center;justify-content:space-between;gap:15px;padding:16px;border-bottom:1px solid var(--line)}
.panel-kicker,.eyebrow{text-transform:uppercase;color:#8ba0b7;font-size:10px;font-weight:800;letter-spacing:.02em}
.panel-header h1,.panel-header h2{margin:6px 0 0;font-size:17px;color:#3c4667}.panel-actions{display:flex;gap:7px}.period-tag{align-self:flex-end;margin-bottom:5px;padding:5px 8px;border-radius:4px;background:#eef1f8;color:var(--blue);font-size:10px;font-weight:800}
.appointment-content{min-height:378px}.panel-empty{min-height:378px;display:grid;place-content:center;text-align:center;gap:6px;color:#4d5879}.panel-empty span{color:#96a1b3;font-size:12px}.appointment-list{padding:8px 16px}.appointment-row{display:grid;grid-template-columns:60px 1fr auto;align-items:center;gap:15px;padding:14px 4px;border-bottom:1px solid var(--line)}.appointment-row time{font-weight:800;color:var(--blue)}.appointment-row>span:nth-child(2){display:grid}.appointment-row small{color:var(--muted);margin-top:3px}
.weekly-chart{height:350px;display:flex;align-items:flex-end;gap:10px;padding:42px 20px 30px;background:repeating-linear-gradient(to bottom,transparent 0,transparent 57px,#e6e9ee 58px,#e6e9ee 59px)}
.chart-column{height:100%;flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:7px}.chart-value{font-size:10px;color:var(--muted)}.chart-bar{position:relative;width:16px;height:250px;background:#f1f3f7;border-radius:6px;overflow:hidden}.chart-bar i{position:absolute;left:0;right:0;bottom:0;min-height:2px;background:var(--blue);border-radius:6px}.chart-column small{font-size:9px;color:#7d89a0;font-weight:700}
.button{display:inline-flex;align-items:center;justify-content:center;min-height:38px;padding:9px 15px;border:1px solid transparent;border-radius:5px;text-decoration:none;font-weight:700;cursor:pointer}.button-primary{background:var(--blue);color:#fff;box-shadow:0 4px 8px rgba(33,71,183,.2)}.button-primary:hover{background:var(--blue-dark)}.button-secondary{background:#fff;color:var(--blue);border-color:#cad4ee}.button-small{min-height:31px;padding:7px 11px;font-size:11px}.button-block{width:100%}
.card{padding:20px;margin:0}.section-heading{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;margin-bottom:20px}.section-heading.compact{margin-bottom:18px}.section-heading h1,.section-heading h2{margin:5px 0;color:#303a59}.section-heading p{margin:5px 0 0;color:var(--muted)}
.search-bar{display:flex;gap:8px;margin-bottom:18px}.search-bar input{flex:1}
.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse}th,td{padding:13px 12px;border-bottom:1px solid var(--line);text-align:left}th{background:#f8f9fc;color:#74839d;text-transform:uppercase;font-size:10px}td{color:#3e4967}.align-right{text-align:right}.table-subtitle{display:block;color:var(--muted);margin-top:3px}.empty-state{text-align:center!important;padding:40px!important;color:var(--muted)}
.tag,.status{display:inline-flex;padding:5px 8px;border-radius:20px;background:#eef2fa;color:#52627d;font-size:11px;font-weight:700}.status-success,.status-aceito,.status-confirmado,.status-finalizado{background:#e4f8f0;color:#138663}.status-muted,.status-revogado,.status-cancelado{background:#f2f3f6;color:#747f91}.status-pendente,.status-agendado{background:#fff5d9;color:#9a6b00}
.link-button{border:0;background:transparent;color:var(--blue);padding:4px;cursor:pointer;font-weight:700}
.table-actions{display:inline-flex;align-items:center;justify-content:flex-end;gap:10px}.table-actions form{margin:0}.icon-button{width:34px;height:34px;display:inline-grid;place-items:center;border:1px solid #cad4ee;border-radius:8px;background:#fff;color:var(--blue);text-decoration:none;transition:.15s ease}.icon-button svg{width:18px;height:18px;fill:currentColor}.icon-button:hover{background:var(--blue);border-color:var(--blue);color:#fff;box-shadow:0 4px 10px rgba(33,71,183,.18)}
.form-card{max-width:940px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}.form-stack{display:grid;gap:16px}.field{display:grid;gap:7px}.field-span-2{grid-column:span 2}.field label{font-weight:700;color:#45516f}.optional-label{color:var(--muted);font-size:11px;font-weight:600}.field input,.field select,.field textarea,.search-bar input{width:100%;min-height:42px;padding:10px 12px;border:1px solid #d7deea;border-radius:5px;background:#fff;color:var(--ink);outline:none}.field input:focus,.field select:focus,.search-bar input:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(33,71,183,.1)}.field-error{color:#b42318}.field-hint{color:var(--muted)}.form-actions{padding-top:6px}
.module-placeholder{min-height:390px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}.module-placeholder h1{font-size:28px;margin:8px}.module-placeholder p{color:var(--muted)}.development-note{max-width:540px;margin-top:20px;padding:18px;background:var(--blue-soft);border-radius:6px;display:grid;gap:5px;color:var(--blue)}
.alert{margin-bottom:14px;padding:12px 15px;border-radius:5px;font-weight:600}.alert-success{background:#e4f8f0;color:#137859}.alert-error{background:#ffebe8;color:#a73326}
.auth-body{display:grid;place-items:center;padding:30px;background:linear-gradient(135deg,#173a9d,#2b57ca)}.auth-shell{width:min(920px,100%);display:grid;grid-template-columns:1.15fr .85fr;background:#fff;border-radius:10px;overflow:hidden;box-shadow:0 25px 70px rgba(11,31,91,.35)}.auth-intro{padding:60px;background:#f5f7fc}.auth-intro h1{max-width:420px;font-size:38px;line-height:1.1;margin:13px 0}.auth-intro p{color:#72809a}.brand-mark{width:42px;height:42px;display:grid;place-items:center;background:var(--blue);border-radius:7px;color:#fff;font-size:22px;font-weight:800}.brand-mark-large{width:56px;height:56px}.auth-card{padding:55px 42px;align-self:center}.auth-card h2{font-size:25px}
.error-body{display:grid;place-items:center;padding:30px}.error-card{max-width:550px;padding:40px;background:#fff;border-radius:8px;box-shadow:var(--shadow)}.error-card pre{white-space:pre-wrap;padding:12px;background:#f5f6f8;border-radius:5px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
@media(max-width:1150px){.dashboard-stats{grid-template-columns:repeat(2,1fr)}.dashboard-grid{grid-template-columns:1fr}.weekly-panel{min-height:390px}}
@media(max-width:760px){:root{--sidebar:100%}.sidebar{position:relative;width:100%;height:auto}.brand{height:70px}.nav{display:flex;overflow-x:auto;padding:0}.nav-link{flex:0 0 auto;border-radius:0}.sidebar-toggle{display:none}.main{margin-left:0}.topbar{height:90px}.content{margin-top:-26px;padding:0 14px 14px}.dashboard-stats{grid-template-columns:1fr}.panel-header,.section-heading{align-items:flex-start;flex-direction:column}.panel-actions{width:100%;flex-wrap:wrap}.dashboard-panel{min-height:390px}.form-grid{grid-template-columns:1fr}.field-span-2{grid-column:span 1}.auth-shell{grid-template-columns:1fr}.auth-intro{display:none}.auth-card{padding:35px 25px}.user-copy{display:none}}
.button[disabled]{opacity:.72;cursor:not-allowed;box-shadow:none}.appointment-filters{margin-bottom:15px}.appointment-filters form{display:grid;gap:18px}.filters-title,.appointment-toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px}.filters-title strong{color:var(--blue)}.filters-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:15px}.appointment-workspace{padding:0;overflow:hidden}.appointment-toolbar{min-height:82px;padding:16px;border-bottom:1px solid var(--line)}.appointment-toolbar h1{margin:5px 0 0;font-size:18px}.appointment-buttons{display:flex;justify-content:flex-end;gap:8px;flex-wrap:wrap}.appointment-buttons .button{gap:8px}.segmented-actions,.view-tabs{display:flex;gap:7px;flex-wrap:wrap}.segmented-actions{margin-top:8px}.segmented-actions a,.view-tabs a{display:inline-flex;align-items:center;justify-content:center;min-height:30px;padding:6px 10px;border:1px solid var(--blue);border-radius:5px;color:var(--blue);text-decoration:none;font-size:11px;font-weight:800}.segmented-actions a.active,.view-tabs a.active{background:var(--blue);color:#fff}.view-tabs{padding:14px 16px;border-bottom:1px solid var(--line);background:#fbfcff}.appointment-table{min-height:315px}.appointment-table table{min-width:980px}.empty-state-danger{color:#f13b35!important;font-weight:800}.calendar-layout{display:grid;grid-template-columns:280px minmax(0,1fr);gap:18px;padding:16px}.slot-summary{display:grid;align-content:start;gap:10px;padding-right:14px;border-right:1px solid var(--line)}.slot-summary>strong{color:var(--blue);font-size:16px}.slot-summary>span{color:var(--muted);font-weight:700}.slot-counts{display:grid;grid-template-columns:1fr 1fr;gap:8px}.slot-counts span{padding:10px;border:1px solid var(--line);border-radius:6px;background:#f8fbff;color:#61708b;font-size:12px}.slot-counts b{display:block;color:var(--blue);font-size:20px}.slot-list{display:grid;gap:8px;max-height:420px;overflow:auto;padding-right:3px}.slot-chip{display:grid;gap:3px;padding:10px 11px;border-radius:6px;text-decoration:none;border:1px solid var(--line);background:#fff}.slot-chip strong{font-size:13px}.slot-chip span{font-size:12px;color:var(--muted)}.slot-free{border-color:#b9ead6;background:#f1fcf7;color:#106d4d}.slot-busy{border-color:#f4c6c6;background:#fff6f6;color:#a73636}.calendar-day{border:1px solid var(--line);border-radius:7px;overflow:hidden;background:#fff}.calendar-row{display:grid;grid-template-columns:72px minmax(0,1fr);min-height:58px;border-bottom:1px solid var(--line)}.calendar-row:last-child{border-bottom:0}.calendar-row time{padding:12px 10px;background:#f8f9fc;color:#7c8ba3;font-size:12px;font-weight:800;text-align:right}.calendar-cell{padding:7px 10px}.calendar-row.available .calendar-cell{background:#fbfffd}.calendar-row.busy .calendar-cell{background:#fffafa}.calendar-event{min-height:42px;display:grid;align-content:center;gap:2px;padding:8px 10px;border-radius:5px;text-decoration:none;border-left:4px solid}.calendar-event strong{font-size:13px}.calendar-event span{font-size:12px;color:#66738d}.calendar-event.free{border-color:#27a66f;background:#effbf5;color:#106d4d}.calendar-event.busy{border-color:var(--blue);background:#edf2ff;color:var(--blue)}.empty-note{margin:8px 0;color:var(--muted);font-weight:700}.appointment-form-screen{padding:0}.appointment-form-layout{display:grid;grid-template-columns:minmax(320px,.9fr) minmax(380px,1.1fr);gap:16px;padding:20px}.appointment-form-main,.appointment-form-side{display:grid;gap:16px;align-content:start}.two-columns{grid-template-columns:repeat(2,minmax(0,1fr));align-items:start}.two-columns>div{display:grid;gap:7px}.form-calendar{height:348px;overflow:auto;border:1px solid var(--line);border-radius:6px;background:#fff;padding:8px;display:grid;align-content:start;gap:7px}.form-slot{width:100%;display:grid;grid-template-columns:100px 1fr;gap:10px;align-items:center;min-height:42px;padding:8px 10px;border-radius:5px;border:1px solid var(--line);background:#fff;text-align:left;color:var(--ink);cursor:pointer}.form-slot strong{font-size:12px}.form-slot span{font-size:12px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.form-slot.free{border-color:#b9ead6;background:#f3fcf8}.form-slot.busy{background:#f7f8fb;color:#7c879b}.form-slot.selected{border-color:var(--blue);box-shadow:0 0 0 3px rgba(33,71,183,.12)}.form-slot[disabled]{cursor:not-allowed;opacity:.72}.info-box{min-height:40px;display:grid;place-items:center;padding:10px;border:1px solid #d7deea;border-radius:5px;color:#596681;font-size:12px;font-weight:700;text-align:center}.appointment-form-actions{grid-column:1/-1;display:flex;justify-content:flex-end;gap:8px;padding-top:4px}
@media(max-width:1100px){.filters-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.calendar-layout,.appointment-form-layout{grid-template-columns:1fr}.slot-summary{border-right:0;border-bottom:1px solid var(--line);padding:0 0 14px}.slot-list{max-height:220px}}
@media(max-width:760px){.filters-title,.appointment-toolbar{align-items:flex-start;flex-direction:column}.filters-grid,.two-columns{grid-template-columns:1fr}.appointment-buttons{width:100%;justify-content:flex-start}.appointment-buttons .button{flex:1 1 180px}.view-tabs{overflow-x:auto;flex-wrap:nowrap}.view-tabs a{flex:0 0 auto}.calendar-layout,.appointment-form-layout{padding:14px}.calendar-row{grid-template-columns:58px minmax(0,1fr)}.calendar-row time{font-size:11px;padding:12px 6px}.form-slot{grid-template-columns:86px 1fr}.appointment-form-actions{justify-content:stretch;flex-direction:column}.appointment-form-actions .button{width:100%}}
.appointment-action-list{display:inline-flex;justify-content:flex-end;gap:7px;flex-wrap:wrap}.slot-chip em,.calendar-event em{justify-self:start;display:inline-flex;align-items:center;min-height:24px;margin-top:4px;padding:3px 9px;border-radius:4px;background:var(--blue);color:#fff;font-style:normal;font-size:11px;font-weight:800}.slot-free em{background:#16865e}.calendar-event{grid-template-columns:minmax(0,1fr) auto}.calendar-event strong,.calendar-event span{min-width:0}.calendar-event em{grid-row:1/3;grid-column:2;align-self:center;margin:0}.medical-records-screen{overflow:hidden}.patient-summary{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-bottom:18px}.patient-summary div{padding:12px;border:1px solid var(--line);border-radius:6px;background:#f8fbff}.patient-summary span{display:block;color:var(--muted);font-size:11px;font-weight:800;text-transform:uppercase}.patient-summary strong{display:block;margin-top:5px;color:var(--ink);overflow-wrap:anywhere}.record-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.record-panel{border:1px solid var(--line);border-radius:7px;background:#fff;overflow:hidden}.record-panel-header{min-height:68px;padding:14px 16px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:12px}.record-panel-header h2{margin:5px 0 0;font-size:16px}.timeline-list{display:grid;gap:0}.timeline-item{display:grid;gap:4px;padding:14px 16px;border-bottom:1px solid var(--line);text-decoration:none}.timeline-item:last-child{border-bottom:0}.timeline-item time{color:var(--blue);font-weight:800;font-size:12px}.timeline-item strong{color:var(--ink)}.timeline-item span{color:var(--muted);line-height:1.35}.timeline-item em{justify-self:start;font-style:normal}.compact-empty{padding:28px!important}
@media(max-width:900px){.patient-summary,.record-grid{grid-template-columns:1fr}.record-panel-header{align-items:flex-start;flex-direction:column}}
@media(max-width:760px){.appointment-table table,.responsive-table{min-width:0}.appointment-table thead,.responsive-table thead{display:none}.appointment-table table,.appointment-table tbody,.appointment-table tr,.appointment-table td,.responsive-table,.responsive-table tbody,.responsive-table tr,.responsive-table td{display:block;width:100%}.appointment-table tr,.responsive-table tr{margin-bottom:12px;border:1px solid var(--line);border-radius:7px;background:#fff;box-shadow:0 5px 14px rgba(35,58,111,.05);overflow:hidden}.appointment-table td,.responsive-table td{display:grid;grid-template-columns:118px minmax(0,1fr);gap:10px;align-items:start;border-bottom:1px solid var(--line);padding:11px 12px;text-align:left!important}.appointment-table td:last-child,.responsive-table td:last-child{border-bottom:0}.appointment-table td::before,.responsive-table td::before{content:attr(data-label);color:#74839d;text-transform:uppercase;font-size:10px;font-weight:800}.appointment-action-list{justify-content:flex-start}.calendar-event{grid-template-columns:1fr}.calendar-event em{grid-row:auto;grid-column:auto;align-self:start;margin-top:4px}.patient-summary div{padding:10px}.record-panel-header .button{width:100%}}
