@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');
:root{--bg:#0f1115;--card:#181b22;--fg:#e8eaed;--muted:#9aa0aa;--ok:#46c46a;--err:#e5534b;--brand:#4f8cff;--line:#272b34}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--fg);font:16px/1.55 system-ui,-apple-system,Segoe UI,Roboto,sans-serif}
.wrap{max-width:880px;margin:0 auto;padding:0 20px}
.site-header{border-bottom:1px solid var(--line);padding:16px 0}
.brand{font-weight:700;color:var(--brand);font-size:20px;letter-spacing:.3px}
main.wrap{padding-top:28px;padding-bottom:48px}
.card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:22px 24px;margin-bottom:20px}
h1{margin:.1em 0 .3em;font-size:26px}
h2{margin:.1em 0 .6em;font-size:20px}
h3{margin:1em 0 .4em;font-size:16px;color:var(--muted)}
.muted{color:var(--muted)}
.ok{color:var(--ok);font-weight:600}
.err{color:var(--err);font-weight:600}
.list{margin:.3em 0 0;padding-left:1.1em}
.list li{margin:.2em 0}
.site-footer{border-top:1px solid var(--line);padding:18px 0;color:var(--muted);font-size:14px}
.header-row{display:flex;align-items:center;justify-content:space-between;gap:16px}
.lang-switch a{color:var(--muted);text-decoration:none;margin-left:8px;padding:2px 8px;border:1px solid var(--line);border-radius:8px;font-size:14px}
.lang-switch a.active{color:#fff;border-color:var(--brand);background:rgba(79,140,255,.15)}
.brand a{color:var(--brand);text-decoration:none}
.topnav{margin-left:auto;margin-right:16px}
.topnav a{color:var(--fg);text-decoration:none;padding:6px 12px;border:1px solid var(--line);border-radius:8px}
.topnav a:hover{border-color:var(--brand)}
.header-row{flex-wrap:wrap}
details.cat{padding:0}
details.cat summary{cursor:pointer;padding:16px 20px;list-style:none}
details.cat summary::-webkit-details-marker{display:none}
details.cat[open] summary{border-bottom:1px solid var(--line)}
.pc{padding:12px 20px;border-bottom:1px solid var(--line)}
.pc:last-child{border-bottom:none}
.pc-name{font-weight:600}
.pc-products{color:var(--muted);margin:2px 0 6px;font-size:14px}
.chip{display:inline-block;font-size:12px;color:var(--fg);background:rgba(79,140,255,.12);border:1px solid var(--line);border-radius:999px;padding:1px 9px;margin:2px 4px 2px 0}
.link{color:var(--brand);text-decoration:none}
.chip.lock{background:rgba(229,83,75,.14);border-color:rgba(229,83,75,.5);color:#f0a39e}
.topnav a+a{margin-left:8px}
.offer-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}
.offer{border:1px solid var(--line);border-radius:12px;padding:16px;background:var(--card)}
.offer-type{display:inline-block;font-size:12px;font-weight:600;color:var(--brand);background:rgba(79,140,255,.12);border:1px solid var(--line);border-radius:999px;padding:1px 10px;margin-bottom:8px}
.offer-title{font-size:18px;margin:2px 0}
.offer-merchant{color:var(--muted);font-size:13px;margin-bottom:6px}
.offer-desc{font-size:14px;margin-bottom:8px}
.offer-price{margin:6px 0}
.offer-price .now{font-size:22px;font-weight:700}
.offer-price .per{color:var(--muted);font-size:13px;margin-left:2px}
.offer-price .was{display:block;color:var(--muted);font-size:13px;margin-top:2px}
.offer-meta{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px;font-size:12px}
.offer-meta span{border:1px solid var(--line);border-radius:999px;padding:1px 9px;color:var(--muted)}
.offer-meta .stocks{color:#f0a39e;border-color:rgba(229,83,75,.5)}
a.offer{display:block;text-decoration:none;color:inherit;transition:border-color .15s}
a.offer:hover{border-color:var(--brand)}
dl.detail{margin:16px 0 0;display:grid;grid-template-columns:minmax(120px,160px) 1fr;gap:8px 16px}
dl.detail dt{color:var(--muted);font-size:13px}
dl.detail dd{margin:0}
.ok{color:#7fdca4;border:1px solid rgba(127,220,164,.4);background:rgba(127,220,164,.1);padding:8px 12px;border-radius:8px}
.flag-form{margin-top:20px;padding-top:16px;border-top:1px solid var(--line);display:flex;flex-wrap:wrap;gap:10px;align-items:flex-end}
.flag-form .fl{display:flex;flex-direction:column;font-size:13px;color:var(--muted);gap:4px}
.flag-form select,.flag-form input[type=text]{background:var(--card);color:var(--fg);border:1px solid var(--line);border-radius:8px;padding:6px 10px}
.flag-form button{background:var(--brand);color:#fff;border:none;border-radius:8px;padding:8px 16px;cursor:pointer}
.flag-form .hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.search-form{margin:16px 0;padding:16px;border:1px solid var(--line);border-radius:12px;background:var(--card)}
.sf-row{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:12px}
.sf-row .fl{flex:1 1 180px}
.fl-check{display:flex;align-items:center;gap:6px;font-size:14px;align-self:flex-end}
.sf-actions{display:flex;align-items:center;gap:14px}
.search-form input[type=text],.search-form select{width:100%;background:var(--bg);color:var(--fg);border:1px solid var(--line);border-radius:8px;padding:7px 10px}
.search-form button{background:var(--brand);color:#fff;border:none;border-radius:8px;padding:9px 20px;cursor:pointer}
.tier-badge{display:inline-block;font-size:11px;font-weight:700;color:#1a1200;background:linear-gradient(135deg,#ffd86b,#f5b53d);border-radius:999px;padding:1px 8px;vertical-align:middle}
.pager{display:flex;align-items:center;justify-content:center;gap:18px;margin:20px 0}
.hero h1{margin-top:0}
.zone-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:12px}
.zone-head h2{margin:0}
.ticker{display:flex;gap:12px;overflow-x:auto;padding-bottom:6px}
.tick{flex:0 0 220px;display:flex;flex-direction:column;gap:4px;border:1px solid var(--line);border-radius:12px;padding:12px;background:var(--bg);text-decoration:none;color:inherit}
.tick:hover{border-color:var(--brand)}
.tick-type{font-size:11px;font-weight:600;color:var(--brand)}
.tick-title{font-weight:600}
.tick-price{font-size:18px;font-weight:700}
.tick-price .per{font-size:12px;font-weight:400;color:var(--muted)}
.tick-merch{font-size:12px;color:var(--muted)}
.admin-login-wrap{max-width:420px;margin:8vh auto;padding:0 16px}
.admin-login h1{margin-top:0}
.admin-shell{display:flex;min-height:100vh}
.admin-side{width:220px;flex:0 0 220px;background:var(--card);border-right:1px solid var(--line);padding:16px}
.admin-brand{font-weight:700;margin-bottom:16px}
.admin-side nav{display:flex;flex-direction:column;gap:4px}
.admin-side nav a,.admin-side nav span{padding:8px 10px;border-radius:8px;text-decoration:none;color:var(--fg);font-size:14px}
.admin-side nav a:hover{background:rgba(79,140,255,.12)}
.admin-side nav a.active{background:var(--brand);color:#fff}
.admin-side nav span.disabled{color:var(--muted)}
.admin-side nav span.disabled small{opacity:.7}
.admin-main{flex:1;min-width:0}
.admin-top{display:flex;justify-content:space-between;align-items:center;padding:12px 20px;border-bottom:1px solid var(--line)}
.admin-top-right{display:flex;gap:16px}
.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;margin:16px 0}
.stat-card{border:1px solid var(--line);border-radius:12px;padding:16px;background:var(--card)}
.stat-h{font-weight:600;margin-bottom:10px}
.stat-rows{display:flex;flex-direction:column;gap:4px;font-size:14px;color:var(--muted)}
.stat-rows b{color:var(--fg);font-size:16px}
.admin-notes p{margin:4px 0}
@media(max-width:640px){.admin-shell{flex-direction:column}.admin-side{width:auto;flex:none}}
.adm-table{width:100%;border-collapse:collapse}
.adm-table th,.adm-table td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--line);vertical-align:top;font-size:14px}
.adm-table th{color:var(--muted);font-weight:600;font-size:12px}
.badge{display:inline-block;font-size:12px;padding:1px 9px;border-radius:999px;border:1px solid var(--line)}
.st-active{color:#7fdca4;border-color:rgba(127,220,164,.5)}
.st-pending_review{color:#ffd86b;border-color:rgba(245,181,61,.5)}
.st-blocked{color:#f0a39e;border-color:rgba(229,83,75,.5)}
.adm-actions{white-space:nowrap}
.adm-actions form{margin-top:6px}
.btn-ok,.btn-danger{border:none;border-radius:8px;padding:6px 12px;cursor:pointer;font-size:13px;margin-right:6px}
.btn-ok{background:#2e7d4f;color:#fff}
.btn-danger{background:#9e2b25;color:#fff}
.adm-actions form{display:inline-block;margin:4px 6px 0 0}
.adm-actions select{margin-right:4px}
.i18n-edit{display:flex;gap:6px;align-items:center}
.i18n-edit input[type=text]{flex:1;min-width:200px;background:var(--bg);color:var(--fg);border:1px solid var(--line);border-radius:8px;padding:6px 10px}
.adm-table code{font-size:12px;color:var(--brand)}
.page-body{line-height:1.65;margin-top:12px}

/* =====================================================================
   CLICKS4 DESIGN REFRESH — light, friendly, dynamic (overrides above)
   ===================================================================== */
:root{
  --bg:#F6F8FB; --bg-soft:#EEF2F7; --card:#FFFFFF; --fg:#0F172A; --muted:#64748B;
  --line:#E6E9EF; --brand:#2563EB; --brand-600:#1D4ED8; --brand-50:#EFF4FF; --brand-100:#DCE7FF;
  --ok:#0EA15B; --ok-50:#E7F8F1; --ok-line:#A6E9C7; --ok-fg:#0A7D44;
  --err:#E11D48; --err-50:#FDEAEF; --err-line:#F5C2C7; --err-fg:#B42318;
  --warn-50:#FEF6E6; --warn-line:#F5D98A; --warn-fg:#B7791F;
  --shadow-sm:0 1px 2px rgba(16,24,40,.06);
  --shadow:0 8px 24px rgba(16,24,40,.07);
  --shadow-lg:0 18px 40px rgba(16,24,40,.12);
  --grad:linear-gradient(135deg,#2563EB 0%,#4F7BF7 50%,#22B8D6 100%);
}
body{font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--fg)}
body::before{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(640px 360px at 10% -8%, rgba(37,99,235,.10), transparent 60%),
    radial-gradient(520px 320px at 102% -2%, rgba(34,184,214,.10), transparent 55%),
    radial-gradient(620px 420px at 95% 105%, rgba(245,181,61,.08), transparent 60%);}
.wrap{max-width:1040px}
h1{font-weight:800;color:var(--fg);font-size:28px}
h2{font-weight:700}

/* header */
.site-header{position:sticky;top:0;z-index:30;background:rgba(246,248,251,.82);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.brand{font-weight:800}
.topnav a{background:#fff;box-shadow:var(--shadow-sm);transition:.15s}
.topnav a:hover{border-color:var(--brand);color:var(--brand)}
.lang-switch a.active{color:#fff;background:var(--brand);border-color:var(--brand)}

/* cards + surfaces */
.card{border-radius:18px;box-shadow:var(--shadow);border-color:var(--line)}
.search-form,.offer,.tick,.stat-card{border-radius:16px}
.search-form{background:var(--card);box-shadow:var(--shadow-sm)}
.search-form input[type=text],.search-form select{background:#fff;border-radius:10px;padding:9px 12px}
.search-form button,.flag-form button{background:var(--brand);border-radius:10px;padding:10px 22px;font-weight:600;box-shadow:0 6px 16px rgba(37,99,235,.22);transition:.15s}
.search-form button:hover,.flag-form button:hover{background:var(--brand-600)}
.flag-form select,.flag-form input[type=text]{background:#fff;border-radius:10px}

/* pills / chips / tags */
.chip{color:var(--brand);background:var(--brand-50);border-color:var(--brand-100)}
.chip.lock{color:var(--err-fg);background:var(--err-50);border-color:var(--err-line)}
.offer-type,.tick-type{color:var(--brand)}
.offer-type{background:var(--brand-50);border-color:var(--brand-100)}
.offer-meta span{color:var(--muted)}
.offer-meta .stocks{color:var(--err-fg);border-color:var(--err-line)}

/* offer + ticker cards: lift on hover */
.offer{box-shadow:var(--shadow-sm);transition:transform .15s,box-shadow .15s,border-color .15s}
a.offer:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--brand-100)}
.offer-price .now{color:var(--brand)}
.tick{background:#fff;box-shadow:var(--shadow-sm);transition:transform .15s,box-shadow .15s,border-color .15s}
.tick:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--brand-100)}
.tick-price{color:var(--brand)}

/* HERO — gradient stage with soft floating shapes */
.card.hero{background:var(--grad);color:#fff;border:none;box-shadow:var(--shadow-lg);position:relative;overflow:hidden;padding:40px 36px}
.card.hero h1{color:#fff}
.card.hero .muted,.card.hero p{color:rgba(255,255,255,.88)}
.card.hero::before{content:"";position:absolute;width:300px;height:300px;border-radius:50%;background:rgba(255,255,255,.12);top:-110px;right:-70px}
.card.hero::after{content:"";position:absolute;width:190px;height:190px;border-radius:50%;background:rgba(255,255,255,.10);bottom:-80px;left:-50px}
.card.hero .search-form{position:relative;z-index:2;background:rgba(255,255,255,.98);color:var(--fg);box-shadow:var(--shadow-lg)}
.card.hero .search-form .fl,.card.hero .search-form label{color:var(--fg)}
.card.hero .search-form .muted{color:var(--muted)}

/* category accordion */
details.cat summary:hover{background:var(--brand-50)}

/* ALERT box (.ok used as banner) */
.ok{color:var(--ok-fg);background:var(--ok-50);border:1px solid var(--ok-line)}

/* ADMIN */
.admin-side{background:#fff;box-shadow:var(--shadow-sm)}
.admin-side nav a:hover{background:var(--brand-50)}
.admin-side nav a.active{background:var(--brand);color:#fff}
.stat-card{box-shadow:var(--shadow-sm);position:relative;overflow:hidden}
.stat-card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--grad)}
.adm-table code{color:var(--brand)}

/* status badges (light tints) */
.badge.st-active{color:var(--ok-fg);background:var(--ok-50);border-color:var(--ok-line)}
.badge.st-pending_review{color:var(--warn-fg);background:var(--warn-50);border-color:var(--warn-line)}
.badge.st-blocked{color:var(--err-fg);background:var(--err-50);border-color:var(--err-line)}
.btn-ok{background:var(--ok)}
.btn-danger{background:var(--err)}

/* page CMS body */
.page-body{line-height:1.7}

/* news ticker accent */
.tick-type.news{color:#B7791F}
.tick.news{background:linear-gradient(180deg,#FEF9EE,#fff)}
.tick.news:hover{border-color:var(--warn-line)}

/* user (login) nav */
.user-nav{display:flex;gap:8px;align-items:center;margin-left:8px}
.user-nav a{color:var(--fg);text-decoration:none;padding:6px 12px;border:1px solid var(--line);border-radius:10px;background:#fff;font-size:14px;box-shadow:var(--shadow-sm);transition:.15s}
.user-nav a:hover{border-color:var(--brand);color:var(--brand)}
.user-nav a.cta{background:var(--brand);color:#fff;border-color:var(--brand)}
.user-nav a.cta:hover{background:var(--brand-600);color:#fff}
.user-chip{font-weight:600}
.badge.st-pending_review{}

/* gating CTA */
.gate{margin-top:16px;padding:18px 20px;border:1px dashed var(--brand-100);border-radius:14px;background:var(--brand-50)}
.gate p{margin:.3em 0}
.gate-btn{display:inline-block;background:var(--brand);color:#fff;text-decoration:none;border-radius:10px;padding:8px 18px;font-weight:600;margin-right:12px;box-shadow:0 6px 16px rgba(37,99,235,.22)}
.gate-btn:hover{background:var(--brand-600)}

/* reviews */
.stars{color:#F5B53D;letter-spacing:1px}
.rev-summary{font-size:14px;color:var(--muted)}
.review{padding:12px 0;border-bottom:1px solid var(--line)}
.review:last-child{border-bottom:none}
.review-head{display:flex;gap:10px;align-items:center;flex-wrap:wrap;font-size:14px}
.verified{font-size:12px;color:var(--ok-fg);background:var(--ok-50);border:1px solid var(--ok-line);border-radius:999px;padding:1px 8px}
.review-body{margin:6px 0 0}
.rating-inline{font-size:13px;color:var(--muted)}
.rating-inline .stars{font-size:13px}
.nav-badge{display:inline-block;min-width:18px;text-align:center;font-size:11px;font-weight:700;line-height:18px;color:#fff;background:var(--err);border-radius:999px;padding:0 5px;margin-left:6px}
.ac-wrap{position:relative;display:block}
.ac-wrap>input[type=text]{width:100%}
.ac-list{position:absolute;left:0;right:0;top:100%;z-index:30;background:var(--card);border:1px solid var(--line);border-radius:10px;box-shadow:0 8px 24px rgba(2,12,40,.12);max-height:240px;overflow:auto;margin-top:4px}
.ac-item{padding:8px 10px;cursor:pointer;font-size:14px}
.ac-item:hover{background:var(--brand-50)}
.tier-pick{border:1px solid var(--line);border-radius:12px;padding:10px 12px;margin:8px 0}
.tier-pick legend{padding:0 6px;color:var(--muted);font-size:13px}
.tier-pick label{margin-right:20px}
.foot-disc{font-size:12px;color:var(--muted);max-width:900px;margin:0 0 8px}
.kyc-imgs{display:flex;gap:14px;flex-wrap:wrap;margin:10px 0}
.kyc-imgs figure{margin:0}
.kyc-imgs img{max-width:300px;max-height:240px;width:auto;height:auto;border:1px solid var(--line);border-radius:10px;display:block;background:var(--bg-soft);object-fit:contain}
.kyc-imgs figcaption{font-size:12px;color:var(--muted);margin-top:4px}
.kyc-badge{display:inline-block;font-size:12px;font-weight:600;padding:2px 9px;border-radius:999px;border:1px solid var(--line);vertical-align:middle}
.kyc-badge.kyc-ok{background:#e7f6ec;border-color:#bfe6cb;color:#176b35}
.kyc-badge.kyc-warn{background:#fff5e0;border-color:#f3dca0;color:#8a5a00}
.kyc-badge.kyc-danger{background:#fdeaea;border-color:#f3c2c2;color:#9b1c1c}
.kyc-badge.kyc-muted{background:var(--bg-soft);color:var(--muted)}
table.adm-kv{border-collapse:collapse;width:100%}
table.adm-kv th{text-align:left;padding:6px 14px 6px 0;color:var(--muted);font-weight:600;white-space:nowrap;vertical-align:top;width:1%}
table.adm-kv td{padding:6px 0;border-bottom:1px solid var(--line)}
table.adm-kv tr:last-child td{border-bottom:0}
.kyc-imgs .poa-pdf{display:flex;align-items:center;justify-content:center;width:130px;height:96px;border:1px solid var(--line);border-radius:10px;background:var(--bg-soft);font-weight:600;text-decoration:none;color:var(--accent,#2563EB)}
.kyc-edit{margin-top:6px}
.kyc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:10px 0}
.kyc-grid label{display:flex;flex-direction:column;font-size:13px;color:var(--muted);gap:3px}
.kyc-grid label input,.kyc-grid label select{font-size:14px}
.kyc-grid .kyc-wide{grid-column:1 / -1}
.kyc-reject{display:flex;flex-wrap:wrap;gap:8px;align-items:flex-end;margin-top:10px;padding-top:10px;border-top:1px solid var(--line)}
.kyc-reject label{display:flex;flex-direction:column;font-size:13px;color:var(--muted);gap:3px}
.kyc-reject input[name=reason_note]{min-width:220px}
@media(max-width:640px){.kyc-grid{grid-template-columns:1fr 1fr}}
.msg-chip{text-decoration:none;font-size:17px}
.msg-tabs{display:flex;flex-wrap:wrap;gap:6px;margin:10px 0 14px}
.msg-tab{padding:5px 12px;border:1px solid var(--line);border-radius:999px;text-decoration:none;color:var(--text,#0F172A);font-size:14px}
.msg-tab.active{background:var(--accent,#2563EB);color:#fff;border-color:var(--accent,#2563EB)}
.msg-list{list-style:none;padding:0;margin:0}
.msg-item{padding:12px 0;border-bottom:1px solid var(--line)}
.msg-item:last-child{border-bottom:0}
.msg-item.unread{background:#f3f7ff;margin:0 -12px;padding:12px;border-radius:8px}
.msg-meta{display:flex;gap:8px;align-items:center;font-size:12px;margin-bottom:3px}
.msg-ch{font-weight:600;padding:1px 8px;border-radius:999px;background:var(--bg-soft);border:1px solid var(--line)}
.msg-new{font-weight:700;color:#2563EB}
.msg-subject{font-weight:600}
.msg-body{color:var(--muted);margin-top:2px}

/* === HP (homepage redesign) — scoped, additive ============================= */
:root{
  --hp-blue:#2563EB; --hp-blue-d:#1D4FD7; --hp-blue-soft:#EEF3FF;
  --hp-gold:#F59E0B; --hp-gold-soft:#FFF6E6; --hp-ok:#176B35; --hp-ok-soft:#E7F6EC;
  --hp-line:#E6EAF1; --hp-muted:#64748B; --hp-radius:14px;
  --hp-shadow:0 1px 2px rgba(15,23,42,.04),0 6px 20px rgba(15,23,42,.06);
}
.hp{max-width:1120px;margin:0 auto;padding:0 4px}
.hp .muted{color:var(--hp-muted)}
.hp .lock{display:inline-flex;align-items:center;gap:4px;font-size:11px;color:var(--hp-muted)}

.hp .hero2{padding:34px 0 22px;background:radial-gradient(1100px 360px at 80% -20%,#E7EEFF 0%,rgba(231,238,255,0) 60%)}
.hp .hero2 h1{font-size:clamp(28px,4.4vw,44px);line-height:1.07;letter-spacing:-.03em;margin:0 0 10px;font-weight:800}
.hp .hero2 h1 .live{color:var(--hp-blue)}
.hp .hero2 .lead{font-size:18px;color:var(--hp-muted);margin:0 0 20px;max-width:820px}
.hp .search2{display:flex;gap:10px;background:#fff;border:1px solid var(--hp-line);border-radius:16px;
  padding:10px;box-shadow:var(--hp-shadow);max-width:780px;flex-wrap:wrap}
.hp .search2 .f{flex:1 1 180px;display:flex;align-items:center;gap:8px;padding:6px 12px;border-radius:10px;position:relative}
.hp .search2 .ico{color:var(--hp-blue)}
.hp .search2 input,.hp .search2 select{border:0;outline:0;font-family:inherit;font-size:16px;width:100%;background:transparent;color:#0F172A}
.hp .search2 .btn2{flex:0 0 auto;border:0;cursor:pointer;font-family:inherit;font-weight:600;border-radius:10px;
  padding:12px 22px;font-size:15px;background:var(--hp-blue);color:#fff}
.hp .search2 .btn2:hover{background:var(--hp-blue-d)}
@media(max-width:640px){.hp .search2 .f{flex-basis:100%}}

.hp .qchips{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.hp .qchip{font-size:13px;font-weight:600;color:#334155;background:#fff;border:1px solid var(--hp-line);
  padding:6px 12px;border-radius:999px;text-decoration:none}
.hp .qchip:hover{border-color:var(--hp-blue);color:var(--hp-blue)}

.hp section.block{padding:22px 0}
.hp .shead{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:13px;gap:12px}
.hp .shead h2{font-size:22px;letter-spacing:-.02em;margin:0;font-weight:700}
.hp .eyebrow{display:block;font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--hp-blue);margin-bottom:3px}
.hp .more{font-size:14px;font-weight:600;color:var(--hp-blue);white-space:nowrap;text-decoration:none}

.hp .ticker2{display:flex;align-items:center;gap:12px;background:#fff;border:1px solid var(--hp-line);
  border-radius:12px;padding:9px 12px;overflow:hidden;margin-bottom:16px;box-shadow:var(--hp-shadow)}
.hp .ticker2 .tag{flex:0 0 auto;display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:700;
  color:#fff;background:var(--hp-blue);padding:4px 9px;border-radius:999px}
.hp .ticker2 .pulse{width:7px;height:7px;border-radius:50%;background:#fff;animation:hp-pulse 1.4s infinite}
.hp .ticker2 .run{white-space:nowrap;overflow:hidden;flex:1}
.hp .ticker2 .run .move{display:inline-block;padding-left:100%;animation:hp-marquee 26s linear infinite}
.hp .ticker2 a{color:#334155;text-decoration:none;font-size:14px}
.hp .ticker2 a b{color:#0F172A}
@keyframes hp-marquee{to{transform:translateX(-100%)}}
@keyframes hp-pulse{0%,100%{opacity:1}50%{opacity:.25}}

.hp .ogrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(228px,1fr));gap:16px}
@media(max-width:520px){.hp .ogrid{grid-template-columns:1fr}}
.hp .ocard{position:relative;background:#fff;border:1px solid var(--hp-line);border-radius:var(--hp-radius);
  padding:16px;box-shadow:var(--hp-shadow);display:flex;flex-direction:column;gap:9px;text-decoration:none;color:inherit;
  transition:transform .14s ease,box-shadow .14s ease}
.hp .ocard:hover{transform:translateY(-3px);box-shadow:0 10px 30px rgba(15,23,42,.10)}
.hp .ocard::before{content:"";position:absolute;left:0;right:0;top:0;height:3px;border-radius:var(--hp-radius) var(--hp-radius) 0 0;background:linear-gradient(90deg,var(--hp-blue),#5b8bff)}
.hp .ocard.premium::before{background:linear-gradient(90deg,var(--hp-gold),#f7c244)}
.hp .ocard .biz{display:flex;align-items:center;gap:7px;font-size:13px;color:var(--hp-muted)}
.hp .prem{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:700;color:#92610a;
  background:var(--hp-gold-soft);border:1px solid #f3dca0;border-radius:999px;padding:1px 8px}
.hp .ocard h3{margin:2px 0 0;font-size:16.5px;letter-spacing:-.01em;line-height:1.25}
.hp .ccat{align-self:flex-start;font-size:11.5px;font-weight:600;color:var(--hp-blue);background:var(--hp-blue-soft);border-radius:6px;padding:2px 8px}
.hp .price{font-size:20px;font-weight:800;letter-spacing:-.02em;margin-top:auto}
.hp .price small{font-size:13px;font-weight:600;color:var(--hp-muted);text-decoration:line-through}
.hp .valid{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:600;color:var(--hp-ok);
  background:var(--hp-ok-soft);border:1px solid #bfe6cb;border-radius:8px;padding:4px 9px;align-self:flex-start}

.hp .cgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}
@media(max-width:560px){.hp .cgrid{grid-template-columns:repeat(2,1fr)}}
.hp .ctile{background:#fff;border:1px solid var(--hp-line);border-radius:12px;padding:13px 12px;
  display:flex;flex-direction:column;gap:5px;box-shadow:var(--hp-shadow);text-decoration:none;color:inherit}
.hp .ctile:hover{border-color:var(--hp-blue)}
.hp .ctile .cn{font-weight:600;font-size:14px}

.hp .dgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}
@media(max-width:520px){.hp .dgrid{grid-template-columns:1fr}}
.hp .dcard{background:#fff;border:1px solid var(--hp-line);border-radius:var(--hp-radius);padding:16px;
  box-shadow:var(--hp-shadow);display:flex;gap:13px;align-items:flex-start;text-decoration:none;color:inherit}
.hp .dcard .av{flex:0 0 auto;width:46px;height:46px;border-radius:11px;background:var(--hp-blue-soft);
  color:var(--hp-blue);font-weight:800;display:flex;align-items:center;justify-content:center;font-size:18px}
.hp .dcard.premium .av{background:var(--hp-gold-soft);color:#92610a}
.hp .dcard .nm{font-weight:700;display:flex;align-items:center;gap:7px}
.hp .dcard .sub{font-size:13px;color:var(--hp-muted);margin-top:1px}
.hp .dcard .meta{font-size:12.5px;color:#334155;margin-top:7px;display:flex;gap:10px;flex-wrap:wrap}

.hp .cities{display:flex;flex-wrap:wrap;gap:9px}
.hp .city{background:#fff;border:1px solid var(--hp-line);border-radius:999px;padding:8px 14px;font-weight:600;
  font-size:14px;text-decoration:none;color:inherit}
.hp .city:hover{border-color:var(--hp-blue);color:var(--hp-blue)}
@media(prefers-reduced-motion:reduce){.hp .ticker2 .run .move{animation:none;padding-left:0}.hp .pulse{animation:none}.hp .ocard{transition:none}}

/* B23 criteria breakdown */
.crit-breakdown{display:flex;flex-direction:column;gap:4px;margin:8px 0}
.crit-row{display:flex;align-items:center;gap:10px;font-size:14px}
.crit-name{min-width:200px;color:var(--muted,#64748B)}
.crit-row .stars{color:#f59e0b;letter-spacing:1px}

/* B24 header refresh — clean .hp-style topbar */
.site-header{padding:11px 0}
.header-row{gap:14px}
.brand a{display:inline-flex;align-items:center;gap:8px;font-size:19px}
.brand a::before{content:"";width:10px;height:10px;border-radius:3px;background:var(--grad);box-shadow:0 2px 8px rgba(37,99,235,.35)}
.topnav{margin-left:auto;margin-right:10px;display:flex;gap:4px;flex-wrap:wrap}
.topnav a{background:transparent;border:1px solid transparent;box-shadow:none;color:var(--fg);font-weight:600;font-size:14px;padding:8px 13px;border-radius:10px;transition:background .15s,color .15s}
.topnav a:hover{background:var(--brand-50);border-color:transparent;color:var(--brand)}
.topnav a.active{background:var(--brand-50);color:var(--brand)}
.topnav a+a{margin-left:0}
.user-nav{gap:6px}
.user-nav a{border-radius:10px;font-weight:600}
.user-nav a.user-chip{background:var(--brand-50);border-color:transparent;color:var(--brand)}
.msg-chip{display:inline-flex;align-items:center;justify-content:center;width:38px;padding:0;height:36px;background:#fff}
.lang-switch{display:flex;align-items:center;gap:2px}
.lang-switch .muted{font-size:13px;margin-right:2px}
.lang-switch a{margin-left:4px;font-weight:600;background:#fff}
@media(max-width:820px){
  .header-row{flex-wrap:wrap;row-gap:8px}
  .topnav{order:3;width:100%;margin:2px 0 0;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;white-space:nowrap;padding-bottom:2px;scrollbar-width:none}
  .topnav::-webkit-scrollbar{display:none}
  .topnav a{flex:0 0 auto}
  .lang-switch .muted{display:none}
}

/* B26 admin action buttons */
.adm-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}
.adm-actions button{border:0;border-radius:10px;padding:9px 18px;font-weight:600;cursor:pointer;color:#fff}
.btn-ok{background:var(--brand)}
.btn-ok:hover{background:var(--brand-600)}
.btn-del{background:var(--err)}
.btn-del:hover{filter:brightness(.93)}

/* B32 — detail pages (scoped to .hp) */
.hp .dhead{display:flex;flex-direction:column;gap:11px}
.hp .dhead h1{margin:0;font-size:26px;font-weight:800;letter-spacing:-.01em}
.hp .ddl{display:grid;grid-template-columns:max-content 1fr;gap:7px 18px;margin:0;font-size:14px}
.hp .ddl dt{color:var(--hp-muted);font-weight:600}
.hp .ddl dd{margin:0;color:#0F172A}
@media(max-width:520px){.hp .ddl{grid-template-columns:1fr;gap:2px 0}.hp .ddl dd{margin:0 0 10px}}

/* B34 — mobile header / burger nav (CSS-only, RTL-safe) */
.burger{display:none}
.nav-collapse{display:contents}
@media(max-width:820px){
  .header-row{flex-wrap:wrap;align-items:center;gap:10px}
  .burger{display:inline-flex;align-items:center;justify-content:center;margin-inline-start:auto;
    width:46px;height:40px;border:1px solid var(--line);border-radius:10px;background:#fff;color:var(--fg);
    font-size:22px;line-height:1;cursor:pointer;box-shadow:var(--shadow-sm);transition:.15s}
  .burger:hover{border-color:var(--brand);color:var(--brand)}
  .nav-collapse{display:none;flex-basis:100%;flex-direction:column;align-items:stretch;gap:10px;margin-top:6px}
  .nav-toggle:checked ~ .nav-collapse{display:flex}
  .site-header .nav-collapse .topnav{order:0;width:100%;margin:0;display:flex;flex-direction:column;
    flex-wrap:nowrap;overflow:visible;white-space:normal;gap:6px}
  .site-header .nav-collapse .topnav a{flex:1 1 auto;display:block;width:100%;padding:12px 14px;
    border:1px solid var(--line);background:#fff}
  .site-header .nav-collapse .topnav a.active{background:var(--brand-50);border-color:transparent}
  .site-header .nav-collapse .user-nav{width:100%;display:flex;flex-direction:column;align-items:stretch;gap:8px;margin:0}
  .site-header .nav-collapse .user-nav a{display:block;width:100%;padding:12px 14px;text-align:start}
  .site-header .nav-collapse .msg-chip{width:auto;height:auto;justify-content:flex-start}
  .site-header .nav-collapse .lang-switch{width:100%;display:flex;flex-wrap:wrap;align-items:center;gap:6px;margin:0}
  .site-header .nav-collapse .lang-switch .muted{display:inline}
  .site-header .nav-collapse .lang-switch a{margin:0;padding:9px 13px}
}
@media(min-width:821px){.burger,.nav-toggle{display:none!important}}

/* B39 — favorite toggle button */
.fav-btn{display:inline-flex;align-items:center;gap:5px;background:#fff;border:1px solid var(--line);color:var(--fg);border-radius:999px;padding:7px 15px;font-size:13px;font-weight:600;cursor:pointer;transition:.15s}
.fav-btn:hover{border-color:var(--brand);color:var(--brand)}
.fav-btn.on{background:var(--brand-50);border-color:var(--brand);color:var(--brand)}

/* B45 — ads (card-size + banner), labeled "Werbung" */
.adcard{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;background:repeating-linear-gradient(45deg,#fafafa,#fafafa 10px,#f5f5f7 10px,#f5f5f7 20px);border:1px dashed var(--line)}
.adcard .ad-html{width:100%}
.adcard .ad-html img{max-width:100%;height:auto}
.adbanner{position:relative;margin:0 0 16px;padding:10px;border:1px dashed var(--line);border-radius:14px;background:#fafafa;text-align:center;overflow:hidden}
.adbanner .ad-html img{max-width:100%;height:auto}
.ad-tag{position:absolute;top:6px;right:8px;font-size:10px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--hp-muted);background:rgba(255,255,255,.85);padding:1px 6px;border-radius:6px;border:1px solid var(--line)}
[dir="rtl"] .ad-tag{right:auto;left:8px}

.ad-link{display:block;color:inherit;text-decoration:none}

.wip{display:inline-block;font-size:11px;font-weight:700;color:#9a6700;background:#fff8e1;border:1px solid #f3d27a;border-radius:6px;padding:1px 7px;vertical-align:middle}

/* ===== D1.2 — LM area & business profile v2 ===== */
.lm-tabs{display:flex;flex-wrap:wrap;gap:6px;margin:10px 0 14px;border-bottom:1px solid var(--line);padding-bottom:8px}
.lm-tab{padding:6px 12px;border-radius:8px;font-size:14px;text-decoration:none;color:var(--fg);border:1px solid var(--line)}
.lm-tab.active{background:#2563eb;border-color:#2563eb;color:#fff}
.db-pick label{display:inline-block;margin:2px 10px 2px 0;font-size:14px}
.hours-grid input[type=time]{padding:4px 6px;border:1px solid var(--line);border-radius:8px}
.hours-span{white-space:nowrap;margin-right:10px}
.media-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:12px;margin:8px 0}
.media-item{border:1px solid var(--line);border-radius:10px;padding:8px;display:flex;flex-direction:column;gap:6px}
.media-item img{width:100%;height:130px;object-fit:cover;border-radius:8px;background:#0002}
.media-meta{display:flex;flex-wrap:wrap;gap:4px;align-items:center;font-size:12px}
.chip.st-pending{background:rgba(234,179,8,.15);border-color:rgba(234,179,8,.5)}
.chip.st-approved{background:rgba(22,163,74,.15);border-color:rgba(22,163,74,.5)}
.chip.st-rejected{background:rgba(220,38,38,.12);border-color:rgba(220,38,38,.5)}
.chip.open-now{background:rgba(22,163,74,.15);border-color:rgba(22,163,74,.6);font-weight:600}
.chip.closed-now{background:rgba(220,38,38,.10);border-color:rgba(220,38,38,.45)}
.biz-logo{max-width:140px;max-height:90px;object-fit:contain;border-radius:8px;margin:4px 0;display:block}
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px}
.gallery-grid img{width:100%;height:120px;object-fit:cover;border-radius:8px}
.branch-list{list-style:none;margin:0;padding:0}
.branch-list li{padding:8px 0;border-bottom:1px solid var(--line)}
.branch-list li:last-child{border-bottom:none}
.branch-list .muted{display:block;font-size:13px}
.linklike{background:none;border:none;color:var(--brand);cursor:pointer;padding:0;font-size:inherit;text-decoration:underline}
.hours-pub td,.hours-pub th{padding:6px 10px}
@media (max-width:640px){.lm-tabs{overflow-x:auto;flex-wrap:nowrap}.lm-tab{white-space:nowrap}}

/* ===== C7 — Homepage CTA ===== */
.cta-join{background:linear-gradient(135deg,#1e3a8a,#2563eb);border-radius:16px;padding:28px;color:#fff;margin:18px 0}
.cta-inner{max-width:680px}
.cta-join .eyebrow{color:#bfdbfe;text-transform:uppercase;font-size:12px;letter-spacing:.06em}
.cta-join h2{margin:6px 0 8px;color:#fff;font-size:26px}
.cta-join .lead{color:#dbeafe;margin:0 0 14px}
.cta-actions{display:flex;flex-wrap:wrap;gap:12px;align-items:center;margin-bottom:14px}
.cta-link{color:#fff;text-decoration:underline;font-weight:600}
.cta-points{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:8px 18px}
.cta-points li{position:relative;padding-left:20px;color:#eff6ff;font-size:14px}
.cta-points li::before{content:"✓";position:absolute;left:0;color:#86efac;font-weight:700}
@media (max-width:640px){.cta-join{padding:20px}.cta-join h2{font-size:22px}}

/* ===== C8 — LU dashboard ===== */
.lu-tabs{overflow-x:auto;flex-wrap:nowrap}
.switch-chip{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border:1px solid var(--line);border-radius:8px;text-decoration:none;font-size:16px}
.acct-switch .switch-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}
.switch-card{display:flex;flex-direction:column;gap:3px;padding:14px;border:1px solid var(--line);border-radius:12px;text-decoration:none;color:var(--fg)}
.switch-card.active{border-color:#2563eb;background:rgba(37,99,235,.06)}
.switch-card.add{border-style:dashed;align-items:flex-start}
.switch-card .sc-kind{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}
.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:12px}
.stat{display:flex;flex-direction:column;gap:2px;padding:14px;border:1px solid var(--line);border-radius:12px;text-decoration:none;color:var(--fg)}
.stat-n{font-size:24px;font-weight:700}
.stat-l{font-size:13px;color:var(--muted)}
.save-search{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}
.save-search input[type=text]{flex:1;min-width:160px;padding:8px 10px;border:1px solid var(--line);border-radius:8px}

/* =====================================================================
   DESIGN POLISH — tabbed dashboard (LU + LM), softer navigation feel
   Overrides earlier .lm-tabs / .lu-tabs / dashboard rules (later wins).
   ===================================================================== */

/* Page glides in on each navigation instead of hard-flashing */
@media (prefers-reduced-motion: no-preference){
  main.wrap{animation:pageIn .22s cubic-bezier(.22,.61,.36,1) both}
}
@keyframes pageIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* Sticky segmented tab control — spans the card, stays in view while scrolling */
.lu-tabs{
  display:flex;gap:4px;flex-wrap:nowrap;overflow-x:auto;
  margin:-22px -24px 18px;padding:11px 16px;
  position:sticky;top:60px;z-index:20;
  background:var(--card);border-bottom:1px solid var(--line);
  border-top-left-radius:18px;border-top-right-radius:18px;
  scrollbar-width:none;scroll-snap-type:x proximity;
}
.lu-tabs::-webkit-scrollbar{display:none}
.lu-tab{
  display:inline-flex;align-items:center;gap:7px;white-space:nowrap;
  padding:8px 14px;border:0;border-radius:11px;background:transparent;
  font-size:14px;font-weight:600;color:var(--muted);text-decoration:none;
  scroll-snap-align:start;
  transition:color .15s ease,background .15s ease,box-shadow .18s ease,transform .12s ease;
}
.lu-tab .lu-ic{width:17px;height:17px;flex:none;opacity:.8}
.lu-tab:hover{color:var(--brand);background:var(--brand-50)}
.lu-tab:active{transform:translateY(1px)}
.lu-tab.active{color:#fff;background:var(--grad);box-shadow:0 6px 16px rgba(37,99,235,.30)}
.lu-tab.active .lu-ic{opacity:1}
.lu-tab:focus-visible{outline:2px solid var(--brand);outline-offset:2px}
.t-badge{min-width:17px;height:17px;padding:0 5px;border-radius:999px;background:var(--err);
  color:#fff;font-size:11px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;line-height:1}
.lu-tab.active .t-badge{background:rgba(255,255,255,.3)}

/* legacy .lm-tab fallback (any view still emitting it) keeps a clean look */
.lm-tab{border:0;color:var(--muted);font-weight:600;border-radius:11px}
.lm-tab.active{background:var(--grad);color:#fff;box-shadow:0 6px 16px rgba(37,99,235,.30)}

/* Account switcher — tactile cards with hover lift */
.acct-switch .switch-grid{gap:14px}
.switch-card{padding:16px;border-radius:14px;box-shadow:var(--shadow-sm);
  transition:transform .15s ease,box-shadow .18s ease,border-color .15s ease}
.switch-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--brand-100)}
.switch-card.active{border-color:var(--brand);background:var(--brand-50);box-shadow:none}
.switch-card.active:hover{transform:none}
.switch-card.add{border-style:dashed;color:var(--muted)}
.switch-card.add:hover{color:var(--brand);border-color:var(--brand)}
.switch-card .sc-kind{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-weight:700}
.switch-card strong{font-size:16px}

/* Overview tiles — gradient numerals as the signature accent */
.stat-grid{gap:14px}
.stat{padding:16px;border-radius:14px;box-shadow:var(--shadow-sm);
  transition:transform .15s ease,box-shadow .18s ease,border-color .15s ease}
.stat:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--brand-100)}
.stat-n{font-size:26px;font-weight:800;line-height:1.1;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.stat-l{font-size:12.5px;color:var(--muted);font-weight:600}

/* Switch chip in the header */
.switch-chip{box-shadow:var(--shadow-sm);background:#fff;transition:.15s}
.switch-chip:hover{border-color:var(--brand);color:var(--brand)}

@media (max-width:640px){
  .lu-tabs{top:54px;margin:-22px -20px 16px;padding:10px 12px}
  .lu-tab span{font-size:13px}
}

/* =====================================================================
   RESPONSIVE FIX — tabs must never clip; use more width on large screens
   ===================================================================== */
/* More breathing room on wide monitors (was 1040) */
.wrap{max-width:1200px}

/* Desktop/tablet: tabs wrap onto a second row instead of clipping/scrolling */
.lu-tabs{flex-wrap:wrap;overflow:visible}
.lu-tab{padding:7px 12px;font-size:13.5px;gap:6px}
.lu-tab .lu-ic{width:16px;height:16px}

/* Phones: single row that scrolls horizontally (swipe), never stacks tall */
@media (max-width:820px){
  .lu-tabs{flex-wrap:nowrap;overflow-x:auto}
}

/* Switcher + stat grids already use auto-fill; ensure they breathe on wide screens */
.acct-switch .switch-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}
.stat-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}

/* C9a — Start page: heading + stats together, offers below */
.ov-head{margin:2px 0 4px}
.ov-head h1{margin:0}
.stat-grid{margin-top:8px}


/* C9b — date dropdowns (Day / Month / Year), no calendar popup */
.datesel{display:inline-flex;flex-wrap:wrap;gap:6px;align-items:center}
.datesel select{background:#fff;border:1px solid var(--line);border-radius:10px;padding:9px 10px;font:inherit;color:var(--fg)}
.datesel select:focus{outline:2px solid var(--brand);outline-offset:1px}
.datesel-time{display:inline-flex;gap:4px;align-items:center;margin-left:4px}
.datesel-colon{color:var(--muted);font-weight:700}
.search-form .datesel select{width:auto}
@media (max-width:520px){.datesel{width:100%}.datesel select{flex:1;min-width:0}}

/* =====================================================================
   RTL — Arabic (html[dir="rtl"]). Flex rows mirror automatically via the
   dir attribute; these rules fix physical margins/alignment only.
   ===================================================================== */
[dir="rtl"] body{text-align:right}
[dir="rtl"] h1,[dir="rtl"] h2,[dir="rtl"] h3,[dir="rtl"] p,[dir="rtl"] label{text-align:right}
[dir="rtl"] .lang-switch a{margin-left:0;margin-right:8px}
[dir="rtl"] .stat,[dir="rtl"] .switch-card,[dir="rtl"] .ocard,[dir="rtl"] .offer{text-align:right}
[dir="rtl"] input,[dir="rtl"] select,[dir="rtl"] textarea{text-align:right}
[dir="rtl"] .datesel{direction:ltr}            /* keep day/month/year numeric order stable */
[dir="rtl"] .sf-row,[dir="rtl"] .sf-actions{flex-direction:row-reverse}
[dir="rtl"] .adm-table th,[dir="rtl"] .adm-table td{text-align:right}
[dir="rtl"] .hp .hero2 h1,[dir="rtl"] .hp .hero2 .lead{text-align:right}
/* directional glyphs in back-links read the other way in RTL */
[dir="rtl"] .link::first-letter{unicode-bidi:isolate}

/* =====================================================================
   d) Auth pages — readable surface, strong flash colours, equal field borders
   ===================================================================== */
/* Clean auth card (no blue-on-blue): form + messages sit on a light surface */
.card.auth-card{background:var(--card);color:var(--fg);box-shadow:var(--shadow);
  border-top:3px solid var(--brand)}
.card.auth-card h1{color:var(--fg)}
.card.auth-card .search-form{background:var(--bg-soft);box-shadow:none}

/* Flash / system messages — strong contrast on any background */
.ok{display:block;background:#dcfce7;color:#166534;border:1px solid #bbf7d0;
  border-left:4px solid #16a34a;border-radius:10px;padding:10px 14px;font-weight:600;margin:0 0 12px}
.err{display:block;background:#fee2e2;color:#991b1b;border:1px solid #fecaca;
  border-left:4px solid #dc2626;border-radius:10px;padding:10px 14px;font-weight:600;margin:0 0 12px}
.info{display:block;background:#dbeafe;color:#1e40af;border:1px solid #bfdbfe;
  border-left:4px solid #2563eb;border-radius:10px;padding:10px 14px;font-weight:600;margin:0 0 12px}
.ok a,.err a,.info a{color:inherit;text-decoration:underline}

/* Equal borders on every field type (text, password, email, date, number, select, textarea) */
.search-form input[type=text],.search-form input[type=password],.search-form input[type=email],
.search-form input[type=date],.search-form input[type=number],.search-form input:not([type]),
.search-form select,.search-form textarea{
  width:100%;background:#fff;color:var(--fg);border:1px solid var(--line);border-radius:10px;padding:10px 12px}
.search-form input:focus,.search-form select:focus,.search-form textarea:focus{
  outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-50)}
.search-form label{font-weight:600;color:var(--fg)}

/* =====================================================================
   HOMEPAGE REDESIGN — full-width search, two columns, refined CTA
   ===================================================================== */
/* c) ticker at the very top */
.hp .ticker-top{margin:0 0 18px}

/* a/b) full-width search: Country + City + Category */
.hp .search3{display:flex;gap:10px;background:#fff;border:1px solid var(--hp-line);border-radius:16px;
  padding:10px;box-shadow:var(--hp-shadow);max-width:none;flex-wrap:wrap}
.hp .search3 .f{flex:1 1 200px;display:flex;align-items:center;gap:8px;padding:6px 12px;border-radius:10px;
  position:relative;border:1px solid transparent}
.hp .search3 .ico{color:var(--hp-blue)}
.hp .search3 input,.hp .search3 select{border:0;outline:0;font-family:inherit;font-size:16px;width:100%;background:transparent;color:#0F172A}
.hp .search3 .btn2{flex:0 0 auto;border:0;cursor:pointer;font-family:inherit;font-weight:600;border-radius:10px;
  padding:12px 26px;font-size:15px;background:var(--hp-blue);color:#fff}
.hp .search3 .btn2:hover{background:var(--hp-blue-d)}
@media(max-width:680px){.hp .search3 .f{flex-basis:100%}.hp .search3 .btn2{width:100%}}

/* e/f) two columns: offers | businesses */
.hp .hp-cols{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:start}
.hp .hp-col{min-width:0}
.hp .col-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:960px){.hp .hp-cols{grid-template-columns:1fr;gap:8px}}
@media(max-width:560px){.hp .col-grid{grid-template-columns:1fr}}

/* i/j) offer card: name+location one line, validity one line, price/unit */
.hp .ocard .biz.one-line,.hp .valid.one-line{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block;max-width:100%}
.hp .price .per{font-size:13px;font-weight:600;color:var(--hp-muted)}

/* compact business card for the right column grid */
.hp .dcard2{position:relative;background:#fff;border:1px solid var(--hp-line);border-radius:var(--hp-radius);
  padding:14px;box-shadow:var(--hp-shadow);display:flex;flex-direction:column;gap:4px;text-decoration:none;color:inherit;
  transition:transform .15s,box-shadow .15s}
.hp .dcard2:hover{transform:translateY(-3px);box-shadow:0 10px 30px rgba(15,23,42,.10)}
.hp .dcard2::before{content:"";position:absolute;left:0;right:0;top:0;height:3px;border-radius:var(--hp-radius) var(--hp-radius) 0 0;background:linear-gradient(90deg,var(--hp-blue),#5b8bff)}
.hp .dcard2.premium::before{background:linear-gradient(90deg,var(--hp-gold),#f7c244)}
.hp .dcard2 .dc-top{display:flex;align-items:center;justify-content:space-between;gap:8px}
.hp .dcard2 .av{width:40px;height:40px;border-radius:10px;background:var(--hp-blue-soft);color:var(--hp-blue);
  display:flex;align-items:center;justify-content:center;font-weight:800;font-size:18px}
.hp .dcard2.premium .av{background:var(--hp-gold-soft);color:#92610a}
.hp .dcard2 .nm{font-weight:700;margin-top:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hp .dcard2 .sub{font-size:12.5px;color:var(--hp-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hp .dcard2 .meta{font-size:12px;color:#334155;margin-top:4px;display:flex;gap:10px;flex-wrap:wrap}

/* m) CTA in a better shape: two-panel, points in their own glass panel */
.cta-join{background:linear-gradient(135deg,#1e3a8a 0%,#2563eb 60%,#22b8d6 130%);border-radius:20px;
  padding:32px;color:#fff;margin:20px 0;box-shadow:0 18px 44px rgba(37,99,235,.28);position:relative;overflow:hidden}
.cta-join::after{content:"";position:absolute;width:320px;height:320px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,255,255,.16),transparent 70%);top:-120px;right:-80px;pointer-events:none}
.cta-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:26px;align-items:center;position:relative;z-index:1}
.cta-left .lead{max-width:520px}
.cta-points{list-style:none;margin:0;padding:18px 20px;display:flex;flex-direction:column;gap:12px;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);border-radius:14px;backdrop-filter:blur(4px)}
.cta-points li{position:relative;padding-left:26px;color:#fff;font-size:14.5px;font-weight:500}
.cta-points li::before{content:"✓";position:absolute;left:0;top:-1px;width:18px;height:18px;border-radius:50%;
  background:#86efac;color:#065f46;font-weight:800;font-size:12px;display:flex;align-items:center;justify-content:center}
@media(max-width:760px){.cta-grid{grid-template-columns:1fr;gap:18px}.cta-join{padding:24px}}

/* =====================================================================
   C9f — equal cards, business card without avatar, CTA button fix
   ===================================================================== */
/* a) CTA primary button: white on blue (was an unstyled pink link) */
.cta-join .btn2{display:inline-block;background:#fff;color:var(--hp-blue);border:0;cursor:pointer;
  font-weight:700;border-radius:10px;padding:12px 24px;font-size:15px;text-decoration:none;
  box-shadow:0 6px 18px rgba(2,6,23,.18)}
.cta-join .btn2:hover{background:#eef4ff}
.cta-join .cta-actions{display:flex;flex-wrap:wrap;gap:16px;align-items:center;margin-top:16px}

/* b) equal card size across both columns */
.hp .ocard,.hp .dcard2{min-height:186px}
.hp .dcard2{padding:16px}
.hp .dcard2 .meta{margin-top:auto}

/* c) business card: name+location one line like offers, chips row */
.hp .dcard2 .biz.one-line{font-size:13px;color:var(--hp-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}
.hp .dcard2 .biz .bn{font-weight:700;color:#0F172A;font-size:15.5px}
.hp .dcard2 .chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:2px}
.hp .dcard2 .meta{font-size:12.5px;color:#334155;display:flex;gap:12px;flex-wrap:wrap;align-items:center}

/* =====================================================================
   C9g — /offers & /directory: search form left, "most searched" right
   ===================================================================== */
.hp .search-split{display:grid;grid-template-columns:1.7fr 1fr;gap:24px;align-items:start}
@media(max-width:820px){.hp .search-split{grid-template-columns:1fr;gap:16px}}
.hp .ss-form{min-width:0}
.hp .ss-popular{min-width:0;border-left:1px solid var(--hp-line);padding-left:22px}
@media(max-width:820px){.hp .ss-popular{border-left:0;padding-left:0;border-top:1px solid var(--hp-line);padding-top:16px}}
.hp .ss-popular h3{margin:0 0 10px;font-size:15px;letter-spacing:-.01em}
.hp .pop-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px}
.hp .pop-list a{display:block;text-decoration:none;color:inherit;padding:8px 10px;border-radius:9px;transition:background .12s}
.hp .pop-list a:hover{background:var(--hp-blue-soft)}
.hp .pop-list .pn{display:block;font-weight:600;font-size:14px;color:#0F172A;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hp .pop-list .pm{display:block;font-size:12px;color:var(--hp-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}

/* =====================================================================
   C9h+ — ONE unified card, fixed row skeleton (offers == businesses)
   Rows: 1 name+loc · 2 badge(reserved) · 3 category · 4+ type-specific
   ===================================================================== */
.hp .ucard{position:relative;background:#fff;border:1px solid var(--hp-line);border-radius:var(--hp-radius);
  padding:16px;box-shadow:var(--hp-shadow);display:flex;flex-direction:column;gap:6px;text-decoration:none;color:inherit;
  min-height:220px;height:auto;overflow:visible;transition:transform .15s,box-shadow .15s}
.hp .ucard:hover{transform:translateY(-3px);box-shadow:0 10px 30px rgba(15,23,42,.10)}
.hp .ucard::before{content:"";position:absolute;left:0;right:0;top:0;height:3px;border-radius:var(--hp-radius) var(--hp-radius) 0 0;background:linear-gradient(90deg,var(--hp-blue),#5b8bff)}
.hp .ucard.premium::before{background:linear-gradient(90deg,var(--hp-gold),#f7c244)}
/* row 1: name + location (same on both) */
.hp .ucard .u-name{font-size:13px;font-weight:600;color:var(--hp-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-height:18px}
.hp .ucard .u-name .bn{font-size:15px;font-weight:700;color:#0F172A}
/* row 2: badge slot — reserved height even when empty so row 3 aligns */
.hp .ucard .u-badge{min-height:22px;display:flex;align-items:center;gap:6px}
.otype{display:inline-block;font-size:11px;font-weight:700;color:#0f766e;background:#ccfbf1;border-radius:6px;padding:2px 8px;letter-spacing:.01em}
/* row 3: category chip — identical vertical position on both cards */
.hp .ucard .u-cat{min-height:24px}
.hp .ucard .ccat{display:inline-block;font-size:11.5px;font-weight:600;color:var(--hp-blue);background:var(--hp-blue-soft);border-radius:6px;padding:2px 8px;max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
/* row 4: offer slogan (big) */
.hp .ucard .u-title{margin:0;font-size:16.5px;font-weight:700;letter-spacing:-.01em;line-height:1.25;color:#0F172A;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-height:20px}
/* rows 5-6: offer validity */
.hp .ucard .u-mid{min-height:46px;display:flex;align-items:flex-start}
.hp .ucard .valid{display:inline-block;font-size:12px;font-weight:600;color:var(--hp-ok);background:var(--hp-ok-soft);border-radius:8px;padding:5px 10px;max-width:100%;line-height:1.5}
.hp .ucard .valid .vrow{display:block;white-space:nowrap}
/* rows 7-8: offer price */
.hp .ucard .u-foot{margin-top:auto;display:flex;align-items:baseline;gap:8px;flex-wrap:wrap;min-height:28px;padding-top:2px}
.hp .ucard .price{font-size:20px;font-weight:800;letter-spacing:-.02em;color:#0F172A}
.hp .ucard .price .per{font-size:13px;font-weight:600;color:var(--hp-muted)}
.hp .ucard .price small{font-size:13px;font-weight:600;color:var(--hp-muted);text-decoration:line-through;margin-left:2px}
.hp .ucard .u-note{font-size:11px;color:var(--hp-muted)}
/* business fill rows (rating / offers / favourites) */
.hp .ucard .u-fill{display:flex;flex-direction:column;gap:5px;margin-top:2px}
.hp .ucard .u-line{font-size:13px;color:#334155}
.hp .ucard .u-line.muted{color:var(--hp-muted);font-size:12.5px}
.hp .ucard .u-star{color:#0F172A;font-weight:700}
/* premium chip (business only) + WIP */
.hp .ucard .prem{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:700;color:#92610a;background:var(--hp-gold-soft);border-radius:6px;padding:2px 7px}
.hp .ucard .wip{font-size:11px;font-weight:600;color:#92610a;background:var(--hp-gold-soft);border-radius:6px;padding:1px 6px}

/* b) CTA: give the left text breathing room (was glued to the edge) */
.cta-join{padding:44px clamp(36px,5vw,72px)}
.cta-left{padding:4px 24px 4px 6px}
@media(max-width:760px){.cta-join{padding:24px 22px}}

/* d) compact login gate placed above the offer */
.hp .gate-top{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;
  background:var(--hp-blue-soft);border:1px solid #cfe0ff;border-radius:12px;padding:12px 16px;margin:0 0 14px}
.hp .gate-top .gate-msg{font-weight:700;color:#1e3a8a}
.hp .gate-top .gate-cta{display:flex;align-items:center;gap:12px}

/* C9l — ads share the .ucard footprint (dashed look, centered content) */
.hp .ucard.adcard{border:1px dashed var(--hp-line);background:repeating-linear-gradient(45deg,#fafafa,#fafafa 10px,#f5f5f7 10px,#f5f5f7 20px);
  align-items:center;justify-content:center;text-align:center;gap:8px}
.hp .ucard.adcard::before{display:none}
.hp .ucard.adcard .ad-html{width:100%}
.hp .ucard.adcard .ad-html img{max-width:100%;height:auto}
.hp .ucard.adcard .ad-tag{position:absolute;top:6px;right:8px;font-size:10px;color:var(--hp-muted);text-transform:uppercase;letter-spacing:.05em}

/* L1a — Händlerzentrale: LM card grid ("Meine Geschäfte") */
.lmgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(258px,1fr));gap:14px;margin:14px 0}
.lmcard{border:1px solid #e2e8f0;border-radius:14px;padding:14px 16px;background:#fff;display:flex;flex-direction:column;gap:6px;box-shadow:0 1px 2px rgba(15,23,42,.04)}
.lmcard .lm-top{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}
.lmcard .lm-name{font-size:15px;color:#0F172A;line-height:1.3}
.lmcard .lm-meta{font-size:13px;color:#475569}
.lmcard .lm-meta.muted{color:#94a3b8;font-size:11px}
.lmcard .lm-row{display:flex;align-items:center;gap:10px;margin-top:2px}
.lmcard .lm-tier{font-size:11px;font-weight:700;border-radius:6px;padding:2px 8px}
.lmcard .lm-tier-basic{color:#475569;background:#f1f5f9}
.lmcard .lm-tier-premium{color:#92610a;background:#fef3c7}
.lmcard .lm-of{font-size:12.5px;color:#475569}
.lmcard .lm-st{font-size:11px;white-space:nowrap}
.lmcard .lm-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
.lmcard .btn-sm{font-size:13px;font-weight:600;text-decoration:none;color:#fff;background:#2563EB;border-radius:8px;padding:6px 12px}
.lmcard .btn-sm.ghost{color:#2563EB;background:#eff6ff}
.lmcard.lm-online{border-left:3px solid #16a34a}
.lmcard.lm-draft,.lmcard.lm-incomplete{border-left:3px solid #cbd5e1}
.lmcard.lm-review{border-left:3px solid #f59e0b}

/* L1b — LU/LM context chooser + switcher */
.lmcard.lm-lu{border-left:3px solid #2563EB}
.lmcard.lm-current{outline:2px solid #2563EB;outline-offset:1px}
.lmcard .lm-st.lm-cur{color:#1e40af;background:#dbeafe;font-weight:700}
.user-chip.ctx-lm{background:#fef3c7;color:#92610a;font-weight:700}
a.lmcard{text-decoration:none;color:inherit;cursor:pointer}
a.lmcard:hover{box-shadow:0 6px 18px rgba(15,23,42,.10)}

/* L1c — premium = golden crown inline with the name (frees the badge row) */
.hp .ucard .u-name .crown{font-size:13px;vertical-align:-1px;filter:drop-shadow(0 1px 1px rgba(146,97,10,.35))}

/* L2a — light stepper headers in the LM form */
.step-h{display:flex;align-items:center;gap:9px;font-weight:700;font-size:15px;color:#0F172A;margin:20px 0 8px;padding-top:14px;border-top:1px solid #eef2f7}
.step-h:first-of-type{border-top:0;padding-top:0;margin-top:6px}
.step-h .step-n{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:#2563EB;color:#fff;font-size:12px;font-weight:800;flex:none}

/* L2b-1 — amenity grouping by topic in the LM form */
.amenity-box .am-topic{font-weight:700;font-size:12px;letter-spacing:.04em;text-transform:uppercase;color:#475569;margin:12px 0 4px;padding-top:8px;border-top:1px dashed #e6ebf2}
.amenity-box .am-topic:first-of-type{border-top:0;padding-top:0;margin-top:4px}
.amenity-box .am-item{display:inline-flex;align-items:center;gap:6px;margin:0 14px 6px 0}

/* L2b-2 — product selection grouped by product category */
.prod-pick .pg{margin:8px 0 10px}
.prod-pick .pg-h{font-weight:700;font-size:13px;color:#0F172A;margin:0 0 4px}
.prod-pick .am-item{display:inline-flex;align-items:center;gap:6px;margin:0 14px 6px 0}

/* L2b-2b — products on public profile */
.biz-products .bp-group{margin:0 0 10px}
.biz-products .bp-cat{font-weight:700;font-size:13px;color:#0F172A;margin:0 0 4px}
.biz-products .bp-items{margin:0;display:flex;flex-wrap:wrap;gap:6px}

/* L2c-1 — review & submit panel */
.rev-box{border:1px solid #e6ebf2;border-radius:10px;padding:12px 14px;margin:6px 0 4px;background:#fafbfc}
.rev-box .rev-row{display:flex;align-items:center;gap:8px;margin:0 0 6px;font-size:14px}
.rev-box .rev-row:last-of-type{margin-bottom:0}
.rev-box .rev-ic{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;font-size:12px;font-weight:800;flex:none;color:#fff}
.rev-box .rev-ic.ok{background:#16a34a}
.rev-box .rev-ic.todo{background:#d97706}
.rev-box .rev-ic.info{background:#e2e8f0;color:#334155}

/* L4-2 — services on public profile + offer-kind toggle */
.biz-services .bs-row{padding:6px 0;border-bottom:1px solid #f1f5f9}
.biz-services .bs-row:last-child{border-bottom:0}
.biz-services .bs-title{font-weight:600}
.biz-services .bs-price{float:right;font-weight:700;color:#0F172A}
.biz-services .bs-price small{font-weight:400;color:#64748b}
.biz-services .bs-desc{clear:both;font-size:13px;margin-top:2px}
.kind-pick label{font-weight:600}

/* D1 — social share bar */
.share-bar{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin:10px 0 2px}
.share-lbl{font-size:13px;color:#64748b;margin-right:2px}
.share-btn{display:inline-block;padding:5px 12px;font-size:13px;font-weight:600;line-height:1.2;
  border:1px solid #cbd5e1;border-radius:999px;background:#fff;color:#1e293b;cursor:pointer;
  text-decoration:none;transition:background .12s,border-color .12s}
.share-btn:hover{background:#f1f5f9;border-color:#94a3b8}
