:root{
  --void:#060709;--deep:#0c0e14;--surface:#13151e;--raised:#191c27;--line:#21253a;--line2:#2a2f46;
  --gold:#c8923a;--gold2:#e8b252;--gold3:#f5d080;--cream:#f0e8d4;
  --sage:#2eb87a;--coral:#e05642;--sky:#3d8ef0;--amber:#e09020;
  --text:#f2f4ff;--text2:#b8c0d8;--text3:#6a7090;
  --r:12px;
  --bg-page:var(--void);--bg-deep:var(--deep);--bg-surface:var(--surface);
  --bg-raised:var(--raised);--border:var(--line);--border2:var(--line2);
  --fg:var(--text);--fg2:var(--text2);--fg3:var(--text3);
}
/* ── LIGHT MODE ── */
body.light-mode{
  --void:#f5f5f0;--deep:#ffffff;--surface:#f0ede6;--raised:#e8e4dc;
  --line:#d4cfc6;--line2:#c8c2b8;
  --text:#1a1a18;--text2:#4a4840;--text3:#8a8680;
  --cream:#1a1a18;
  --bg-page:var(--void);--bg-deep:var(--deep);--bg-surface:var(--surface);
  --bg-raised:var(--raised);--border:var(--line);--border2:var(--line2);
  --fg:var(--text);--fg2:var(--text2);--fg3:var(--text3);
}
body.light-mode .auth-visual{background:linear-gradient(145deg,#f0ede6 0%,#ede8e0 100%)!important}
body.light-mode .auth-visual-grid{background-image:linear-gradient(rgba(180,140,60,.1) 1px,transparent 1px),linear-gradient(90deg,rgba(180,140,60,.1) 1px,transparent 1px)!important}
body.light-mode .notif{background:#fff;color:var(--gold)}
body.light-mode .alex-msg.alex{background:rgba(180,130,40,.1);border-color:rgba(180,130,40,.2);color:#2a2820}
body.light-mode .alex-msg.user{background:#e8e4dc;color:#1a1a18}
body.light-mode input,body.light-mode select,body.light-mode textarea{background:var(--raised)!important;color:var(--text)!important}
body.light-mode .spinner{border-color:var(--line2);border-top-color:var(--gold)}
*{box-sizing:border-box;margin:0;padding:0}
html{height:auto;min-height:100%;}body{height:auto;min-height:100%;overflow-x:hidden;font-family:'DM Sans',sans-serif;background:var(--void);color:var(--text)}
::-webkit-scrollbar{width:4px}::-webkit-scrollbar-thumb{background:var(--line2);border-radius:2px}

/* ── GRAIN OVERLAY ── */
body::before{content:'';position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");pointer-events:none;z-index:9999;opacity:.4}

/* ── TYPOGRAPHY ── */
.serif{font-family:'Cormorant Garamond',serif}
.mono{font-family:'DM Mono',monospace}

/* ══════════════════════════════════════════════════
   ONBOARDING / AUTH — PANTALLA COMPLETA
══════════════════════════════════════════════════ */
#auth-screen{
  position:relative;
  min-height:100vh;
  display:block;
  overflow-y:auto;
  overflow-x:hidden;
  background:var(--void);
  z-index:auto;
}
#auth-screen.hidden{display:none!important;}

/* Panel izquierdo — visual (not used in new landing) */
.auth-visual{
  display:none!important;
  background:linear-gradient(145deg,#0a0c14 0%,#0e1020 60%,#131828 100%);
}
.auth-visual-bg{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse 70% 50% at 30% 30%, rgba(200,146,58,.12) 0%, transparent 60%),
    radial-gradient(ellipse 50% 60% at 80% 80%, rgba(46,184,122,.06) 0%, transparent 60%);
}
.auth-visual-grid{
  position:absolute;inset:0;
  background-image:linear-gradient(rgba(200,146,58,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(200,146,58,.04) 1px,transparent 1px);
  background-size:40px 40px;
}
.auth-visual-content{
  position:relative;z-index:1;height:100%;display:flex;flex-direction:column;justify-content:space-between;padding:48px 40px;
}
.auth-logo{font-family:'Cormorant Garamond',serif;font-size:38px;font-weight:700;color:var(--gold);letter-spacing:-.5px}
.auth-logo-tag{font-size:11px;color:var(--text3);letter-spacing:3px;text-transform:uppercase;margin-top:2px;font-family:'DM Sans',sans-serif;font-weight:400}
.auth-hero{flex:1;display:flex;flex-direction:column;justify-content:center;padding:20px 0}
.auth-hero-title{font-family:'Cormorant Garamond',serif;font-size:46px;line-height:1.1;font-weight:600;color:var(--cream);margin-bottom:16px}
.auth-hero-title em{font-style:italic;color:var(--gold)}
.auth-hero-sub{font-size:15px;color:var(--text2);line-height:1.6;max-width:300px}
.auth-stats{display:flex;gap:0;margin-top:40px;border:1px solid rgba(200,146,58,.15);border-radius:10px;overflow:hidden}
.auth-stats>div{flex:1;text-align:center;padding:14px 8px;border-right:1px solid rgba(200,146,58,.12)}
.auth-stats>div:last-child{border-right:none}
.auth-stat-val{font-family:'Cormorant Garamond',serif;font-size:26px;font-weight:700;color:var(--gold2);line-height:1}
.auth-stat-lbl{font-size:10px;color:#8a90b0;margin-top:4px;text-transform:uppercase;letter-spacing:.8px}
.auth-badge-launch{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(200,146,58,.12);border:1px solid rgba(200,146,58,.25);
  color:var(--gold2);padding:8px 14px;border-radius:20px;font-size:12px;font-weight:500;margin-top:24px;width:fit-content;
}
.auth-badge-dot{width:6px;height:6px;border-radius:50%;background:var(--sage);animation:blink 2s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}

/* Panel derecho — formulario */
.auth-form-panel{
  flex:1;display:flex;align-items:center;justify-content:center;
  background:var(--deep);padding:40px 24px;overflow-y:auto;
}
.auth-form-card{width:100%;max-width:420px}
.auth-form-card h2{font-family:'Cormorant Garamond',serif;font-size:26px;font-weight:600;color:var(--cream);margin-bottom:6px}
.auth-form-card p{font-size:13.5px;color:var(--text2);margin-bottom:28px;line-height:1.5}

/* Selector de tipo de usuario — EL MOMENTO CLAVE */
.user-type-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-bottom:28px}
.user-type-card{
  border:1px solid var(--line2);border-radius:10px;padding:14px 10px;text-align:center;cursor:pointer;
  transition:all .2s;background:var(--surface);position:relative;overflow:hidden;
}
.user-type-card::before{
  content:'';position:absolute;inset:0;opacity:0;transition:opacity .2s;
}
.user-type-card.prop::before{background:linear-gradient(135deg,rgba(200,146,58,.08),transparent)}
.user-type-card.comp::before{background:linear-gradient(135deg,rgba(61,142,240,.08),transparent)}
.user-type-card.pro::before{background:linear-gradient(135deg,rgba(46,184,122,.08),transparent)}
.user-type-card:hover::before,.user-type-card.active::before{opacity:1}
.user-type-card.active.prop{border-color:var(--gold);box-shadow:0 0 0 2px rgba(200,146,58,.15)}
.user-type-card.active.comp{border-color:var(--sky);box-shadow:0 0 0 2px rgba(61,142,240,.15)}
.user-type-card.active.pro{border-color:var(--sage);box-shadow:0 0 0 2px rgba(46,184,122,.15)}
.user-type-icon{font-size:24px;margin-bottom:8px}
.user-type-name{font-size:12px;font-weight:600;color:var(--text)}
.user-type-desc{font-size:10px;color:var(--text3);margin-top:3px;line-height:1.3}

/* Alex mini en auth */
.alex-auth-hint{
  display:flex;gap:10px;align-items:flex-start;
  background:rgba(200,146,58,.07);border:1px solid rgba(200,146,58,.15);
  border-radius:10px;padding:12px;margin-bottom:20px;
}
.alex-auth-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#1a1206,#3d2a10);border:1.5px solid var(--gold);display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.alex-auth-text{font-size:12.5px;color:var(--cream);line-height:1.5}

/* Campos */
.field{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}
.field label{font-size:12px;color:var(--text2);font-weight:500}
.field input,.field select{
  background:var(--surface);border:1px solid var(--line2);color:var(--text);
  padding:11px 14px;border-radius:9px;font-size:14px;font-family:'DM Sans',sans-serif;
  outline:none;transition:border .15s;
}
.field input:focus,.field select:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(200,146,58,.08)}
.field select option{background:var(--surface)}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}

/* Botones */
.btn{padding:11px 20px;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;border:none;font-family:'DM Sans',sans-serif;transition:all .15s;display:flex;align-items:center;justify-content:center;gap:6px}
.btn-primary{background:linear-gradient(135deg,var(--gold),var(--gold2));color:#000;width:100%;padding:13px}
.btn-primary:hover{filter:brightness(1.08);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--text2);border:1px solid var(--line2)}
.btn-ghost:hover{color:var(--text);border-color:var(--text3)}
.btn-sage{background:rgba(46,184,122,.15);color:var(--sage);border:1px solid rgba(46,184,122,.25)}
.btn-sky{background:rgba(61,142,240,.15);color:var(--sky);border:1px solid rgba(61,142,240,.25)}
.btn-sm{padding:6px 14px;font-size:12.5px}
.btn-danger{background:rgba(224,86,66,.12);color:var(--coral);border:1px solid rgba(224,86,66,.2)}

/* Toggle auth */
.auth-toggle{text-align:center;margin-top:20px;font-size:13px;color:var(--text3)}
.auth-toggle a{color:var(--gold);cursor:pointer;text-decoration:none}
.auth-toggle a:hover{color:var(--gold2)}
.auth-error{background:rgba(224,86,66,.1);border:1px solid rgba(224,86,66,.2);color:var(--coral);padding:10px 12px;border-radius:8px;font-size:13px;margin-bottom:14px;display:none}
.auth-success{background:rgba(46,184,122,.1);border:1px solid rgba(46,184,122,.2);color:var(--sage);padding:10px 12px;border-radius:8px;font-size:13px;margin-bottom:14px;display:none}
.promo-row{display:flex;gap:8px;margin-top:16px;padding-top:16px;border-top:1px solid var(--line)}
.promo-row input{flex:1;background:var(--surface);border:1px solid var(--line2);color:var(--text);padding:9px 12px;border-radius:8px;font-size:13px;font-family:'DM Mono',monospace;outline:none;text-transform:uppercase}

/* ══════════════════════════════════════════════════
   APP SHELL
══════════════════════════════════════════════════ */
#app{display:none;flex-direction:column;height:100dvh;overflow:hidden}

/* TOPBAR */
.topbar{height:52px;flex-shrink:0;display:flex;align-items:center;justify-content:space-between;padding:0 20px;background:var(--deep);border-bottom:1px solid var(--line);z-index:20}
.topbar-left{display:flex;align-items:center;gap:16px}
.top-logo{font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:700;color:var(--gold);cursor:pointer}
.top-pill{display:flex;align-items:center;gap:6px;background:var(--surface);border:1px solid var(--line2);padding:4px 10px;border-radius:16px;font-size:11.5px;color:var(--text2)}
.top-pill-dot{width:5px;height:5px;border-radius:50%}
.top-pill-dot.prop{background:var(--gold)}
.top-pill-dot.comp{background:var(--sky)}
.top-pill-dot.pro{background:var(--sage)}
.topbar-nav{display:flex;gap:2px}
.tnav{padding:5px 12px;border-radius:7px;font-size:13px;cursor:pointer;color:var(--text2);transition:all .12s;border:none;background:transparent;font-family:'DM Sans',sans-serif;font-weight:500}
.tnav:hover{background:rgba(255,255,255,.05);color:var(--text)}
.tnav.active{background:rgba(200,146,58,.1);color:var(--gold)}
.topbar-right{display:flex;align-items:center;gap:8px}
.user-chip{display:flex;align-items:center;gap:7px;padding:4px 10px 4px 6px;border-radius:20px;background:var(--surface);border:1px solid var(--line);cursor:pointer;font-size:12.5px;color:var(--text2)}
.user-avatar{width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--gold2));display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#000}
.live-badge{display:flex;align-items:center;gap:4px;font-size:10px;color:var(--sage);background:rgba(46,184,122,.1);padding:3px 8px;border-radius:12px}

/* SHELL */
.shell{display:flex;flex:1;overflow:hidden}

/* SIDEBAR */
.sidebar{width:220px;flex-shrink:0;background:var(--deep);border-right:1px solid var(--line);display:flex;flex-direction:column;overflow:hidden}
.sb-section{font-size:9.5px;color:var(--text3);text-transform:uppercase;letter-spacing:1.5px;padding:16px 16px 5px}
.sb-item{display:flex;align-items:center;gap:9px;padding:8px 16px;cursor:pointer;border-left:2px solid transparent;transition:all .12s;font-size:13px;color:var(--text2);user-select:none}
.sb-item:hover{background:rgba(200,146,58,.04);color:var(--text)}
.sb-item.active{border-left-color:var(--gold);background:rgba(200,146,58,.07);color:var(--gold)}
.sb-item.active-sky{border-left-color:var(--sky);background:rgba(61,142,240,.07);color:var(--sky)}
.sb-item.active-sage{border-left-color:var(--sage);background:rgba(46,184,122,.07);color:var(--sage)}
.sb-icon{font-size:15px;width:18px;text-align:center;flex-shrink:0}
.sb-badge{margin-left:auto;font-size:10px;padding:1px 5px;border-radius:8px;font-weight:700}
.sb-badge-gold{background:rgba(200,146,58,.2);color:var(--gold)}
.sb-badge-coral{background:rgba(224,86,66,.2);color:var(--coral)}
.sb-group{margin-bottom:1px}
.sb-group-header{display:flex;align-items:center;gap:8px;padding:6px 14px 6px 14px;cursor:pointer;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:1.1px;color:var(--text3);user-select:none;transition:all .15s;border-left:2px solid transparent}
.sb-group-header:hover{color:var(--text2)}
.sb-group-header.open{color:var(--text2)}
.sb-group-arrow{margin-left:auto;font-size:8px;transition:transform .2s;display:inline-block;opacity:.4}
.sb-group-header.open .sb-group-arrow{transform:rotate(90deg);opacity:.7}
.sb-group-items{overflow:hidden;max-height:0;transition:max-height .28s ease}
.sb-group-items.open{max-height:900px}
.sb-group-items .sb-item{padding-left:30px;font-size:12.5px;position:relative;gap:7px}
.sb-group-items .sb-item::before{content:'';position:absolute;left:16px;top:50%;transform:translateY(-50%);width:4px;height:4px;border-radius:50%;background:var(--line2);opacity:.8}
.sb-group-items .sb-item.active::before{background:var(--gold);opacity:1;box-shadow:0 0 4px rgba(200,146,58,.4)}
.sb-group-items .sb-item.active{color:var(--gold)}
.sb-divider{height:1px;background:rgba(255,255,255,.05);margin:6px 14px}
.sb-badge-sage{background:rgba(46,184,122,.2);color:var(--sage)}
.sidebar-footer{margin-top:auto;border-top:1px solid var(--line)}

/* ALEX mini sidebar */
.alex-mini{display:flex;align-items:center;gap:9px;padding:12px 16px;cursor:pointer;transition:background .15s}
.alex-mini:hover{background:rgba(200,146,58,.05)}
.alex-mini-avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,#1a1206,#3d2a10);border:1.5px solid var(--gold);display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;position:relative}
.alex-online-dot{position:absolute;bottom:-1px;right:-1px;width:8px;height:8px;background:var(--sage);border-radius:50%;border:1.5px solid var(--deep)}
.alex-mini-info{flex:1;min-width:0}
.alex-mini-name{font-size:12px;font-weight:600;color:var(--gold)}
.alex-mini-status{font-size:10.5px;color:var(--text3)}
.alex-mini-icon{color:var(--gold);font-size:14px}

/* MAIN */
.main{flex:1;overflow-y:auto;position:relative}

/* ══════════════════════════════════════════════════
   ALEX AGENT — CHAT FLOTANTE
══════════════════════════════════════════════════ */
/* Hide alex button when auth screen is showing */
#auth-screen:not(.hidden) ~ #alex-btn,
#auth-screen:not([style*="display:none"]) ~ #alex-btn,
#auth-screen:not([style*="display: none"]) ~ #alex-btn { display: none !important; }
#auth-screen:not(.hidden) ~ #alex-chat,
#auth-screen:not([style*="display:none"]) ~ #alex-chat,
#auth-screen:not([style*="display: none"]) ~ #alex-chat { display: none !important; }

#alex-btn{
  position:fixed;bottom:20px;right:20px;
  width:48px;height:48px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold),var(--gold2));
  border:none;cursor:pointer;z-index:200;
  display:flex;align-items:center;justify-content:center;font-size:20px;
  box-shadow:0 4px 20px rgba(200,146,58,.4);
  animation:alexPulse 3s ease infinite;
}
@keyframes alexPulse{0%,100%{box-shadow:0 4px 20px rgba(200,146,58,.4)}50%{box-shadow:0 4px 30px rgba(200,146,58,.7)}}
#alex-unread{
  position:absolute;top:-3px;right:-3px;width:16px;height:16px;
  background:var(--coral);border-radius:50%;border:2px solid var(--deep);
  font-size:9px;font-weight:700;color:#fff;display:none;align-items:center;justify-content:center;
}

