:root{--navy-950: #031a33;--navy-900: #062341;--navy-800: #0a3159;--navy-700: #0e4377;--cyan: #00b7c7;--cyan-dark: #0096a7;--green: #17b26a;--amber: #f59e0b;--red: #ef4444;--purple: #7c3aed;--ink: #0f213f;--muted: #60708a;--soft: #f5f8fb;--soft-2: #eef4f8;--line: #dce5ee;--card: #ffffff;--shadow: 0 18px 45px rgba(6, 35, 65, .1);--shadow-soft: 0 8px 24px rgba(6, 35, 65, .07);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}html,body,#root{min-height:100%;margin:0}body{background:var(--soft);color:var(--ink)}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}button{cursor:pointer}.app-shell{display:grid;grid-template-columns:252px minmax(0,1fr);min-height:100vh}.sidebar{background:linear-gradient(180deg,var(--navy-950),var(--navy-900) 60%,#021222);color:#fff;padding:26px 18px;display:flex;flex-direction:column;position:sticky;top:0;height:100vh}.brand{display:flex;align-items:center;gap:12px;margin-bottom:34px}.brand-mark{width:46px;height:46px;border:1px solid rgba(255,255,255,.2);border-radius:16px;display:grid;place-items:center;font-size:28px;background:#ffffff0f}.brand-text strong{display:block;font-size:22px;line-height:1;letter-spacing:-.04em}.brand-text span{display:block;font-size:18px;color:#ffffffd6}.nav-group-label{color:#ffffff73;text-transform:uppercase;letter-spacing:.12em;font-size:10px;font-weight:800;margin:14px 12px 10px}.nav-link{display:flex;align-items:center;gap:12px;color:#ffffffd1;padding:12px 14px;border-radius:14px;font-weight:650;font-size:14px;margin-bottom:5px;border:1px solid transparent;transition:.16s ease}.nav-link:hover{background:#ffffff14;color:#fff}.nav-link.active{background:#00b7c724;border-color:#00b7c73d;color:#fff;box-shadow:inset 3px 0 0 var(--cyan)}.nav-icon{width:24px;text-align:center;color:var(--cyan)}.sidebar-footer{margin-top:auto;border:1px solid rgba(255,255,255,.12);border-radius:16px;padding:13px 14px;display:flex;align-items:center;justify-content:space-between;color:#ffffffdb;font-size:13px}.main{min-width:0;display:flex;flex-direction:column}.topbar{height:74px;background:#ffffffdb;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border-bottom:1px solid var(--line);display:flex;align-items:center;gap:18px;padding:0 32px;position:sticky;top:0;z-index:10}.searchbox{flex:1;max-width:600px;position:relative}.searchbox input{width:100%;height:44px;border:1px solid var(--line);border-radius:14px;background:#fff;padding:0 16px 0 44px;outline:none;color:var(--ink)}.searchbox span{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:var(--muted)}.top-actions{margin-left:auto;display:flex;align-items:center;gap:18px}.notification{position:relative;width:42px;height:42px;border-radius:16px;display:grid;place-items:center;border:1px solid var(--line);background:#fff}.notification b{position:absolute;right:-3px;top:-6px;background:var(--cyan);color:#fff;width:20px;height:20px;border-radius:50%;display:grid;place-items:center;font-size:11px}.user-pill{display:flex;align-items:center;gap:12px}.avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--navy-950),var(--navy-700));color:#fff;display:grid;place-items:center;font-weight:800}.user-pill strong{display:block;font-size:14px}.user-pill small{display:block;color:var(--muted);font-size:12px}.signout{border:1px solid var(--line);background:#fff;color:var(--muted);border-radius:12px;height:38px;padding:0 12px}.content{padding:30px 34px}.page-head{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;margin-bottom:22px}.eyebrow{color:var(--cyan-dark);font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.12em;margin-bottom:8px}h1{font-size:34px;line-height:1.05;letter-spacing:-.05em;margin:0;color:var(--navy-950)}.sub{margin:9px 0 0;color:var(--muted);max-width:760px}.btn{height:42px;padding:0 16px;border-radius:13px;border:1px solid transparent;display:inline-flex;align-items:center;gap:9px;font-weight:800;font-size:13px;transition:.14s ease}.btn-primary{background:linear-gradient(135deg,var(--navy-950),var(--navy-800));color:#fff;box-shadow:var(--shadow-soft)}.btn-primary:hover{transform:translateY(-1px);box-shadow:var(--shadow)}.btn-secondary{background:#fff;border-color:var(--line);color:var(--navy-900)}.btn-secondary:hover{border-color:var(--cyan);color:var(--cyan-dark)}.btn-green{background:var(--green);color:#fff}.btn-ghost{background:transparent;color:var(--muted);border-color:transparent}.card{background:var(--card);border:1px solid var(--line);border-radius:22px;box-shadow:var(--shadow-soft)}.card-pad{padding:22px}.card-title{font-weight:850;color:var(--navy-950);margin:0 0 8px}.muted{color:var(--muted)}.grid{display:grid;gap:20px}.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}.tabs{background:#fff;border:1px solid var(--line);border-radius:22px;overflow:hidden}.tabs-row{display:flex;gap:4px;padding:8px 12px 0;border-bottom:1px solid var(--line);overflow-x:auto}.tab{background:transparent;border:0;padding:16px 18px;font-weight:800;color:var(--muted);border-bottom:3px solid transparent;white-space:nowrap}.tab.active{color:var(--navy-950);border-bottom-color:var(--cyan)}.filter-row{padding:18px;display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:12px;border-bottom:1px solid var(--line)}.field label{display:block;font-size:12px;color:var(--muted);font-weight:750;margin-bottom:6px}.input,.select,.textarea{width:100%;border:1px solid var(--line);border-radius:13px;background:#fff;min-height:42px;padding:0 12px;outline:none;color:var(--ink)}.textarea{min-height:100px;padding:12px;resize:vertical}.input:focus,.select:focus,.textarea:focus{border-color:var(--cyan);box-shadow:0 0 0 4px #00b7c71f}.project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:22px}.project-card{overflow:hidden;transition:.18s ease;cursor:pointer}.project-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:#00b7c773}.project-image{height:210px;position:relative;overflow:hidden;background:linear-gradient(135deg,#082340,#155d8f)}.project-image img{width:100%;height:100%;object-fit:cover;display:block;transition:.35s ease}.project-card:hover .project-image img{transform:scale(1.05)}.project-placeholder{height:100%;display:grid;place-items:center;color:#ffffffa6;font-size:58px;background:radial-gradient(circle at 80% 20%,rgba(0,183,199,.34),transparent 28%),linear-gradient(135deg,#082340,#155d8f)}.favorite{position:absolute;right:14px;top:14px;width:40px;height:40px;border-radius:50%;border:1px solid rgba(255,255,255,.34);background:#031a3373;color:#fff;display:grid;place-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.badges{display:flex;flex-wrap:wrap;gap:7px}.badge{display:inline-flex;align-items:center;gap:5px;height:26px;padding:0 10px;border-radius:999px;font-size:11px;font-weight:850}.badge-cyan{background:#00b7c71f;color:var(--cyan-dark)}.badge-green{background:#17b26a1f;color:#087443}.badge-purple{background:#7c3aed1c;color:var(--purple)}.badge-amber{background:#f59e0b26;color:#b45309}.badge-red{background:#ef44441c;color:#b91c1c}.project-body{padding:18px}.project-title-row{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:8px}.project-title{font-size:21px;font-weight:900;letter-spacing:-.03em;color:var(--navy-950);margin:0}.price{text-align:right;min-width:115px}.price small{display:block;color:var(--muted);font-weight:700;font-size:11px}.price strong{display:block;color:var(--navy-950);font-size:19px}.meta-line{display:flex;gap:8px;align-items:center;color:var(--muted);font-size:13px;margin:6px 0}.project-footer{display:flex;justify-content:space-between;align-items:center;margin-top:16px;gap:12px}.stat-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.stat-card{padding:18px;border-radius:20px;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-soft)}.stat-icon{width:48px;height:48px;border-radius:50%;display:grid;place-items:center;background:#00b7c71f;color:var(--cyan-dark);font-size:22px;margin-bottom:12px}.stat-card strong{display:block;font-size:30px;letter-spacing:-.04em;color:var(--navy-950)}.stat-card span{color:var(--muted);font-size:13px}.detail-hero{display:grid;grid-template-columns:1.45fr 1fr;gap:22px;margin-bottom:22px}.hero-photo{height:420px;border-radius:24px;overflow:hidden;background:linear-gradient(135deg,#082340,#145c8f);position:relative;box-shadow:var(--shadow)}.hero-photo img{width:100%;height:100%;object-fit:cover;display:block}.project-info-card{padding:24px;display:grid;gap:18px}.mapbox{min-height:148px;border-radius:18px;border:1px solid var(--line);background:radial-gradient(circle at 50% 50%,rgba(0,183,199,.28),transparent 25%),linear-gradient(135deg,#eef4f8,#fff);display:grid;place-items:center;color:var(--cyan-dark);font-weight:900}.info-stats{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--line);padding-top:16px;gap:12px}.info-stats strong{display:block;font-size:20px;color:var(--navy-950)}.info-stats span{color:var(--muted);font-size:12px}.gallery-row{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px}.gallery-thumb{height:120px;border-radius:16px;overflow:hidden;background:var(--soft-2);border:1px solid var(--line)}.gallery-thumb img{width:100%;height:100%;object-fit:cover}.amenities{display:flex;gap:10px;flex-wrap:wrap}.amenity{height:38px;display:inline-flex;align-items:center;gap:8px;padding:0 13px;border-radius:13px;background:var(--soft-2);color:var(--navy-800);font-weight:800;font-size:12px}.stock-layout{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:22px}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse}th{text-align:left;color:var(--muted);font-size:12px;padding:14px 16px;border-bottom:1px solid var(--line);white-space:nowrap}td{padding:15px 16px;border-bottom:1px solid var(--line);font-size:14px;white-space:nowrap}tr.selected{outline:2px solid rgba(0,183,199,.5);outline-offset:-2px;background:#00b7c70a}.status{display:inline-flex;align-items:center;height:26px;padding:0 9px;border-radius:999px;font-size:11px;font-weight:850}.status-disponible{background:#17b26a21;color:#087443}.status-reservado,.status-pendiente_pago{background:#f59e0b29;color:#b45309}.status-vendido{background:#ef44441f;color:#b91c1c}.status-bloqueada{background:#7c3aed1f;color:var(--purple)}.unit-panel{position:sticky;top:98px;align-self:start}.floorplan{height:210px;border-radius:16px;background:linear-gradient(135deg,#fff,#eef4f8);border:1px solid var(--line);display:grid;place-items:center;overflow:hidden}.floorplan img{width:100%;height:100%;object-fit:cover}.spec-list{display:grid;gap:10px;margin:18px 0}.spec{display:flex;justify-content:space-between;gap:14px;font-size:13px;color:var(--muted)}.spec strong{color:var(--navy-950)}.quote-layout{display:grid;grid-template-columns:290px minmax(0,1fr) 330px;gap:22px;align-items:start}.quote-step{padding:20px;margin-bottom:18px}.step-title{font-size:17px;font-weight:900;margin:0 0 16px;color:var(--navy-950)}.option-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.option-card{padding:18px;border:1.5px solid var(--line);border-radius:18px;background:#fff;transition:.14s ease}.option-card.active{border-color:var(--cyan);box-shadow:0 0 0 4px #00b7c71c}.option-card strong{display:block;margin-bottom:5px;color:var(--navy-950)}.payment-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.summary-card{position:sticky;top:98px}.summary-row{display:flex;justify-content:space-between;gap:16px;padding:11px 0;border-bottom:1px solid var(--line);color:var(--muted);font-size:13px}.summary-row strong{color:var(--navy-950)}.big-total{background:linear-gradient(135deg,var(--navy-950),var(--navy-800));color:#fff;border-radius:18px;padding:22px;margin:18px 0}.big-total span{display:block;color:#ffffffb8;font-size:12px;margin-bottom:5px}.big-total strong{font-size:31px;letter-spacing:-.05em}.login-screen{min-height:100vh;display:grid;grid-template-columns:40% 60%;background:#fff}.login-brand{background:radial-gradient(circle at 70% 82%,rgba(0,183,199,.22),transparent 25%),linear-gradient(180deg,var(--navy-950),var(--navy-800));color:#fff;padding:56px;display:flex;flex-direction:column;justify-content:space-between;overflow:hidden;position:relative}.login-brand h1{color:#fff;font-size:44px;line-height:1.05;max-width:410px}.login-brand h1 em{color:var(--cyan);font-style:normal}.login-features{display:grid;gap:18px;max-width:360px}.login-feature{display:flex;gap:14px;align-items:center;color:#ffffffd9}.login-feature b{width:46px;height:46px;border-radius:16px;background:#ffffff1a;display:grid;place-items:center;font-size:22px}.login-form-wrap{display:grid;place-items:center;padding:40px;background:linear-gradient(135deg,#fff,var(--soft))}.login-card{width:100%;max-width:560px;padding:48px}.login-card h2{font-size:30px;letter-spacing:-.04em;margin:0 0 8px}.admin-tabs{display:flex;gap:8px;border-bottom:1px solid var(--line);margin-bottom:22px;overflow-x:auto}.admin-tab{border:0;background:transparent;padding:14px 16px;color:var(--muted);font-weight:850;border-bottom:3px solid transparent}.admin-tab.active{color:var(--navy-950);border-bottom-color:var(--cyan)}.toggle-list{display:grid;gap:10px}.toggle-item{display:flex;align-items:center;justify-content:space-between;border:1px solid var(--line);border-radius:14px;padding:13px 14px;background:#fff}.switch{width:46px;height:26px;border-radius:999px;background:#cad7e3;position:relative;transition:.15s}.switch.on{background:var(--green)}.switch:after{content:"";position:absolute;width:20px;height:20px;background:#fff;border-radius:50%;top:3px;left:3px;transition:.15s;box-shadow:0 2px 6px #0000002e}.switch.on:after{left:23px}.pipeline{display:grid;grid-template-columns:repeat(5,minmax(240px,1fr));gap:16px;overflow-x:auto;padding-bottom:12px}.pipeline-col{background:#edf3f8;border:1px solid var(--line);border-radius:20px;padding:12px;min-height:520px}.pipeline-col h3{margin:4px 4px 12px;font-size:14px;color:var(--navy-950);display:flex;justify-content:space-between}.lead-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:14px;margin-bottom:10px;box-shadow:0 3px 12px #0623410a}.lead-card strong{display:block;color:var(--navy-950);margin-bottom:6px}.lead-card small{display:block;color:var(--muted);margin-bottom:4px}.empty{padding:44px;text-align:center;color:var(--muted)}.loading{min-height:50vh;display:grid;place-items:center;color:var(--muted)}.skeleton{background:linear-gradient(90deg,#eef4f8,#f8fbfd,#eef4f8);background-size:200% 100%;animation:shimmer 1.1s infinite;border-radius:18px}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@media (max-width: 1120px){.app-shell{grid-template-columns:86px minmax(0,1fr)}.brand-text,.nav-link span:not(.nav-icon),.sidebar-footer span,.nav-group-label{display:none}.sidebar{padding:22px 12px}.nav-link{justify-content:center;padding:13px}.detail-hero,.stock-layout,.quote-layout{grid-template-columns:1fr}.summary-card,.unit-panel{position:static}.filter-row{grid-template-columns:repeat(2,minmax(0,1fr))}.login-screen{grid-template-columns:1fr}.login-brand{display:none}}@media (max-width: 680px){.app-shell{display:block}.sidebar{display:none}.topbar{padding:0 14px}.content{padding:20px 14px}h1{font-size:28px}.project-grid,.grid-2,.grid-3,.grid-4,.stat-grid{grid-template-columns:1fr}.detail-hero{gap:14px}.hero-photo{height:260px}.filter-row{grid-template-columns:1fr}.quote-layout{gap:14px}.option-grid,.payment-grid{grid-template-columns:1fr}}.app-shell-drawer{min-height:100vh;background:#f0f4ff;color:#111827}.topbar-simple{height:58px;background:#fffffff5;border-bottom:1px solid #dbe5f0;display:flex;align-items:center;gap:12px;padding:0 18px;position:sticky;top:0;z-index:40;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.hamburger{width:38px;height:38px;border:1px solid #dbe5f0;border-radius:10px;background:#fff;display:grid;place-items:center;gap:4px;padding:9px}.hamburger span{width:18px;height:2px;background:#111827;border-radius:999px;display:block;transition:.18s ease}.hamburger.open span:nth-child(1){transform:translateY(6px) rotate(45deg)}.hamburger.open span:nth-child(2){opacity:0}.hamburger.open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}.brand-simple{display:flex;align-items:center;gap:9px;cursor:pointer;-webkit-user-select:none;user-select:none}.brand-mark-simple{width:34px;height:34px;border-radius:10px;background:#2563eb;color:#fff;display:grid;place-items:center;box-shadow:0 8px 18px #2563eb33}.brand-simple strong,.drawer-head strong{display:block;line-height:1.1;color:#111827}.brand-simple small,.drawer-head small{display:block;color:#64748b;font-size:11px}.topbar-spacer{flex:1}.user-mini{display:flex;align-items:center;gap:10px}.user-mini .avatar.simple{width:34px;height:34px;font-size:12px;background:#2563eb}.user-mini-text strong{display:block;font-size:13px}.user-mini-text small{display:block;font-size:11px;color:#64748b}.drawer-overlay{position:fixed;top:58px;right:0;bottom:0;left:0;background:#0f172a38;z-index:35;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px)}.drawer{position:fixed;left:0;top:58px;bottom:0;width:274px;background:#fff;border-right:1px solid #dbe5f0;z-index:45;transform:translate(-100%);transition:transform .22s cubic-bezier(.4,0,.2,1);box-shadow:8px 0 30px #0f172a1f;display:flex;flex-direction:column}.drawer.open{transform:translate(0)}.drawer-head{display:flex;align-items:center;gap:10px;padding:18px 16px;border-bottom:1px solid #dbe5f0}.drawer-section{font-size:10px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:#94a3b8;padding:16px 18px 8px}.drawer-nav{display:grid;gap:4px;padding:0 10px}.drawer-link{display:flex;align-items:center;gap:11px;min-height:40px;padding:0 12px;border-radius:10px;color:#64748b;font-size:13px;font-weight:700;border:1px solid transparent}.drawer-link:hover{background:#f8fafc;color:#1d4ed8}.drawer-link.active{background:#eff6ff;color:#1d4ed8;border-color:#bfdbfe;box-shadow:inset 3px 0 #2563eb}.drawer-icon{width:22px;text-align:center}.drawer-footer{margin-top:auto;border-top:1px solid #dbe5f0;padding:14px;display:grid;gap:10px}.drawer-footer strong{display:block;font-size:13px}.drawer-footer small{display:block;font-size:11px;color:#64748b;overflow:hidden;text-overflow:ellipsis}.main-simple{min-height:calc(100vh - 58px)}.content-simple{padding:24px}.client-search-wrap{position:relative}.client-results{position:absolute;left:0;right:0;top:68px;background:#fff;border:1px solid #dbe5f0;border-radius:14px;box-shadow:0 18px 45px #0f172a24;overflow:hidden;z-index:30}.client-result{width:100%;border:0;background:#fff;text-align:left;padding:10px 12px;display:grid;gap:2px;color:#111827;border-bottom:1px solid #eef2f7}.client-result:hover{background:#eff6ff}.client-result strong{font-size:13px}.client-result span,.client-result.muted{font-size:11px;color:#64748b}.crm-selected{background:#f0fdf4;color:#166534;border:1px solid #bbf7d0;border-radius:12px;padding:8px 10px;font-size:12px;font-weight:800;margin-bottom:12px}.crm-selected small{display:block;color:#15803d;font-weight:500;margin-top:2px}@media (max-width: 680px){.user-mini-text{display:none}.content-simple{padding:16px}}
