:root{--bg:#eef2f7;--panel:#ffffff;--text:#101828;--muted:#667085;--brand:#1d4ed8;--brand2:#0f172a;--line:#d7dee9;--ok:#16a34a;--warn:#d97706;--bad:#dc2626;--soft:#f8fafc}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--text);font-family:Arial,Helvetica,sans-serif;font-size:16px}.app-shell{min-height:100vh;display:flex}.sidebar{width:285px;background:linear-gradient(180deg,#0f172a,#13213d);color:#fff;display:flex;flex-direction:column;position:fixed;left:0;top:0;bottom:0;padding:18px 14px;box-shadow:8px 0 24px rgba(15,23,42,.18);z-index:5}.brand{display:flex;gap:12px;align-items:center;padding:10px 8px 20px;border-bottom:1px solid rgba(255,255,255,.12)}.brand-mark{width:44px;height:44px;border-radius:14px;background:#2563eb;display:flex;align-items:center;justify-content:center;font-weight:900}.brand span{display:block;color:#b9c6dd;font-size:13px;margin-top:2px}.side-nav{padding:18px 0;display:flex;flex-direction:column;gap:8px}.side-nav a{color:#e5e7eb;text-decoration:none;padding:12px 12px;border-radius:12px;font-weight:700;display:block;border:1px solid transparent}.side-nav a:hover{background:rgba(37,99,235,.22);border-color:rgba(147,197,253,.35);color:#fff}.side-footer{margin-top:auto;border-top:1px solid rgba(255,255,255,.12);padding:16px 8px;color:#e5e7eb}.side-footer small{display:block;color:#a9b6cc;margin:4px 0 12px}.logout{display:inline-block;color:#fff;background:#dc2626;text-decoration:none;padding:8px 12px;border-radius:10px;font-weight:700}.main-area{margin-left:285px;width:calc(100% - 285px);min-height:100vh}.login-area{margin-left:0;width:100%}.topbar{height:74px;background:#fff;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;padding:0 28px;position:sticky;top:0;z-index:3}.topbar span{display:block;color:var(--muted);font-size:13px;margin-top:3px}.login-head{background:#0f172a;color:white;padding:16px 22px}.content{max-width:1220px;margin:0 auto;padding:28px}.login-area .content{max-width:620px}.page-title{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:18px}.page-title h1,h1{font-size:30px;margin:0 0 8px;color:#0f172a}.page-title p,.muted{color:var(--muted);margin:0}.card{background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:20px;margin:18px 0;box-shadow:0 12px 28px rgba(15,23,42,.07)}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.stat-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:20px;box-shadow:0 12px 28px rgba(15,23,42,.07)}.stat-card span{color:var(--muted);font-weight:700}.stat-card strong{display:block;font-size:34px;margin:18px 0 6px;color:#0f172a}.stat-card small{color:var(--muted)}.hero-card{display:flex;justify-content:space-between;gap:20px;align-items:center}.actions{display:flex;gap:10px;flex-wrap:wrap}.feature-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.feature-grid div{background:var(--soft);border:1px solid var(--line);padding:14px;border-radius:14px}.feature-grid span{display:block;color:var(--muted);margin-top:6px}.form{max-width:560px}.grid-form{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}.grid-form .full{grid-column:1/-1}label{display:block;margin:8px 0 6px;font-weight:800;color:#111827}input,select,textarea{width:100%;padding:12px;border:1px solid #b8c2d1;border-radius:12px;background:#fff;color:#111827;font-size:16px}input:focus,select:focus,textarea:focus{outline:3px solid rgba(37,99,235,.18);border-color:#2563eb}.check input{width:auto;margin-right:8px}button,.btn{background:var(--brand);color:white;padding:11px 16px;border:0;border-radius:12px;text-decoration:none;display:inline-block;font-weight:800;cursor:pointer;box-shadow:0 8px 18px rgba(29,78,216,.22)}.btn.secondary,button.secondary{background:#0f172a}.btn.light{background:#fff;color:#0f172a;border:1px solid var(--line);box-shadow:none}table{width:100%;border-collapse:separate;border-spacing:0;background:white;border-radius:16px;overflow:hidden;margin-top:15px;border:1px solid var(--line);box-shadow:0 10px 24px rgba(15,23,42,.05)}th,td{border-bottom:1px solid var(--line);text-align:left;padding:12px;vertical-align:top}th{background:#f1f5f9;color:#111827;font-weight:900}tr:last-child td{border-bottom:0}.alert{background:#fee2e2;border:1px solid #ef4444;padding:12px;border-radius:12px;margin:10px 0}.badge{display:inline-flex;padding:5px 9px;border-radius:999px;font-size:12px;font-weight:900;background:#e0e7ff;color:#1d4ed8}.badge.disponible{background:#dcfce7;color:#166534}.badge.alquilada,.badge.vendida{background:#fee2e2;color:#991b1b}.badge.reservada{background:#fef3c7;color:#92400e}@media(max-width:1000px){.sidebar{position:relative;width:100%;height:auto}.app-shell{display:block}.main-area{margin-left:0;width:100%}.stats-grid,.feature-grid,.grid-form{grid-template-columns:1fr}.hero-card{display:block}.content{padding:18px}.topbar{height:auto;gap:12px;padding:16px;align-items:flex-start;flex-direction:column}}

/* FASE 10.2 - Portal público Premium Light */
.public-shell{display:block;background:linear-gradient(180deg,#fffaf4 0%,#f7f9fc 42%,#ffffff 100%)}
.public-shell .main-area{margin-left:0;width:100%}.public-topnav{height:74px;background:rgba(255,255,255,.92);backdrop-filter:blur(16px);border-bottom:1px solid rgba(226,232,240,.85);display:flex;align-items:center;justify-content:space-between;padding:0 5vw;position:sticky;top:0;z-index:20;box-shadow:0 8px 30px rgba(15,23,42,.04)}.public-logo{font-weight:950;color:#172033;text-decoration:none;font-size:22px;letter-spacing:-.04em}.public-topnav nav{display:flex;gap:18px;align-items:center}.public-topnav nav a{color:#172033;text-decoration:none;font-weight:850}.public-topnav nav a:hover{color:#2563eb}.public-content{max-width:none!important;margin:0!important;padding:0!important}.public-hero{position:relative;min-height:590px;background:radial-gradient(circle at 12% 20%,rgba(250,204,21,.20),transparent 27%),linear-gradient(115deg,rgba(255,255,255,.95) 0%,rgba(255,255,255,.88) 43%,rgba(239,246,255,.48) 100%),url('https://images.unsplash.com/photo-1600607687939-ce8a6c25118c?auto=format&fit=crop&w=1900&q=88') center/cover no-repeat;display:flex;align-items:center;padding:70px 5vw 96px;color:#172033;overflow:hidden}.public-hero:after{content:"";position:absolute;right:5vw;bottom:42px;width:245px;height:245px;border-radius:50%;background:rgba(255,255,255,.42);border:1px solid rgba(255,255,255,.72);box-shadow:0 28px 80px rgba(15,23,42,.10);backdrop-filter:blur(12px)}.public-hero-content{position:relative;max-width:1180px;width:100%;margin:0 auto;z-index:1}.public-kicker{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.76);border:1px solid rgba(203,213,225,.8);padding:9px 13px;border-radius:999px;font-weight:950;text-transform:uppercase;letter-spacing:.08em;font-size:12px;color:#2563eb;box-shadow:0 10px 28px rgba(15,23,42,.06)}.public-kicker.dark{background:#eff6ff;color:#1d4ed8;border-color:#bfdbfe}.public-hero h1{color:#111827;font-size:58px;line-height:1.02;letter-spacing:-.06em;max-width:860px;margin:22px 0 16px}.public-hero p{font-size:20px;color:#475569;max-width:770px;line-height:1.58}.public-search{background:rgba(255,255,255,.88);border:1px solid rgba(226,232,240,.95);border-radius:30px;padding:18px;box-shadow:0 28px 80px rgba(15,23,42,.13);margin-top:34px;color:#0f172a;backdrop-filter:blur(18px)}.public-search-main{display:grid;grid-template-columns:1fr 230px;gap:12px}.public-search-main input{height:58px;border-radius:18px;font-size:17px;background:#fff}.public-search-main button{border-radius:18px;font-size:16px;background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 14px 30px rgba(37,99,235,.23)}.public-filter-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:12px}.public-filter-grid select,.public-filter-grid input{height:50px;border-radius:15px;background:#fff}.public-clear{display:flex;align-items:center;justify-content:center;border:1px solid #d9e1ec;border-radius:15px;color:#0f172a;text-decoration:none;font-weight:900;background:#fff}.public-trust-strip{max-width:1180px;margin:-46px auto 0;position:relative;z-index:2;display:grid;grid-template-columns:repeat(4,1fr);gap:14px;padding:0 18px}.public-trust-strip div{background:rgba(255,255,255,.94);border:1px solid #e8edf5;border-radius:24px;padding:21px;box-shadow:0 18px 48px rgba(15,23,42,.09)}.public-trust-strip strong{display:block;font-size:27px;color:#111827}.public-trust-strip span{color:#64748b;font-weight:750}.public-section-head{max-width:1180px;margin:62px auto 22px;padding:0 18px;display:flex;align-items:end;justify-content:space-between;gap:30px}.public-section-head h2{font-size:36px;letter-spacing:-.045em;margin:12px 0 0;color:#111827}.public-section-head p{color:#64748b;max-width:430px}.public-property-grid{max-width:1180px;margin:0 auto 64px;padding:0 18px;display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.public-property-card{background:#fff;border:1px solid #e8edf5;border-radius:30px;overflow:hidden;box-shadow:0 18px 46px rgba(15,23,42,.075);transition:.22s transform,.22s box-shadow}.public-property-card:hover{transform:translateY(-5px);box-shadow:0 28px 75px rgba(15,23,42,.14)}.public-img-wrap{display:block;position:relative;height:260px;overflow:hidden;background:#e2e8f0}.public-img-wrap:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.05),rgba(0,0,0,.18));pointer-events:none}.public-img-wrap img{width:100%;height:100%;object-fit:cover;transition:.35s transform}.public-property-card:hover .public-img-wrap img{transform:scale(1.055)}.public-chip,.public-status{position:absolute;top:14px;border-radius:999px;padding:7px 11px;font-size:12px;font-weight:950;text-transform:uppercase;z-index:2}.public-chip{left:14px;background:rgba(255,255,255,.92);color:#0f172a;box-shadow:0 10px 22px rgba(15,23,42,.10)}.public-status{right:14px;background:#dcfce7;color:#166534}.public-status.reservada{background:#fef3c7;color:#92400e}.public-status.alquilada,.public-status.vendida{background:#fee2e2;color:#991b1b}.public-card-body{padding:20px}.public-price{font-size:25px;color:#1d4ed8;display:block;margin-bottom:10px}.public-card-body h3{font-size:21px;line-height:1.25;margin:0 0 10px}.public-card-body h3 a{color:#111827;text-decoration:none}.public-location,.public-desc{color:#64748b;line-height:1.48}.public-specs{display:flex;gap:8px;flex-wrap:wrap;margin:14px 0}.public-specs span{background:#f8fafc;border:1px solid #e2e8f0;border-radius:999px;padding:7px 10px;font-weight:850;color:#334155;font-size:13px}.public-card-actions{display:flex;gap:10px;margin-top:16px}.public-card-actions .btn{box-shadow:none}.public-card-actions .btn.light{background:#fff}.public-empty{max-width:900px;margin:52px auto;padding:40px;background:white;border-radius:30px;text-align:center;border:1px solid #e8edf5;box-shadow:0 18px 48px rgba(15,23,42,.06)}.public-idea-band{max-width:1180px;margin:24px auto 74px;padding:32px;display:flex;align-items:center;justify-content:space-between;gap:22px;background:linear-gradient(135deg,#fff,#eff6ff);color:#172033;border:1px solid #dbeafe;border-radius:32px;box-shadow:0 18px 50px rgba(37,99,235,.09)}.public-idea-band h2{margin:0 0 8px;color:#111827}.public-idea-band p{margin:0;color:#475569;max-width:780px;line-height:1.55}.public-idea-band .btn.secondary{background:#172033;color:#fff}.detail-hero{max-width:1180px;margin:36px auto 18px;padding:0 18px;display:flex;justify-content:space-between;gap:20px;align-items:end}.detail-hero h1{font-size:46px;letter-spacing:-.055em}.public-back{display:inline-block;margin-bottom:14px;color:#1d4ed8;font-weight:900;text-decoration:none}.detail-price-box{background:white;border:1px solid #e8edf5;border-radius:26px;padding:20px;min-width:260px;box-shadow:0 18px 48px rgba(15,23,42,.08)}.detail-price-box span,.detail-price-box small{display:block;color:#64748b;font-weight:800}.detail-price-box strong{display:block;color:#1d4ed8;font-size:31px;margin:6px 0}.detail-gallery{max-width:1180px;margin:0 auto;padding:0 18px;display:grid;grid-template-columns:2fr 1fr;gap:14px}.detail-main-img,.detail-thumbs img{width:100%;object-fit:cover;border-radius:26px;background:#e2e8f0;box-shadow:0 18px 48px rgba(15,23,42,.08)}.detail-main-img{height:520px}.detail-thumbs{display:grid;grid-template-columns:1fr 1fr;gap:14px}.detail-thumbs img{height:253px}.detail-layout{max-width:1180px;margin:24px auto 70px;padding:0 18px;display:grid;grid-template-columns:1fr 360px;gap:22px}.detail-spec-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px}.detail-spec-grid div{background:white;border:1px solid #e8edf5;border-radius:22px;padding:18px;text-align:center}.detail-spec-grid strong{display:block;font-size:28px;color:#111827}.detail-spec-grid span{color:#64748b;font-weight:800}.map-placeholder{height:230px;border-radius:22px;background:linear-gradient(135deg,#eff6ff,#fff7ed);border:1px solid #e8edf5;display:flex;align-items:center;justify-content:center;color:#64748b;font-weight:900}.detail-contact{position:sticky;top:92px;align-self:start}.whatsapp{background:#16a34a}.contact-mini{display:grid;gap:10px;margin-top:14px}.contact-mini input,.contact-mini textarea{border-radius:14px;background:#fff}
@media(max-width:1050px){.public-hero{min-height:auto;padding:48px 18px 44px}.public-hero:after{display:none}.public-hero h1{font-size:42px}.public-hero p{font-size:18px}.public-search-main,.public-filter-grid,.public-trust-strip,.public-property-grid,.detail-gallery,.detail-layout{grid-template-columns:1fr}.public-section-head,.public-idea-band,.detail-hero{display:block}.detail-main-img{height:360px}.detail-thumbs{grid-template-columns:repeat(2,1fr)}.detail-thumbs img{height:160px}.detail-spec-grid{grid-template-columns:repeat(2,1fr)}.public-topnav{height:auto;padding:14px 18px;gap:12px;align-items:flex-start;flex-direction:column}.public-topnav nav{flex-wrap:wrap}.public-trust-strip{margin-top:18px}.public-search{border-radius:24px}.public-search-main button{height:54px}}

/* FASE 11 - Personas PRO */
.kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin:16px 0}.kpi-card{background:#fff;border:1px solid #dbe5f2;border-radius:18px;padding:18px;box-shadow:0 10px 25px rgba(15,23,42,.06)}.kpi-card span{display:block;color:#52627a;font-weight:700;font-size:13px}.kpi-card strong{display:block;font-size:32px;margin:8px 0;color:#0f172a}.kpi-card small{color:#64748b}.table-wrap{width:100%;overflow:auto}.badge{display:inline-flex;align-items:center;border-radius:999px;padding:5px 10px;font-size:12px;font-weight:800}.badge-soft{background:#eaf1ff;color:#1e40af}.badge.ok{background:#dcfce7;color:#166534}.badge.warn{background:#fef3c7;color:#92400e}.btn-mini{display:inline-flex;align-items:center;justify-content:center;padding:8px 12px;border-radius:10px;background:#0f172a;color:#fff;text-decoration:none;font-weight:800;font-size:12px;border:0}.btn-mini:hover{filter:brightness(1.08)}.page-head-actions{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:12px}.profile-hero{display:flex;align-items:center;justify-content:space-between;gap:20px;background:linear-gradient(135deg,#ffffff,#eef5ff)}.profile-hero h2{font-size:30px;margin:10px 0 5px}.profile-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.profile-stats div{min-width:110px;background:#fff;border:1px solid #dbe5f2;border-radius:16px;padding:14px;text-align:center}.profile-stats strong{display:block;font-size:28px;color:#1d4ed8}.profile-stats span{font-size:12px;color:#64748b;font-weight:800}.muted{color:#64748b}@media(max-width:900px){.kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.profile-hero{display:block}.profile-stats{margin-top:14px}}@media(max-width:560px){.kpi-grid,.profile-stats{grid-template-columns:1fr}.page-head-actions{display:block}.btn-mini{margin-top:10px}}

/* FASE 12 + 13 - Contratos, pagos y liquidaciones */
.compact-form{grid-template-columns:repeat(4,minmax(0,1fr));align-items:end}.contract-hero{display:flex;justify-content:space-between;gap:22px;align-items:center;background:linear-gradient(135deg,#fff,#eef6ff)}.contract-hero h2{font-size:30px;margin:10px 0 6px}.contract-price{min-width:260px;background:#fff;border:1px solid #dbe5f2;border-radius:18px;padding:18px;text-align:right;box-shadow:0 12px 30px rgba(15,23,42,.07)}.contract-price span,.contract-price small{display:block;color:#64748b;font-weight:800}.contract-price strong{display:block;font-size:28px;color:#1d4ed8;margin:6px 0}.accent-card{border-color:#bfdbfe;background:linear-gradient(135deg,#ffffff,#f8fbff)}.estado-vigente,.estado-pagado{background:#dcfce7!important;color:#166534!important}.estado-por_vencer,.estado-pendiente,.estado-observado{background:#fef3c7!important;color:#92400e!important}.estado-vencido,.estado-rescindido{background:#fee2e2!important;color:#991b1b!important}.estado-finalizado{background:#e2e8f0!important;color:#334155!important}.mini-pay-form{display:grid;grid-template-columns:120px 145px 145px 170px 140px auto;gap:7px;min-width:860px}.mini-pay-form input,.mini-pay-form select{height:36px;border-radius:9px;font-size:12px}.mini-pay-form .btn-mini{height:36px;margin:0}.grid-form textarea{width:100%;border:1px solid #d5deea;border-radius:12px;padding:11px;font-family:inherit;resize:vertical}.table-wrap table small{color:#64748b}@media(max-width:1000px){.compact-form{grid-template-columns:1fr}.contract-hero{display:block}.contract-price{text-align:left;margin-top:14px}.mini-pay-form{grid-template-columns:1fr;min-width:240px}}
/* FASE 14 + 15 - Incidencias PRO + Agenda/CRM */
.stats-grid.mini{grid-template-columns:repeat(4,1fr);margin-bottom:14px}.doc-list{display:grid;gap:10px}.doc-list div{border:1px solid var(--line);background:var(--soft);border-radius:14px;padding:12px}.doc-list strong{display:block;color:#0f172a}.doc-list span{display:block;color:var(--muted);font-size:14px;margin:5px 0}.doc-list a{font-weight:800;color:var(--brand);text-decoration:none}td form{display:grid;grid-template-columns:1fr;gap:6px}td form input,td form select,td form button{font-size:13px;padding:8px;border-radius:10px}textarea{resize:vertical}@media(max-width:1000px){.stats-grid.mini{grid-template-columns:1fr}}