#alex-chat{
  position:fixed;bottom:76px;right:20px;width:360px;
  background:var(--deep);border:1px solid var(--line2);border-radius:16px;
  box-shadow:0 20px 60px rgba(0,0,0,.6);z-index:200;
  display:flex;flex-direction:column;
  transform:translateY(20px) scale(.95);opacity:0;pointer-events:none;
  transition:all .25s cubic-bezier(.34,1.56,.64,1);
  max-height:480px;
}
#alex-chat.open{transform:translateY(0) scale(1);opacity:1;pointer-events:all}
.alex-chat-header{
  padding:12px 14px;border-bottom:1px solid var(--line);
  display:flex;align-items:center;gap:10px;flex-shrink:0;
}
.alex-chat-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#1a1206,#3d2a10);border:2px solid var(--gold);display:flex;align-items:center;justify-content:center;font-size:17px;position:relative;flex-shrink:0}
.alex-chat-info{flex:1}
.alex-chat-name{font-family:'Cormorant Garamond',serif;font-size:15px;font-weight:600;color:var(--gold)}
.alex-chat-sub{font-size:10.5px;color:var(--text3)}
.alex-chat-close{width:26px;height:26px;border-radius:7px;background:transparent;border:1px solid var(--line);color:var(--text2);cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center}
.alex-msgs{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:8px;min-height:160px;max-height:280px}
.alex-msg{max-width:86%;padding:9px 12px;font-size:12.5px;line-height:1.5;border-radius:10px;animation:msgIn .2s ease}
@keyframes msgIn{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}
.alex-msg.alex{background:rgba(200,146,58,.1);border:1px solid rgba(200,146,58,.15);color:var(--cream);border-radius:10px 10px 10px 3px}
.alex-msg.user{background:var(--surface);border:1px solid var(--line);color:var(--text);margin-left:auto;border-radius:10px 10px 3px 10px}
.alex-actions{display:flex;flex-wrap:wrap;gap:5px;padding:0 12px 8px}
.alex-action-chip{background:rgba(200,146,58,.08);border:1px solid rgba(200,146,58,.2);color:var(--gold);padding:4px 10px;border-radius:20px;font-size:11px;cursor:pointer;transition:all .12s}
.alex-action-chip:hover{background:rgba(200,146,58,.18)}
.alex-typing{display:flex;gap:3px;padding:8px 12px;align-items:center}
.alex-typing-dot{width:5px;height:5px;border-radius:50%;background:var(--gold);opacity:.4;animation:td 1.2s infinite}
.alex-typing-dot:nth-child(2){animation-delay:.2s}
.alex-typing-dot:nth-child(3){animation-delay:.4s}
@keyframes td{0%,60%,100%{opacity:.3;transform:scale(1)}30%{opacity:1;transform:scale(1.2)}}
.alex-input-row{padding:10px;border-top:1px solid var(--line);display:flex;gap:7px;flex-shrink:0}
.alex-input{flex:1;background:var(--surface);border:1px solid var(--line2);color:var(--text);padding:8px 11px;border-radius:9px;font-size:12.5px;font-family:'DM Sans',sans-serif;outline:none}
.alex-input:focus{border-color:rgba(200,146,58,.4)}
.alex-send{width:34px;height:34px;border-radius:9px;background:var(--gold);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:13px;color:#000;font-weight:700}

/* Alex burbuja inline */
.alex-bubble{
  display:flex;gap:10px;align-items:flex-start;
  background:linear-gradient(135deg,rgba(200,146,58,.07),rgba(200,146,58,.03));
  border:1px solid rgba(200,146,58,.18);border-radius:12px;
  padding:12px 14px;margin-bottom:20px;
  animation:bubbleIn .3s ease;
}
@keyframes bubbleIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
.alex-bubble-av{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#1a1206,#3d2a10);border:1.5px solid var(--gold);display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0}
.alex-bubble-body{flex:1}
.alex-bubble-who{font-size:10px;color:var(--gold);font-weight:700;text-transform:uppercase;letter-spacing:.8px;margin-bottom:4px}
.alex-bubble-text{font-size:13px;color:var(--cream);line-height:1.5}
.alex-bubble-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.alex-chip{background:rgba(200,146,58,.1);border:1px solid rgba(200,146,58,.22);color:var(--gold);padding:4px 10px;border-radius:20px;font-size:11.5px;cursor:pointer;transition:all .12s}
.alex-chip:hover{background:rgba(200,146,58,.2)}

/* ══════════════════════════════════════════════════
   VISTAS DE CONTENIDO
══════════════════════════════════════════════════ */
.view{padding:24px 28px;animation:vFade .25s ease}
@keyframes vFade{from{opacity:0}to{opacity:1}}
.view-head{margin-bottom:24px}
.view-title{font-family:'Cormorant Garamond',serif;font-size:28px;font-weight:600;color:var(--cream)}
.view-sub{font-size:13.5px;color:var(--text2);margin-top:4px}

/* CARDS */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.card-header{padding:14px 18px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between}
.card-title{font-size:13.5px;font-weight:600;color:var(--text)}
.card-sub{font-size:11px;color:var(--text3);margin-top:2px}
.card-body{padding:18px}

/* GRIDS */
.g2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.g3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}

/* KPIs */
.kpi{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:16px 18px;position:relative;overflow:hidden}
.kpi::after{content:'';position:absolute;bottom:-10px;right:-10px;width:70px;height:70px;border-radius:50%;opacity:.05}
.kpi-label{font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:.8px;margin-bottom:8px}
.kpi-value{font-family:'Cormorant Garamond',serif;font-size:30px;font-weight:700;line-height:1}
.kpi-note{font-size:11px;color:var(--text3);margin-top:5px}
.kpi-gold .kpi-value{color:var(--gold)}.kpi-gold::after{background:var(--gold)}
.kpi-sage .kpi-value{color:var(--sage)}.kpi-sage::after{background:var(--sage)}
.kpi-sky .kpi-value{color:var(--sky)}.kpi-sky::after{background:var(--sky)}
.kpi-coral .kpi-value{color:var(--coral)}.kpi-coral::after{background:var(--coral)}

/* TAGS */
.tag{display:inline-flex;align-items:center;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:500}
.tg{background:rgba(200,146,58,.12);color:var(--gold)}
.ts{background:rgba(46,184,122,.12);color:var(--sage)}
.tk{background:rgba(61,142,240,.12);color:var(--sky)}
.tc{background:rgba(224,86,66,.12);color:var(--coral)}
.tz{background:rgba(255,255,255,.06);color:var(--text3)}
.ta{background:rgba(224,144,32,.12);color:var(--amber)}

/* STEPS */
.steps{display:flex;align-items:center;margin-bottom:24px;gap:0}
.step{display:flex;flex-direction:column;align-items:center;gap:4px;flex:1;position:relative}
.step:not(:last-child)::after{content:'';position:absolute;top:13px;left:60%;width:80%;height:1px;background:var(--line2)}
.step-dot{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;z-index:1}
.step-dot.done{background:var(--sage);color:#000}
.step-dot.active{background:var(--gold);color:#000}
.step-dot.pending{background:var(--surface);border:1px solid var(--line2);color:var(--text3)}
.step-lbl{font-size:10px;color:var(--text3);text-align:center}
.step.active .step-lbl{color:var(--gold)}
.step.done .step-lbl{color:var(--sage)}

/* UPLOAD ZONE */
.upload-zone{border:2px dashed var(--line2);border-radius:10px;padding:28px;text-align:center;cursor:pointer;transition:all .2s;position:relative}
.upload-zone:hover,.upload-zone.drag{border-color:var(--gold);background:rgba(200,146,58,.04)}
.upload-zone input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer}
.upload-icon{font-size:28px;margin-bottom:8px}
.upload-text{font-size:13.5px;color:var(--text2)}
.upload-sub{font-size:11px;color:var(--text3);margin-top:3px}

/* SCORE BAR */
.score-bar-row{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.score-bar-label{font-size:12px;color:var(--text2);width:100px;flex-shrink:0}
.score-bar-track{flex:1;height:5px;background:rgba(255,255,255,.05);border-radius:3px;overflow:hidden}
.score-bar-fill{height:100%;border-radius:3px;transition:width .8s cubic-bezier(.34,1.1,.64,1)}
.score-bar-val{font-size:11px;font-family:'DM Mono',monospace;color:var(--text3);width:50px;text-align:right;flex-shrink:0}

/* PRICE HERO */
.price-hero{
  background:linear-gradient(135deg,rgba(200,146,58,.08),rgba(200,146,58,.03));
  border:1px solid rgba(200,146,58,.18);border-radius:14px;
  padding:24px;text-align:center;margin-bottom:16px;
}
.price-hero-label{font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:1px;margin-bottom:8px}
.price-hero-value{font-family:'Cormorant Garamond',serif;font-size:44px;font-weight:700;color:var(--gold);line-height:1}
.price-hero-range{font-size:13px;color:var(--text3);margin-top:8px}
.price-hero-conf{margin-top:12px}

/* VERDICT BANNER */
.verdict-banner{border-radius:12px;padding:16px 18px;display:flex;align-items:center;gap:14px;margin-bottom:16px}
.verdict-banner.muy_caro{background:rgba(224,86,66,.1);border:1px solid rgba(224,86,66,.25)}
.verdict-banner.caro{background:rgba(224,144,32,.1);border:1px solid rgba(224,144,32,.25)}
.verdict-banner.precio_justo{background:rgba(61,142,240,.08);border:1px solid rgba(61,142,240,.2)}
.verdict-banner.oportunidad,.verdict-banner.gran_oportunidad{background:rgba(46,184,122,.08);border:1px solid rgba(46,184,122,.2)}
.verdict-icon{font-size:26px}
.verdict-title{font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:600}
.verdict-sub{font-size:12px;color:var(--text2);margin-top:2px}

/* RISK ROW */
.risk-row{display:flex;align-items:center;gap:10px;padding:10px 13px;border-radius:9px;margin-bottom:7px}
.risk-row.critico{background:rgba(224,86,66,.07);border:1px solid rgba(224,86,66,.18)}
.risk-row.alto{background:rgba(224,144,32,.07);border:1px solid rgba(224,144,32,.18)}
.risk-row.medio{background:rgba(61,142,240,.06);border:1px solid rgba(61,142,240,.15)}
.risk-row.bajo,.risk-row.ok,.risk-row.sin_riesgo{background:rgba(46,184,122,.06);border:1px solid rgba(46,184,122,.15)}
.risk-icon{font-size:16px;width:22px;text-align:center}
.risk-label{flex:1;font-size:12.5px;font-weight:500}
.risk-cost{font-size:11px;font-family:'DM Mono',monospace;color:var(--text3)}

/* PAYWALL */
.paywall-block{background:linear-gradient(135deg,rgba(200,146,58,.07),rgba(200,146,58,.02));border:1px solid rgba(200,146,58,.2);border-radius:14px;padding:22px;text-align:center}
.paywall-icon{font-size:32px;margin-bottom:10px}
.paywall-title{font-family:'Cormorant Garamond',serif;font-size:20px;color:var(--cream);margin-bottom:6px}
.paywall-sub{font-size:13px;color:var(--text2);margin-bottom:18px}
.plan-cards-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}
.plan-card{background:var(--raised);border:1px solid var(--line2);border-radius:10px;padding:14px;cursor:pointer;transition:all .15s;text-align:left}
.plan-card:hover{border-color:rgba(200,146,58,.4)}
.plan-card.feat{border-color:var(--gold);background:rgba(200,146,58,.05)}
.plan-card-label{font-size:10px;color:var(--text3);margin-bottom:4px}
.plan-card-name{font-size:13.5px;font-weight:600;margin-bottom:4px;color:var(--text)}
.plan-card-price{font-family:'Cormorant Garamond',serif;font-size:22px;color:var(--gold)}
.plan-card-launch{font-size:11px;color:var(--sage)}
.plan-card-items{margin-top:8px;display:flex;flex-direction:column;gap:3px}
.plan-card-item{font-size:11px;color:var(--text2);display:flex;gap:4px}

/* PROMO RESULT */
.promo-ok{background:rgba(46,184,122,.08);border:1px solid rgba(46,184,122,.2);border-radius:10px;padding:14px}
.promo-fail{background:rgba(224,86,66,.08);border:1px solid rgba(224,86,66,.2);border-radius:10px;padding:14px}

/* VERIFY BADGE */
.verify-banner{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:10px;margin-bottom:16px;font-size:13px}
.verify-banner.no_verificado{background:rgba(224,86,66,.07);border:1px solid rgba(224,86,66,.2);color:var(--coral)}
.verify-banner.pendiente{background:rgba(224,144,32,.07);border:1px solid rgba(224,144,32,.2);color:var(--amber)}
.verify-banner.verificado{background:rgba(46,184,122,.07);border:1px solid rgba(46,184,122,.2);color:var(--sage)}

/* LOADING SPINNER */
.spinner{width:18px;height:18px;border:2px solid var(--line2);border-top-color:var(--gold);border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.loading-center{display:flex;align-items:center;justify-content:center;padding:60px}

/* EMPTY STATE */
.empty{text-align:center;padding:48px 20px;color:var(--text3)}
.empty-icon{font-size:36px;margin-bottom:12px}
.empty-text{font-size:14px;margin-bottom:16px}

/* RENTAL YIELD BLOCK */
.yield-card{background:var(--raised);border:1px solid var(--line);border-radius:12px;overflow:hidden}
.yield-header{padding:14px 18px;background:var(--surface);border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center}
.yield-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-bottom:1px solid var(--line)}
.yield-cell{padding:14px 16px;border-right:1px solid var(--line)}
.yield-cell:last-child{border-right:none}
.yield-cell-label{font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:.7px;margin-bottom:6px}
.yield-cell-val{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:600}
.yield-consequence{padding:12px 16px;border-bottom:1px solid var(--line);display:flex;gap:10px;align-items:flex-start}
.yield-consequence.critica{border-left:3px solid var(--coral)}
.yield-consequence.alta{border-left:3px solid var(--amber)}
.yield-consequence.media{border-left:3px solid var(--sky)}
.yield-consequence-type{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;flex-shrink:0;width:90px;margin-top:2px}
.yield-consequence-text{font-size:12px;color:var(--text2);line-height:1.5}

/* PROFESSIONAL VERIFY FORM */
.verify-form-card{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:24px;max-width:600px}
.verify-checks{display:flex;flex-direction:column;gap:8px;margin-top:16px}
.check-item{display:flex;align-items:center;gap:10px;font-size:13px}
.check-icon.ok{color:var(--sage)}
.check-icon.fail{color:var(--coral)}
.check-icon.pending{color:var(--text3)}

/* TABS */
.tabs{display:flex;background:var(--raised);border-radius:10px;padding:3px;margin-bottom:20px;border:1px solid var(--line);width:fit-content}
.tab{padding:7px 16px;border-radius:8px;font-size:13px;cursor:pointer;color:var(--text3);transition:all .15s;font-weight:500}
.tab.active{background:var(--surface);color:var(--text);box-shadow:0 1px 4px rgba(0,0,0,.3)}

/* LISTING INPUT */
.url-input-row{display:flex;gap:10px;margin-bottom:20px}
.url-input{flex:1;background:var(--surface);border:1px solid var(--line2);color:var(--text);padding:12px 16px;border-radius:10px;font-size:14px;outline:none;transition:border .15s;font-family:'DM Sans',sans-serif}
.url-input:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(200,146,58,.08)}
.portal-tags{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:20px}

/* NOTIFICATION */
.notif{position:fixed;bottom:80px;left:50%;transform:translateX(-50%);background:var(--surface);border:1px solid var(--gold);color:var(--gold);padding:10px 20px;border-radius:10px;font-size:13px;z-index:300;animation:notifIn .3s ease;box-shadow:0 4px 20px rgba(0,0,0,.4)}
@keyframes notifIn{from{opacity:0;transform:translateX(-50%) translateY(10px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}

/* IMG GRID */
.img-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:16px}
.img-thumb{border-radius:8px;overflow:hidden;aspect-ratio:1;background:var(--raised);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;position:relative}
.img-thumb-type{position:absolute;bottom:4px;left:4px;right:4px;background:rgba(0,0,0,.7);font-size:9px;color:#fff;padding:2px 5px;border-radius:4px;text-align:center}

/* PHOTO TYPE PICKER */
.photo-types{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:16px}
.photo-type-label{
  display:flex;flex-direction:column;align-items:center;gap:5px;
  padding:12px 8px;background:var(--raised);border:1px solid var(--line2);
  border-radius:9px;cursor:pointer;text-align:center;transition:all .15s;
  position:relative;overflow:hidden;
}
.photo-type-label input{position:absolute;inset:0;opacity:0;cursor:pointer}
.photo-type-label:hover{border-color:rgba(200,146,58,.4)}
.photo-type-label.done{border-color:var(--sage)}
.photo-type-icon{font-size:20px}
.photo-type-name{font-size:11px;font-weight:600;color:var(--text)}
.photo-type-hint{font-size:9px;color:var(--text3)}
.photo-type-check{position:absolute;top:4px;right:4px;font-size:12px;color:var(--sage);display:none}
.photo-type-label.done .photo-type-check{display:block}

/* INVESTMENT SCENARIO */
.scenario-row{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:8px;margin-bottom:6px}
.scenario-row.cons{background:rgba(255,255,255,.03);border:1px solid var(--line)}
.scenario-row.base{background:rgba(200,146,58,.07);border:1px solid rgba(200,146,58,.2)}
.scenario-row.opt{background:rgba(46,184,122,.07);border:1px solid rgba(46,184,122,.2)}
.scenario-label{flex:1;font-size:12.5px;color:var(--text2)}
.scenario-pct{font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:600;width:70px;text-align:right}

/* PROPERTY LIST ITEM */
.prop-item{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--raised);border:1px solid var(--line2);border-radius:10px;cursor:pointer;transition:all .12s;margin-bottom:8px}
.prop-item:hover{border-color:rgba(200,146,58,.3);background:var(--surface)}
.prop-item-icon{font-size:22px;width:36px;height:36px;border-radius:8px;background:rgba(200,146,58,.1);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.prop-item-info{flex:1}
.prop-item-name{font-size:13.5px;font-weight:600;color:var(--text)}
.prop-item-meta{font-size:11px;color:var(--text3);margin-top:2px}
.prop-item-value{text-align:right}
.prop-item-price{font-family:'Cormorant Garamond',serif;font-size:16px;color:var(--gold)}
.prop-item-conf{font-size:10px;color:var(--text3)}

/* ARGUMENT ITEM */
.arg-item{display:flex;gap:8px;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.04)}
.arg-num{width:18px;height:18px;border-radius:4px;background:var(--gold);display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;color:#000;flex-shrink:0;margin-top:2px}
.arg-text{font-size:12.5px;color:var(--text2);line-height:1.5}

/* FORM SECTION */
.form-section-title{font-size:11px;color:var(--text3);text-transform:uppercase;letter-spacing:1px;margin-bottom:12px;margin-top:20px;display:flex;align-items:center;gap:8px}
.form-section-title::before{content:'';flex:1;height:1px;background:var(--line)}
.form-section-title::after{content:'';flex:1;height:1px;background:var(--line)}
.checkrow{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:12px}
.checkrow label{display:flex;align-items:center;gap:6px;font-size:12.5px;color:var(--text2);cursor:pointer;padding:5px 10px;border-radius:7px;border:1px solid var(--line2);background:var(--raised)}
.checkrow label:hover{border-color:var(--line)}
.checkrow input{accent-color:var(--gold)}

/* ══════════════════════════════════════════════════
   MOBILE / PWA — iOS & Android optimizado
══════════════════════════════════════════════════ */

/* Safe areas para notch/Dynamic Island/gesture bar */
:root {
  --safe-top: env(safe-area-inset-top, 0px);
  --safe-bot: env(safe-area-inset-bottom, 0px);
  --safe-left: env(safe-area-inset-left, 0px);
  --safe-right: env(safe-area-inset-right, 0px);
  --mob-nav-h: 60px;
}

/* Eliminar tap highlight en iOS */
*{-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none}
input,textarea,select,button{-webkit-tap-highlight-color:transparent}

/* Smooth scrolling iOS */
.main,.alex-msgs,.auth-form-panel{-webkit-overflow-scrolling:touch}

/* Inputs nativos en iOS sin zoom (min 16px) */
input,select,textarea{font-size:16px !important}

/* Fix iOS 100vh */
html{height:-webkit-fill-available}
body{min-height:-webkit-fill-available}
#app{height:100dvh}

@media (max-width:768px){

  /* ── TOPBAR MOBILE ── */
  .topbar{
    padding:0 12px;
    padding-top:var(--safe-top);
    height:calc(48px + var(--safe-top));
  }
  .topbar-nav{display:none} /* ocultamos topbar nav, usamos bottom nav */
  .live-badge{display:none}
  #lang-switcher-wrap{order:-1}
  #lang-btn span:last-child{display:none} /* hide name on mobile, show only flag */
  .top-pill{display:flex;cursor:pointer}
  .user-chip{padding:4px 8px;font-size:11px;gap:5px}
  #user-email-top{display:none}

  /* ── SIDEBAR → OCULTO en mobile ── */
  .sidebar{display:none}

  /* ── SHELL ── */
  .shell{flex-direction:column}

  /* ── MAIN ── */
  .main{
    flex:1;
    padding-bottom:calc(var(--mob-nav-h) + var(--safe-bot) + 16px);
    overflow-y:scroll;
    -webkit-overflow-scrolling:touch;
    overscroll-behavior:contain;
  }

  /* ── BOTTOM NAV BAR — el corazón del mobile ── */
  #bottom-nav{
    display:flex;
    position:fixed;
    bottom:0;left:0;right:0;
    height:calc(var(--mob-nav-h) + var(--safe-bot));
    padding-bottom:var(--safe-bot);
    background:var(--deep);
    border-top:1px solid var(--line);
    z-index:180;
    align-items:stretch;
  }
  .bnav-item{
    flex:1;display:flex;flex-direction:column;align-items:center;
    justify-content:center;gap:3px;cursor:pointer;
    border:none;background:transparent;color:var(--text3);
    font-family:'DM Sans',sans-serif;font-size:10px;font-weight:500;
    padding:6px 0;transition:color .15s;
    -webkit-tap-highlight-color:transparent;
    min-width:44px; /* WCAG touch target */
  }
  .bnav-item.active{color:var(--gold)}
  .bnav-item.active-sky{color:var(--sky)}
  .bnav-item.active-sage{color:var(--sage)}
  .bnav-icon{font-size:20px;line-height:1}
  .bnav-dot{
    position:absolute;top:5px;right:calc(50% - 14px);
    width:7px;height:7px;background:var(--coral);
    border-radius:50%;border:1.5px solid var(--deep);
  }

  /* ── CONTENT PADDING ── */
  .view{padding:16px 14px}
  .view-head{margin-bottom:16px}
  .view-title{font-size:22px}

  /* ── GRIDS → 1 columna en mobile ── */
  .g2,.g3,.g4{grid-template-columns:1fr}
  
  /* ── AUTH SCREEN MOBILE ── */
  #auth-screen{overflow-y:auto;-webkit-overflow-scrolling:touch}
  .auth-visual{
    width:100%;flex-shrink:0;
    height:auto;min-height:0;
    padding-top:var(--safe-top);
  }
  .auth-visual-content{padding:16px 16px 12px}
  .auth-logo{font-size:24px;margin-bottom:4px}
  .auth-hero{padding:4px 0}
  .auth-hero-title{font-size:26px}
  .auth-hero-sub{font-size:12px;max-width:100%;display:none}
  .auth-badge-launch{font-size:11px}
  .auth-stats{margin-top:10px;display:none}
  .auth-visual svg{display:none}
  .auth-form-panel{
    flex:1;
    padding:20px 16px 80px;
    overflow-y:scroll;
    -webkit-overflow-scrolling:touch;
    overscroll-behavior:contain;
  }
  .auth-form-card{max-width:100%;width:100%}

  /* ── CARDS ── */
  .card-body{padding:14px}
  .card-header{padding:12px 14px}
  .field-row{grid-template-columns:1fr}

  /* ── ALEX CHAT — full screen en mobile ── */
  #alex-chat{
    bottom:0;right:0;left:0;width:100%;
    border-radius:20px 20px 0 0;
    max-height:75dvh;
    border-bottom:none;
    box-shadow:0 -8px 40px rgba(0,0,0,.6);
  }
  #alex-btn{bottom:calc(var(--mob-nav-h) + var(--safe-bot) + 10px);right:14px}
  #feedback-btn{bottom:calc(var(--mob-nav-h) + var(--safe-bot) + 12px);left:14px}

  /* ── BOTONES más grandes en mobile ── */
  .btn{min-height:44px;padding:11px 16px}
  .btn-sm{min-height:36px;font-size:13px}
  .btn-primary{padding:14px}

  /* ── STEPS — horizontal scroll ── */
  .steps{overflow-x:auto;padding-bottom:4px;gap:4px}
  .step-lbl{font-size:9px}

  /* ── PHOTO TYPES — 3 col → 3 col (mantener) ── */
  .photo-types{grid-template-columns:repeat(3,1fr);gap:6px}
  .photo-type-label{padding:10px 6px}

  /* ── IMG GRID — 3 col en mobile ── */
  .img-grid{grid-template-columns:repeat(3,1fr)}

  /* ── PRICE HERO ── */
  .price-hero-value{font-size:36px}

  /* ── KPI grid ── */
  .g4{grid-template-columns:repeat(2,1fr)}

  /* ── MR. HOUSE POPUP ── */
  #mrhouse-popup .mrhouse-inner{border-radius:20px 20px 0 0;position:fixed;bottom:0;left:0;right:0;max-width:100%}

  /* ── FEEDBACK MODAL ── */
  #feedback-modal > div{border-radius:20px 20px 0 0;position:fixed;bottom:0;left:0;right:0;max-width:100%;max-height:85dvh;overflow-y:auto;border-bottom:none}

  /* ── URL input row ── */
  .url-input-row{flex-direction:column}
  .url-input-row .btn{width:100%}

  /* ── TOPBAR compact ── */
  .top-logo{font-size:18px}

  /* ── HIDE elementos innecesarios en mobile ── */
  .auth-logo-tag{display:none}
  
  /* ── YIELD grid ── */
  .yield-grid{grid-template-columns:1fr 1fr}
  .yield-cell:last-child{grid-column:span 2}

  /* ── Admin panels mobile ── */
  .g2.admin-grid{grid-template-columns:1fr}
}

/* Extra small (iPhone SE, etc.) */
@media (max-width:375px){
  .auth-hero-title{font-size:26px}
  .price-hero-value{font-size:30px}
  .g4{grid-template-columns:1fr 1fr}
  .view{padding:12px 12px}
}

/* Tablet (iPad) — sidebar visible pero más estrecho */
@media (min-width:769px) and (max-width:1024px){
  .sidebar{width:180px}
  .g4{grid-template-columns:repeat(2,1fr)}
  #bottom-nav{display:none}
}

/* Desktop — bottom nav oculto */
@media (min-width:769px){
  #bottom-nav{display:none !important}
}

/* PWA standalone mode */
@media (display-mode:standalone){
  .topbar{padding-top:max(var(--safe-top), 8px)}
  #app{height:100dvh}
}


/* ── PROFILE SWITCHER ── */
#profile-switcher{
  position:fixed;top:52px;left:0;right:0;bottom:0;
  z-index:300;display:none;
}
#profile-switcher.open{display:block}
#profile-switcher-backdrop{
  position:absolute;inset:0;background:rgba(0,0,0,.5);
}
#profile-switcher-menu{
  position:absolute;top:0;left:50%;transform:translateX(-50%);
  background:var(--deep);border:1px solid var(--line2);border-top:none;
  border-radius:0 0 14px 14px;padding:8px;
  display:flex;gap:8px;box-shadow:0 12px 40px rgba(0,0,0,.5);
  z-index:1;
}
@media(max-width:768px){
  #profile-switcher-menu{
    left:0;right:0;transform:none;
    border-radius:0;padding:12px;
    flex-direction:column;
    top:auto;bottom:0;
    border-radius:16px 16px 0 0;
    border-bottom:none;
  }
  #profile-switcher{top:0}
}
.ps-option{
  display:flex;flex-direction:column;align-items:center;gap:6px;
  padding:14px 20px;border-radius:10px;cursor:pointer;
  border:1px solid var(--line2);background:var(--surface);
  transition:all .15s;min-width:110px;
}
.ps-option:hover{transform:translateY(-2px)}
.ps-option.active-prop{border-color:var(--gold);background:rgba(200,146,58,.08)}
.ps-option.active-comp{border-color:var(--sky);background:rgba(61,142,240,.08)}
.ps-option.active-pro{border-color:var(--sage);background:rgba(46,184,122,.08)}
.ps-option.active-admin{border-color:var(--gold);background:rgba(200,146,58,.08)}
.ps-icon{font-size:26px}
.ps-name{font-size:12px;font-weight:600;color:var(--text)}
.ps-desc{font-size:10px;color:var(--text3);text-align:center;line-height:1.3}
@media(max-width:768px){
  .ps-option{flex-direction:row;min-width:0;width:100%;padding:14px}
  .ps-icon{font-size:22px}
  .ps-desc{display:none}
}

