/* ============================================================
   radars.immo — Design system (sombre CHALEUREUX)
   Partagé par login / register / dashboard / profil / premium / légales
   Identité : Fraunces (titres chaleureux) + ambre/cyan. Voir mémoire project-design-direction.
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,600;9..144,700;9..144,800&family=Manrope:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;600&display=swap');
:root{
  --bg:#0b0a10;--bg-soft:#12121c;
  --panel:rgba(255,255,255,.035);--panel-2:rgba(255,255,255,.06);
  --stroke:rgba(150,150,200,.13);--stroke-strong:rgba(160,160,210,.24);
  --txt:#f1ecf2;--muted:#9890a4;--muted-2:#6a6276;
  --blue:#4d82ff;--blue-bright:#6ba0ff;--cyan:#3ad8e0;--green:#34d39a;
  --amber:#ffb454;--amber-bright:#ffc977;
  --glow:rgba(77,130,255,.4);--warm:rgba(255,180,84,.5);
  --font-d:"Fraunces",Georgia,serif;--font-b:"Manrope",sans-serif;--font-m:"JetBrains Mono",monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--txt);font-family:var(--font-b);line-height:1.6;
  -webkit-font-smoothing:antialiased;min-height:100vh;position:relative;overflow-x:hidden}
body::before{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(55vw 55vw at 84% -10%,rgba(77,130,255,.15),transparent 60%),
             radial-gradient(46vw 46vw at 6% 90%,rgba(255,180,84,.1),transparent 58%),
             radial-gradient(40vw 40vw at 8% 8%,rgba(58,216,224,.06),transparent 55%)}
body::after{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.03;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
a{color:inherit;text-decoration:none}
.z{position:relative;z-index:2}

/* ---- NAV (app shell) ---- */
.pnav{position:sticky;top:0;z-index:50;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  background:rgba(5,7,15,.62);border-bottom:1px solid var(--stroke)}
.pnav-in{max-width:1100px;margin:0 auto;padding:13px 20px;display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.logo{display:flex;align-items:center;gap:9px;font-family:var(--font-d);font-weight:800;font-size:1.05rem;margin-right:auto}
/* Logo cliquable → accueil : retour visuel au survol (découvrabilité) */
a.logo,a.brand{cursor:pointer;transition:filter .2s ease,transform .2s ease}
a.logo:hover,a.brand:hover{filter:brightness(1.3) drop-shadow(0 0 10px rgba(34,211,238,.55));transform:translateY(-1px)}
a.logo:hover .dot,a.brand:hover .dot{filter:drop-shadow(0 0 7px rgba(58,216,224,.6))}
/* Logo = favicon Simon (appliqué partout) */
.dot{width:28px;height:28px;border-radius:7px;background:none;box-shadow:none;animation:none;flex-shrink:0;
  background-image:url('/static/favicon.png');background-size:contain;background-repeat:no-repeat;background-position:center;transition:filter .2s}
.pnav a.link{padding:9px 14px;border-radius:9px;font-size:.9rem;font-weight:600;color:var(--muted);transition:.2s;min-height:42px;display:inline-flex;align-items:center}
.pnav a.link:hover{color:var(--txt)}
.pnav a.active{background:var(--panel-2);color:var(--txt);border:1px solid var(--stroke)}
.pnav a.prem{background:linear-gradient(90deg,var(--blue),var(--cyan));color:#03101f;font-weight:800}
.pnav a.out{color:#f87171}

/* ---- LAYOUT ---- */
.wrap{max-width:1100px;margin:22px auto;padding:0 20px;position:relative;z-index:2}
.wrap-narrow{max-width:680px}
.card{background:var(--panel);border:1px solid var(--stroke);border-radius:16px;padding:24px;
  backdrop-filter:blur(10px);margin-bottom:16px}
h2.title{font-family:var(--font-d);font-weight:700;font-size:1.2rem;letter-spacing:-.01em;margin-bottom:1rem}

/* ---- AUTH (login/register centrés) ---- */
.auth{min-height:100vh;display:grid;place-items:center;padding:20px;position:relative;z-index:2}
.auth-card{width:100%;max-width:400px;background:var(--panel);border:1px solid var(--stroke);
  border-radius:20px;padding:34px 30px;backdrop-filter:blur(14px);box-shadow:0 40px 90px -40px #000}
.auth-card .brand{display:flex;align-items:center;justify-content:center;gap:9px;font-family:var(--font-d);
  font-weight:800;font-size:1.3rem}
.auth-card .tag{text-align:center;color:var(--muted);font-size:.92rem;margin:.3rem 0 1.5rem}

/* ---- FORM ---- */
label{display:block;margin:.85rem 0 .35rem;font-weight:600;font-size:.85rem}
input[type=text],input[type=email],input[type=password],input[type=number],select{
  width:100%;padding:13px;background:rgba(255,255,255,.04);border:1.5px solid var(--stroke);
  border-radius:11px;font-size:1rem;color:var(--txt);font-family:var(--font-b);transition:.2s}
input::placeholder{color:var(--muted-2)}
input:focus,select:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(61,123,255,.18);background:rgba(255,255,255,.06)}
#ban-dropdown{position:absolute;top:100%;left:0;right:0;background:#0f1830;border:1px solid var(--stroke-strong);
  border-radius:10px;margin-top:4px;z-index:60;display:none;max-height:230px;overflow-y:auto;box-shadow:0 14px 40px -12px #000}
#ban-dropdown .opt{padding:10px 14px;cursor:pointer;font-size:.88rem;border-bottom:1px solid var(--stroke)}
#ban-dropdown .opt:last-child{border-bottom:none}
#ban-dropdown .opt:hover{background:rgba(61,123,255,.14)}
#ban-dropdown .cp{color:var(--cyan);font-weight:700}
#mc-suggestions{display:flex;flex-wrap:wrap;gap:7px;margin-top:.55rem}
.mc-bulle{background:rgba(61,123,255,.14);border:1px solid var(--stroke-strong);color:var(--blue-bright);
  padding:6px 12px;border-radius:100px;font-size:.82rem;cursor:pointer;transition:.15s}
.mc-bulle:hover{background:rgba(61,123,255,.3);border-color:var(--blue)}
.row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.hint{font-size:.8rem;color:var(--muted);margin-top:.35rem}
.types{display:flex;flex-wrap:wrap;gap:8px;margin-top:.5rem}
.types label{display:inline-flex;align-items:center;gap:7px;margin:0;background:rgba(255,255,255,.04);
  border:1.5px solid var(--stroke);padding:8px 13px;border-radius:100px;font-weight:500;font-size:.85rem;cursor:pointer;transition:.2s}
.types label:hover{border-color:var(--stroke-strong)}
.types input{width:auto;accent-color:var(--blue)}
.tg{display:flex;align-items:center;gap:11px;margin-top:.7rem}
.tg input[type=checkbox]{width:22px;height:22px;accent-color:var(--blue)}

/* ---- BUTTONS ---- */
.btn{font-family:var(--font-b);font-weight:700;font-size:1rem;padding:14px 22px;border-radius:12px;cursor:pointer;
  border:1px solid transparent;transition:transform .2s,box-shadow .3s,background .2s;min-height:48px;
  display:inline-flex;align-items:center;justify-content:center;gap:9px;width:100%}
.btn-primary{background:linear-gradient(180deg,var(--blue-bright),var(--blue));color:#fff;
  box-shadow:0 10px 30px -10px var(--glow),inset 0 1px 0 rgba(255,255,255,.25)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 40px -10px var(--glow)}
.btn-ghost{background:var(--panel-2);border-color:var(--stroke-strong);color:var(--txt)}
.btn-ghost:hover{border-color:var(--blue)}
.btn-tg{background:#229ED9;color:#fff;width:auto;margin-top:.2rem}
.btn-tg:hover{transform:translateY(-2px);background:#1b87ba}
.alt{text-align:center;margin-top:1.2rem;font-size:.9rem;color:var(--muted)}
.alt a{color:var(--blue-bright);font-weight:700}

/* ---- MESSAGES ---- */
.err{background:rgba(248,113,113,.12);border:1px solid rgba(248,113,113,.3);color:#fca5a5;
  padding:11px 13px;border-radius:10px;font-size:.9rem;margin-bottom:.6rem}
.ok{background:rgba(34,197,94,.12);border:1px solid rgba(34,197,94,.3);color:#86efac;
  padding:16px;border-radius:12px;text-align:center}
.ok a{color:#86efac;font-weight:800}
.msg{background:rgba(34,197,94,.12);border:1px solid rgba(34,197,94,.3);color:#86efac;
  padding:12px;border-radius:11px;margin-bottom:14px;font-weight:600}
.teaser{margin-top:.9rem;background:rgba(245,158,11,.1);border:1px solid rgba(245,158,11,.28);
  color:#fcd34d;padding:11px 13px;border-radius:11px;font-size:.86rem}
.teaser a{color:#fde047;font-weight:800}
.tgstat{font-weight:700;margin:.1rem 0 .8rem;font-size:.92rem}
.tgstat.okc{color:#86efac}.tgstat.koc{color:#fcd34d}

/* ---- SUMMARY + PROMO (dashboard) ---- */
.promo{background:linear-gradient(120deg,rgba(61,123,255,.18),rgba(34,211,238,.08));
  border:1px solid var(--stroke-strong);border-radius:16px;padding:18px 20px;margin-bottom:18px;
  display:flex;gap:14px;align-items:center;flex-wrap:wrap;backdrop-filter:blur(10px)}
.promo b{color:#fde047}
.promo a{margin-left:auto;background:linear-gradient(90deg,var(--blue),var(--cyan));color:#03101f;font-weight:800;
  padding:11px 18px;border-radius:11px;min-height:44px;display:inline-flex;align-items:center}
.summary{background:var(--panel);border:1px solid var(--stroke);border-radius:14px;padding:14px 18px;margin-bottom:18px;
  display:flex;gap:18px;flex-wrap:wrap;align-items:center;font-size:.92rem;backdrop-filter:blur(10px)}
.summary b{color:var(--blue-bright)}
.summary .mono{font-family:var(--font-m)}

/* ---- TOOLS ---- */
.tools{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:18px}
.tool{flex:1;min-width:130px;background:var(--panel);border:1px solid var(--stroke);border-radius:12px;padding:13px;
  text-align:center;font-size:.85rem;font-weight:600;backdrop-filter:blur(10px)}
.tool.lock{color:var(--muted);opacity:.7}
.tool .lk{display:block;font-family:var(--font-m);font-size:.68rem;color:var(--amber);margin-top:4px}

/* ---- LISTINGS ---- */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}
.ann{background:var(--panel);border:1px solid var(--stroke);border-radius:15px;padding:17px;position:relative;
  display:flex;flex-direction:column;overflow:hidden;backdrop-filter:blur(10px);transition:transform .25s,border-color .25s}
.ann:hover{transform:translateY(-4px);border-color:var(--stroke-strong)}
.ann .photo{height:150px;margin:-17px -17px 13px;border-radius:14px 14px 0 0;background:#0f1830 center/cover no-repeat}
.ann.locked .photo{filter:blur(7px)}
.score{position:absolute;top:13px;right:13px;font-family:var(--font-m);font-weight:600;font-size:.82rem;color:#03150d;
  background:linear-gradient(180deg,#4ade80,#16a34a);border-radius:9px;padding:4px 10px}
.fav-btn{position:absolute;top:13px;left:13px;z-index:2;width:38px;height:38px;border-radius:50%;
  border:1px solid var(--stroke);background:rgba(5,7,15,.55);backdrop-filter:blur(4px);
  font-size:1.1rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:transform .15s,border-color .15s}
.fav-btn:hover{transform:scale(1.08);border-color:var(--stroke-strong)}
.fav-btn.active{border-color:rgba(248,113,113,.5)}
.score.mid{background:linear-gradient(180deg,#fbbf24,#d97706);color:#1c1207}.score.low{background:#475569;color:#cbd5e1}
.ann h3{font-family:var(--font-d);font-weight:700;font-size:1rem;line-height:1.3;padding-right:48px}
.prix{font-family:var(--font-d);font-weight:800;font-size:1.3rem;margin-top:8px}
.meta{color:var(--muted);font-size:.84rem;margin:.4rem 0;line-height:1.6}
.meta .src{font-family:var(--font-m);font-size:.72rem;color:var(--muted-2)}
.voir{margin-top:auto;text-align:center;background:var(--panel-2);border:1px solid var(--stroke-strong);color:var(--txt);
  padding:11px;border-radius:10px;font-weight:700;min-height:44px;display:flex;align-items:center;justify-content:center;transition:.2s}
.voir:hover{border-color:var(--blue);background:rgba(61,123,255,.12)}
.ann.locked h3,.ann.locked .prix,.ann.locked .meta{filter:blur(7px);user-select:none}
.lockover{position:absolute;inset:0;background:rgba(5,7,15,.55);backdrop-filter:blur(3px);display:flex;
  flex-direction:column;align-items:center;justify-content:center;gap:10px;text-align:center;padding:14px;font-weight:700}
.lockover a{background:linear-gradient(90deg,var(--blue),var(--cyan));color:#03101f;font-weight:800;padding:10px 16px;border-radius:10px}
.empty{background:var(--panel);border:1px solid var(--stroke);border-radius:14px;padding:42px;text-align:center;color:var(--muted)}
.empty a{color:var(--blue-bright);font-weight:700}

/* ---- PREMIUM PAGE ---- */
.phero{text-align:center;padding:52px 20px 10px}
.phero h1{font-family:var(--font-d);font-weight:800;font-size:clamp(2rem,5vw,2.8rem);letter-spacing:-.02em}
.phero h1 .g{background:linear-gradient(100deg,var(--blue-bright),var(--cyan));-webkit-background-clip:text;background-clip:text;color:transparent}
.phero p{color:var(--muted);max-width:560px;margin:14px auto 0}
.cmp{overflow:hidden;border-radius:16px;border:1px solid var(--stroke);background:var(--panel);backdrop-filter:blur(10px)}
table{width:100%;border-collapse:collapse}
th,td{padding:13px 16px;text-align:left;border-bottom:1px solid var(--stroke);font-size:.92rem}
th{font-family:var(--font-m);font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}
.colp{background:rgba(61,123,255,.07)}
.yes{color:#4ade80;font-weight:800}.no{color:var(--muted-2)}
.grid-price{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:14px}
.price{border:1px solid var(--stroke);border-radius:16px;padding:24px 18px;text-align:center;background:var(--panel);
  position:relative;backdrop-filter:blur(10px);transition:transform .25s,border-color .25s}
.price:hover{transform:translateY(-4px);border-color:var(--stroke-strong)}
.price.best{border-color:var(--blue);background:linear-gradient(180deg,rgba(61,123,255,.14),var(--panel));box-shadow:0 30px 70px -36px var(--glow)}
.price .badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);font-family:var(--font-m);font-size:.66rem;
  text-transform:uppercase;letter-spacing:.07em;background:linear-gradient(90deg,var(--blue),var(--cyan));color:#03101f;font-weight:700;padding:4px 12px;border-radius:100px}
.price .dur{font-family:var(--font-m);font-size:.8rem;text-transform:uppercase;letter-spacing:.09em;color:var(--muted)}
.price .amt{font-family:var(--font-d);font-weight:800;font-size:2.2rem;margin:10px 0 2px}
.price .mo{font-size:.8rem;color:var(--muted-2)}
.how{margin-top:18px}
.how b{color:var(--blue-bright)}

@media(max-width:640px){
  .row{grid-template-columns:1fr}.grid-price{grid-template-columns:1fr 1fr}
  .summary{font-size:.84rem}
}
@media(max-width:460px){.grid-price{grid-template-columns:1fr}.btn{width:100%}}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}
