:root{--green:#008f6b;--green2:#047857;--soft:#e7f8f2;--slate:#0f172a;--muted:#64748b;--line:#e5e7eb;--bg:#f8fafc;--blue:#2878d8;--orange:#f59e0b;--red:#ef4444;--purple:#7c3aed}*{box-sizing:border-box}body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;background:var(--bg);color:var(--slate)}a{text-decoration:none;color:inherit}button,input,select,textarea{font:inherit}.auth-shell{min-height:100vh;display:grid;grid-template-columns:1.05fr .95fr;background:white}.auth-hero{padding:56px 64px;background:linear-gradient(135deg,#ecfdf5,#fff,#f8fafc);position:relative;overflow:hidden}.brand{display:flex;align-items:center;gap:12px}.brand-mark{width:46px;height:46px;border-radius:18px;background:#dff8ef;color:var(--green);display:grid;place-items:center;font-weight:900}.brand-title{font-size:32px;font-weight:900;color:var(--green2);letter-spacing:-1px}.brand-sub{margin-top:-5px;font-size:18px;font-weight:700;color:#059669}.hero-copy{max-width:620px;margin-top:90px}.hero-copy h1{font-size:54px;line-height:1.02;margin:0;letter-spacing:-2px}.hero-copy h1 span{color:var(--green2)}.hero-copy p{font-size:18px;line-height:1.7;color:var(--muted)}.feature{display:flex;gap:16px;background:rgba(255,255,255,.75);border:1px solid #fff;border-radius:28px;padding:18px;margin-top:16px;box-shadow:0 16px 44px rgba(15,23,42,.05)}.feature-icon,.iconbox{width:48px;height:48px;border-radius:18px;background:var(--soft);color:var(--green);display:grid;place-items:center;flex:0 0 auto}.feature b{display:block;margin-bottom:4px}.auth-card-wrap{display:grid;place-items:center;padding:40px}.auth-card,.card{background:white;border:1px solid rgba(226,232,240,.9);border-radius:30px;box-shadow:0 18px 50px rgba(15,23,42,.06)}.auth-card{width:100%;max-width:530px;padding:42px}.auth-card h2{font-size:34px;margin:20px 0 5px;text-align:center}.muted{color:var(--muted)}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:14px;font-weight:800;margin-bottom:8px}.input{width:100%;border:1px solid var(--line);border-radius:18px;padding:14px 16px;background:white;outline:0}.input:focus{border-color:#34d399;box-shadow:0 0 0 4px #d1fae5}.btn{border:0;border-radius:18px;padding:13px 18px;font-weight:900;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer}.btn-primary{background:var(--green);color:white;box-shadow:0 12px 30px rgba(0,143,107,.18)}.btn-secondary{background:white;color:#334155;border:1px solid var(--line)}.btn-danger{background:#fff1f2;color:#e11d48;border:1px solid #fecdd3}.alert{padding:14px 16px;border-radius:18px;margin-bottom:16px}.alert-error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.alert-success{background:#ecfdf5;color:#065f46;border:1px solid #a7f3d0}.app{display:grid;grid-template-columns:280px 1fr;min-height:100vh}.sidebar{background:white;border-right:1px solid var(--line);padding:26px 20px;position:sticky;top:0;height:100vh}.nav{margin-top:34px;display:grid;gap:5px}.nav a{display:flex;align-items:center;gap:12px;padding:13px 14px;border-radius:18px;color:#475569;font-weight:800}.nav a.active,.nav a:hover{background:var(--soft);color:var(--green2)}.plan{margin-top:40px;padding:18px;border-radius:26px;background:linear-gradient(135deg,#fff,#ecfdf5);border:1px solid #d1fae5}.main{min-width:0}.topbar{height:76px;background:rgba(255,255,255,.9);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;padding:0 26px;position:sticky;top:0;z-index:5}.search{width:420px;max-width:48vw}.userbox{display:flex;align-items:center;gap:12px}.avatar{width:42px;height:42px;border-radius:50%;background:#d1fae5;color:var(--green2);display:grid;place-items:center;font-weight:900}.content{padding:26px}.page-head{display:flex;justify-content:space-between;gap:18px;align-items:flex-end;margin-bottom:22px}.page-head h1{font-size:34px;letter-spacing:-1px;margin:0}.actions{display:flex;flex-wrap:wrap;gap:10px}.grid{display:grid;gap:18px}.kpis{grid-template-columns:repeat(5,minmax(0,1fr))}.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.card{padding:22px}.metric .big{font-size:34px;font-weight:950;margin:8px 0}.metric .label{font-size:14px;font-weight:800;color:#64748b}.pill{display:inline-flex;align-items:center;border-radius:999px;padding:5px 10px;font-size:12px;font-weight:900;border:1px solid}.pill.green{background:#ecfdf5;color:#047857;border-color:#bbf7d0}.pill.blue{background:#eff6ff;color:#1d4ed8;border-color:#bfdbfe}.pill.orange{background:#fffbeb;color:#b45309;border-color:#fde68a}.pill.red{background:#fef2f2;color:#dc2626;border-color:#fecaca}.pill.purple{background:#f5f3ff;color:#6d28d9;border-color:#ddd6fe}.pill.gray{background:#f8fafc;color:#64748b;border-color:#e2e8f0}.table-wrap{overflow:auto}.table{width:100%;border-collapse:collapse;font-size:14px}.table th{text-align:left;font-size:12px;color:#64748b;text-transform:uppercase;letter-spacing:.04em;padding:12px}.table td{padding:14px 12px;border-top:1px solid #eef2f7;color:#334155;vertical-align:top}.table td strong{color:#0f172a}.visit-row{display:flex;align-items:center;gap:14px;border:1px solid #eef2f7;border-radius:22px;padding:14px;margin-top:12px;background:white}.dot{width:10px;height:10px;border-radius:50%}.dot.green{background:var(--green)}.dot.blue{background:var(--blue)}.dot.orange{background:var(--orange)}.dot.purple{background:var(--purple)}.dot.red{background:var(--red)}.fake-map{height:260px;border-radius:26px;background:linear-gradient(135deg,#dff8ef,#eef6ff,#fff);position:relative;overflow:hidden}.map-pin{position:absolute;width:36px;height:36px;border-radius:50%;background:var(--green);color:white;display:grid;place-items:center;font-weight:900;box-shadow:0 14px 30px rgba(4,120,87,.25)}.bars{display:grid;gap:12px}.bar-line{height:10px;background:#edf2f7;border-radius:99px;overflow:hidden}.bar-line>span{display:block;height:100%;background:var(--green);border-radius:99px}.agenda-grid{display:grid;grid-template-columns:80px repeat(7,1fr);border:1px solid #edf2f7;border-radius:26px;overflow:auto;background:white}.agenda-grid>div{border-right:1px solid #edf2f7;border-bottom:1px solid #edf2f7;min-height:72px;padding:9px;font-size:13px}.schedule-card{border-radius:16px;padding:9px;font-size:12px;font-weight:800}.schedule-card.green{background:#ecfdf5;color:#047857;border:1px solid #bbf7d0}.schedule-card.blue{background:#eff6ff;color:#1d4ed8;border:1px solid #bfdbfe}.schedule-card.orange{background:#fffbeb;color:#b45309;border:1px solid #fde68a}.schedule-card.purple{background:#f5f3ff;color:#6d28d9;border:1px solid #ddd6fe}.statline{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:12px 0}.photo-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.photo-tile{height:86px;border-radius:18px;background:linear-gradient(135deg,#e2e8f0,#f8fafc);display:grid;place-items:center;color:#94a3b8}.split{display:grid;grid-template-columns:1.1fr .9fr;gap:18px}.client-shell{display:grid;grid-template-columns:240px 1fr;min-height:100vh}.client-shell .sidebar{height:100vh}.timeline{display:flex;justify-content:space-between;border-top:3px solid #e2e8f0;padding-top:22px;gap:14px}.mobile-hide{display:inherit}@media(max-width:1050px){.app,.client-shell{grid-template-columns:1fr}.sidebar{position:relative;height:auto}.kpis,.cols-4,.cols-3,.cols-2,.split{grid-template-columns:1fr}.search{display:none}.auth-shell{grid-template-columns:1fr}.auth-hero{display:none}.page-head{display:block}.actions{margin-top:14px}.timeline{display:grid}.mobile-hide{display:none}}