/* ── LANG SWITCHER ── */
#lang-menu { animation: vFade .15s ease }
#lang-btn, #lang-btn-auth, #theme-btn, #theme-btn-auth {
  transition: all .15s;
  -webkit-tap-highlight-color: transparent;
}
#lang-btn:hover, #theme-btn:hover { opacity:.85; transform:scale(1.04) }

/* ── LIGHT MODE extra polish ── */
body.light-mode .topbar { background:#fff; border-bottom-color:#e0dbd2 }
body.light-mode .sidebar { background:#f8f5f0; border-right-color:#e0dbd2 }
body.light-mode .card { background:#fff; border-color:#e0dbd2 }
body.light-mode .kpi { background:#fff; border-color:#e0dbd2 }
body.light-mode .prop-item { background:#f8f5f0; border-color:#e0dbd2 }
body.light-mode .prop-item:hover { background:#fff; border-color:rgba(180,130,40,.4) }
body.light-mode .sb-item:hover { background:rgba(180,130,40,.06) }
body.light-mode .sb-item.active { background:rgba(180,130,40,.12); border-left-color:var(--gold) }
body.light-mode #bottom-nav { background:#fff; border-top-color:#e0dbd2 }
body.light-mode .tabs { background:#f0ece4; border-color:#e0dbd2 }
body.light-mode .tab.active { background:#fff }
body.light-mode .price-hero { background:linear-gradient(135deg,rgba(180,130,40,.08),rgba(180,130,40,.03)); border-color:rgba(180,130,40,.2) }
body.light-mode .auth-form-panel { background:#f8f5f0 }
body.light-mode .auth-form-card h2 { color:#1a1a18 }
body.light-mode .verdict-banner.precio_justo { background:rgba(61,142,240,.06) }
body.light-mode .btn-ghost { color:#4a4840; border-color:#c8c2b8 }
body.light-mode .url-input { background:#fff; border-color:#c8c2b8; color:#1a1a18 }
body.light-mode #alex-chat { background:#fff; border-color:#c8c2b8 }
body.light-mode .alex-chat-header { border-bottom-color:#e0dbd2 }
body.light-mode .alex-input { background:#f0ece4; border-color:#c8c2b8; color:#1a1a18 }
body.light-mode .score-bar-track { background:rgba(0,0,0,.08) }
body.light-mode .scenario-row.cons { background:rgba(0,0,0,.03) }
body.light-mode .yield-card { background:#fff; border-color:#e0dbd2 }
body.light-mode .risk-row.medio { background:rgba(61,142,240,.04); border-color:rgba(61,142,240,.15) }
body.light-mode body::before { display:none } /* Remove grain in light mode */


/* ════════════════════════════════════════════════════
   LANDING PAGE — Full redesign v2
   ════════════════════════════════════════════════════ */

/* auth-screen landing: scrollable (main rule is above) */

/* Landing nav */
.ld-nav {
  position: sticky; top: 0; z-index: 50;
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 40px;
  background: rgba(6,7,9,.92);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(200,146,58,.1);
}
@media (max-width:768px) { .ld-nav { padding: 12px 16px; } }

.ld-nav-logo { font-family:'Cormorant Garamond',serif; font-size:26px; font-weight:700; color:var(--gold); letter-spacing:-.5px; }
.ld-nav-logo span { font-size:9px; color:var(--text3); letter-spacing:2px; text-transform:uppercase; display:block; margin-top:-2px; font-family:'DM Sans',sans-serif; }
.ld-nav-right { display:flex; align-items:center; gap:8px; }
.ld-nav-btn { padding:8px 18px; border-radius:8px; font-size:12.5px; font-weight:500; cursor:pointer; font-family:'DM Sans',sans-serif; transition:all .15s; }
.ld-nav-login { background:transparent; border:1px solid var(--line2); color:var(--text2); }
.ld-nav-login:hover { border-color:var(--gold); color:var(--gold); }
.ld-nav-register { background:linear-gradient(135deg,var(--gold),var(--gold2)); border:none; color:#000; font-weight:600; }
.ld-nav-register:hover { filter:brightness(1.1); }

/* Lang selector */
.ld-lang-wrap { position:relative; }
.ld-lang-btn { padding:5px 10px; border-radius:7px; background:rgba(200,146,58,.08); border:1px solid rgba(200,146,58,.18); color:var(--gold2); font-size:11px; cursor:pointer; display:flex; align-items:center; gap:4px; font-family:'DM Sans',sans-serif; }
.ld-lang-menu { display:none; position:absolute; top:calc(100% + 6px); right:0; background:var(--deep); border:1px solid var(--line2); border-radius:10px; padding:4px; min-width:150px; z-index:999; box-shadow:0 8px 24px rgba(0,0,0,.5); }
.ld-lang-menu.open { display:block; }
.ld-lang-item { display:flex; align-items:center; gap:8px; padding:8px 10px; border-radius:7px; cursor:pointer; font-size:12px; color:var(--text2); font-family:'DM Sans',sans-serif; transition:background .1s; }
.ld-lang-item:hover { background:rgba(200,146,58,.08); color:var(--gold); }

/* Hero section */
.ld-hero {
  display: grid;
  grid-template-columns: 1fr 420px;
  gap: 48px;
  align-items: center;
  max-width: 1180px; margin: 0 auto;
  padding: 64px 40px 48px;
  min-height: calc(100vh - 60px);
}
@media (max-width:960px) {
  .ld-hero { grid-template-columns:1fr; padding:40px 20px 32px; min-height:unset; gap:32px; }
}

/* Hero copy */
.ld-hero-eyebrow { display:inline-flex; align-items:center; gap:8px; background:rgba(200,146,58,.1); border:1px solid rgba(200,146,58,.2); border-radius:20px; padding:5px 14px; font-size:11px; color:var(--gold); letter-spacing:.5px; text-transform:uppercase; font-weight:500; margin-bottom:20px; }
.ld-hero-eyebrow-dot { width:6px; height:6px; border-radius:50%; background:var(--gold); animation:pulse 2s infinite; }
@keyframes pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.5;transform:scale(.8)} }

.ld-hero-title { font-family:'Cormorant Garamond',serif; font-size:58px; line-height:1.05; font-weight:600; color:var(--cream); margin-bottom:18px; }
.ld-hero-title em { font-style:italic; color:var(--gold); }
.ld-hero-title strong { color:var(--gold); font-style:normal; }
@media (max-width:960px) { .ld-hero-title { font-size:38px; } }
@media (max-width:480px) { .ld-hero-title { font-size:30px; } }

.ld-hero-sub { font-size:16px; color:var(--text2); line-height:1.65; margin-bottom:28px; max-width:540px; }
@media (max-width:480px) { .ld-hero-sub { font-size:14px; } }

.ld-hero-features { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:32px; }
.ld-feat-chip { display:flex; align-items:center; gap:5px; background:var(--raised); border:1px solid var(--line); border-radius:20px; padding:5px 12px; font-size:12px; color:var(--text2); }
.ld-feat-chip span { color:var(--gold); }

.ld-hero-stats { display:flex; gap:28px; flex-wrap:wrap; }
.ld-stat { }
.ld-stat-num { font-family:'Cormorant Garamond',serif; font-size:28px; font-weight:700; color:var(--cream); }
.ld-stat-lbl { font-size:11px; color:var(--text3); }

/* Auth form panel */
.ld-form-panel {
  background: var(--surface);
  border: 1px solid var(--line2);
  border-radius: 16px;
  padding: 28px 28px 24px;
  box-shadow: 0 24px 64px rgba(0,0,0,.4);
}
@media (max-width:960px) { .ld-form-panel { border-radius:12px; padding:22px 18px 18px; } }

.ld-form-header { text-align:center; margin-bottom:22px; }
.ld-form-title { font-size:18px; font-weight:700; color:var(--cream); margin-bottom:4px; }
.ld-form-sub { font-size:12px; color:var(--text3); }

.ld-tabs { display:flex; background:var(--raised); border-radius:10px; padding:4px; gap:4px; margin-bottom:20px; }
.ld-tab { flex:1; text-align:center; padding:8px; border-radius:7px; font-size:13px; color:var(--text3); cursor:pointer; transition:all .15s; font-family:'DM Sans',sans-serif; }
.ld-tab.active { background:var(--deep); color:var(--cream); font-weight:500; }

/* Form fields reuse existing styles */

/* Section separator */
.ld-section { max-width:1180px; margin:0 auto; padding:72px 40px; }
@media (max-width:768px) { .ld-section { padding:48px 20px; } }

.ld-section-label { font-size:11px; color:var(--gold); text-transform:uppercase; letter-spacing:2px; font-weight:600; margin-bottom:12px; }
.ld-section-title { font-family:'Cormorant Garamond',serif; font-size:42px; font-weight:600; color:var(--cream); line-height:1.1; margin-bottom:16px; }
.ld-section-title em { font-style:italic; color:var(--gold); }
@media (max-width:768px) { .ld-section-title { font-size:30px; } }
.ld-section-sub { font-size:15px; color:var(--text2); line-height:1.6; max-width:560px; }

/* Profile tabs */
.ld-profile-tabs { display:flex; gap:8px; margin-bottom:40px; flex-wrap:wrap; }
.ld-ptab { padding:8px 20px; border-radius:20px; font-size:13px; border:1px solid var(--line2); color:var(--text2); cursor:pointer; font-family:'DM Sans',sans-serif; transition:all .15s; }
.ld-ptab.active { background:var(--gold); border-color:var(--gold); color:#000; font-weight:600; }
.ld-profile-content { display:none; }
.ld-profile-content.active { display:block; }

/* Feature grid */
.ld-features-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:16px; }
.ld-feat-card { background:var(--raised); border:1px solid var(--line); border-radius:12px; padding:22px; }
.ld-feat-card-icon { font-size:26px; margin-bottom:12px; }
.ld-feat-card-title { font-size:15px; font-weight:600; color:var(--cream); margin-bottom:6px; }
.ld-feat-card-desc { font-size:13px; color:var(--text2); line-height:1.55; }
.ld-feat-card.highlight { border-color:rgba(200,146,58,.3); background:linear-gradient(135deg,var(--raised),rgba(200,146,58,.04)); }

/* How it works */
.ld-steps { display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:20px; margin-top:40px; }
.ld-step { position:relative; padding:24px 20px; }
.ld-step::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:linear-gradient(90deg,var(--gold),transparent); border-radius:2px; }
.ld-step-num { font-family:'Cormorant Garamond',serif; font-size:48px; font-weight:700; color:rgba(200,146,58,.15); line-height:1; margin-bottom:12px; }
.ld-step-title { font-size:15px; font-weight:600; color:var(--cream); margin-bottom:6px; }
.ld-step-desc { font-size:13px; color:var(--text3); line-height:1.5; }

/* Divider */
.ld-divider { border:none; border-top:1px solid var(--line); margin:0; }

/* Social proof bar */
.ld-trust-bar { background:var(--raised); border-top:1px solid var(--line); border-bottom:1px solid var(--line); padding:20px 40px; display:flex; align-items:center; justify-content:center; gap:40px; flex-wrap:wrap; }
@media (max-width:768px) { .ld-trust-bar { gap:20px; padding:16px; } }
.ld-trust-item { display:flex; align-items:center; gap:8px; font-size:13px; color:var(--text3); }
.ld-trust-item strong { color:var(--text2); }

/* Tech section */
.ld-tech-grid { display:grid; grid-template-columns:1fr 1fr; gap:32px; align-items:center; }
@media (max-width:768px) { .ld-tech-grid { grid-template-columns:1fr; } }
.ld-tech-list { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:14px; }
.ld-tech-list li { display:flex; gap:12px; align-items:flex-start; font-size:14px; color:var(--text2); line-height:1.5; }
.ld-tech-list li .icon { font-size:18px; flex-shrink:0; margin-top:1px; }
.ld-tech-list li strong { color:var(--cream); }

/* CTA section */
.ld-cta { background:linear-gradient(135deg,rgba(200,146,58,.08),rgba(200,146,58,.02)); border-top:1px solid rgba(200,146,58,.15); padding:72px 40px; text-align:center; }
.ld-cta-title { font-family:'Cormorant Garamond',serif; font-size:46px; font-weight:600; color:var(--cream); margin-bottom:14px; }
.ld-cta-title em { color:var(--gold); font-style:italic; }
.ld-cta-sub { font-size:15px; color:var(--text2); margin-bottom:28px; }
.ld-cta-actions { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }
.ld-cta-btn { padding:14px 32px; border-radius:10px; font-size:14px; font-weight:600; cursor:pointer; font-family:'DM Sans',sans-serif; }
.ld-cta-primary { background:linear-gradient(135deg,var(--gold),var(--gold2)); border:none; color:#000; }
.ld-cta-secondary { background:transparent; border:1px solid var(--line2); color:var(--text2); }

/* Footer */
.ld-footer { background:var(--deep); border-top:1px solid var(--line); padding:32px 40px; display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:16px; }
@media (max-width:768px) { .ld-footer { padding:24px 16px; flex-direction:column; align-items:flex-start; gap:12px; } }
.ld-footer-logo { font-family:'Cormorant Garamond',serif; font-size:22px; font-weight:700; color:var(--gold); }
.ld-footer-copy { font-size:11px; color:var(--text3); }
.ld-footer-links { display:flex; gap:16px; }
.ld-footer-links a { font-size:12px; color:var(--text3); text-decoration:none; }
.ld-footer-links a:hover { color:var(--text2); }

/* Ticker / animated proof */
.ld-ticker { overflow:hidden; white-space:nowrap; background:rgba(200,146,58,.05); border-top:1px solid rgba(200,146,58,.1); border-bottom:1px solid rgba(200,146,58,.1); padding:10px 0; }
.ld-ticker-inner { display:inline-flex; gap:60px; animation:ticker 30s linear infinite; }
@keyframes ticker { from{transform:translateX(0)} to{transform:translateX(-50%)} }
.ld-ticker-item { font-size:12px; color:var(--text3); display:inline-flex; align-items:center; gap:8px; }
.ld-ticker-item .dot { width:5px; height:5px; border-radius:50%; background:var(--gold); opacity:.6; }

/* Responsive form fix */
@media (max-width:960px) {
  .ld-form-panel { width:100%; max-width:460px; margin:0 auto; }
}

/* Grid visual inside hero (replaces old map) */
.ld-hero-visual { position:relative; }
.ld-hero-visual-bg { position:absolute; inset:0; background:radial-gradient(ellipse 80% 60% at 50% 40%,rgba(200,146,58,.12) 0%,transparent 70%); border-radius:12px; }

/* Scroll animations */
.ld-fade-in { opacity:0; transform:translateY(20px); transition:opacity .6s ease,transform .6s ease; }
.ld-fade-in.visible { opacity:1; transform:translateY(0); }


/* ════════════════════════════════════════════════════════════════
   PWA & MOBILE OPTIMIZATIONS v2 — TasaIA
   Targets: iPhone SE → iPhone 16 Pro Max, Android small → tablet
   ════════════════════════════════════════════════════════════════ */

/* ── Reset mobile browser quirks ──────────────────────────────── */
* {
  -webkit-tap-highlight-color: transparent;
  -webkit-touch-callout: none;
}
input, textarea, select, button {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border-radius: 0;
}
input, textarea, select {
  font-size: 16px !important; /* Prevents iOS zoom on focus */
}
a, button, [onclick], .btn, .bnav-item, .sb-item, .prop-item {
  touch-action: manipulation; /* Removes 300ms tap delay */
  cursor: pointer;
}

/* ── iOS standalone (Add to Home Screen) ─────────────────────── */
@media (display-mode: standalone) {
  /* Already handled in main CSS but reinforce */
  html { height: -webkit-fill-available; }
  body { min-height: -webkit-fill-available; }
}

/* ── Universal small phone (≤ 390px — iPhone SE, small Android) ── */
@media (max-width: 390px) {
  /* Landing hero */
  .ld-hero-title   { font-size: 28px !important; line-height: 1.1; }
  .ld-hero-sub     { font-size: 13px !important; }
  .ld-hero-stats   { gap: 16px; }
  .ld-stat-num     { font-size: 22px; }
  .ld-section-title{ font-size: 26px !important; }
  .ld-cta-title    { font-size: 28px !important; }
  .ld-features-grid{ grid-template-columns: 1fr !important; }
  .ld-steps        { grid-template-columns: 1fr !important; }
  .ld-tech-grid    { grid-template-columns: 1fr !important; }

  /* Form panel */
  .ld-form-panel   { padding: 18px 14px !important; }
  .ld-tabs         { gap: 2px; }
  .ld-tab          { font-size: 12px; padding: 8px 4px; }

  /* Nav */
  .ld-nav          { padding: 10px 12px !important; }
  .ld-nav-logo     { font-size: 20px !important; }
  .ld-nav-btn      { padding: 7px 12px !important; font-size: 11.5px !important; }

  /* App internals */
  .view-title      { font-size: 20px !important; }
  .card            { padding: 0 !important; }
  .card-body       { padding: 12px !important; }
  .g2              { grid-template-columns: 1fr !important; }
  .field-row       { flex-direction: column !important; }
  .btn             { min-height: 44px; }
  .field input, .field select, .field textarea { min-height: 44px; }
}

/* ── Standard mobile (≤ 480px) ────────────────────────────────── */
@media (max-width: 480px) {
  /* Ensure tap targets ≥ 44px (Apple HIG) / 48dp (Material) */
  .btn, button { min-height: 44px; }
  .sb-item     { min-height: 44px; }
  .bnav-item   { min-height: 52px; }
  .prop-item   { min-height: 60px; }
  input, select, textarea { min-height: 44px; padding: 10px 12px; }

  /* Landing */
  .ld-hero        { padding: 32px 16px 24px !important; }
  .ld-section     { padding: 40px 16px !important; }
  .ld-trust-bar   { gap: 12px !important; padding: 14px 12px !important; }
  .ld-trust-item  { font-size: 11.5px !important; }
  .ld-footer      { padding: 20px 16px !important; }
  .ld-cta         { padding: 48px 16px !important; }

  /* Profile tabs scroll horizontal on small screens */
  .ld-profile-tabs {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    flex-wrap: nowrap !important;
    padding-bottom: 4px;
    scrollbar-width: none;
  }
  .ld-profile-tabs::-webkit-scrollbar { display: none; }
  .ld-ptab { white-space: nowrap; flex-shrink: 0; }

  /* FAQ grid → single col */
  #faq .ld-features-grid > * { grid-column: 1 / -1; }
  #faq [style*="grid-template-columns:1fr 1fr"] {
    grid-template-columns: 1fr !important;
  }

  /* Nav links hidden on mobile (use bottom nav) */
  #ld-nav-links { display: none !important; }
  .ld-nav-login { display: none !important; } /* Show only register on mobile */

  /* Hero stats compress */
  .ld-hero-stats  { gap: 20px; }
  .ld-hero-features { gap: 6px; }
  .ld-feat-chip   { font-size: 11px; padding: 4px 10px; }
}

/* ── Tablet portrait (481px–768px) ───────────────────────────── */
@media (min-width: 481px) and (max-width: 768px) {
  .ld-hero        { grid-template-columns: 1fr !important; padding: 48px 24px !important; }
  .ld-tech-grid   { grid-template-columns: 1fr !important; }
  .ld-steps       { grid-template-columns: 1fr 1fr !important; }
  .ld-features-grid { grid-template-columns: 1fr 1fr !important; }
  #faq [style*="grid-template-columns:1fr 1fr"] {
    grid-template-columns: 1fr !important;
  }
}

/* ── Tablet landscape / small desktop (769px–1024px) ─────────── */
@media (min-width: 769px) and (max-width: 1024px) {
  .ld-hero        { gap: 28px; padding: 48px 28px !important; }
  .ld-hero-title  { font-size: 44px !important; }
  .ld-section     { padding: 56px 28px; }
}

/* ── Notch / Dynamic Island safe areas ───────────────────────── */
/* Reinforcement — also applied from main CSS */
.topbar, .ld-nav {
  padding-left: max(16px, env(safe-area-inset-left));
  padding-right: max(16px, env(safe-area-inset-right));
}
#bottom-nav {
  padding-bottom: max(var(--safe-bot, 0px), env(safe-area-inset-bottom));
}
.shell, #app {
  padding-left: env(safe-area-inset-left);
  padding-right: env(safe-area-inset-right);
}

/* ── Prevent content behind notch in landscape ───────────────── */
@media (orientation: landscape) and (max-width: 900px) {
  .ld-nav {
    padding-left: max(24px, env(safe-area-inset-left));
    padding-right: max(24px, env(safe-area-inset-right));
  }
  .ld-hero { padding-left: max(20px, env(safe-area-inset-left)) !important; padding-right: max(20px, env(safe-area-inset-right)) !important; }
}

/* ── Smooth scrolling native ──────────────────────────────────── */
html { scroll-behavior: smooth; -webkit-overflow-scrolling: touch; }

/* ── Pull-to-refresh prevention (app mode) ────────────────────── */
@media (display-mode: standalone) {
  html { overscroll-behavior-y: none; }
  body { overscroll-behavior-y: none; }
}

/* ── Focus styles for keyboard / switch access ───────────────── */
:focus-visible {
  outline: 2px solid var(--gold);
  outline-offset: 2px;
  border-radius: 4px;
}

/* ── Text sizing — prevent text too small on mobile ──────────── */
@media (max-width: 480px) {
  body { font-size: 14px; }
  p, li { font-size: 14px; line-height: 1.65; }
}

/* ── Image optimization ───────────────────────────────────────── */
img { max-width: 100%; height: auto; display: block; }

/* ── Install banner mobile ────────────────────────────────────── */
#install-banner {
  position: fixed;
  bottom: calc(var(--mob-nav-h, 60px) + var(--safe-bot, 0px) + 12px);
  left: 12px; right: 12px;
  background: var(--deep);
  border: 1px solid rgba(200,146,58,.35);
  border-radius: 16px;
  padding: 16px;
  display: flex; align-items: flex-start; gap: 12px; flex-wrap: wrap;
  box-shadow: 0 8px 40px rgba(0,0,0,.6);
  z-index: 500;
  animation: slideUp .3s ease;
  max-width: 420px;
}
@keyframes slideUp { from { transform: translateY(30px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }
@keyframes slideDown { from { transform: translateY(0); opacity: 1; } to { transform: translateY(30px); opacity: 0; } }
@media (min-width: 769px) {
  #install-banner { bottom: 24px; left: auto; right: 24px; max-width: 380px; }
}
