/* ============================
   SHOK.GE — 3-სვეტიანი დიზაინი
   ============================ */

/* === CSS Variables === */
:root {
    --primary:      #4361ee;
    --primary-dark: #3a0ca3;
    --primary-light:#7209b7;
    --accent:       #f72585;
    --success:      #10b981;
    --warning:      #f59e0b;
    --danger:       #ef4444;
    --info:         #06b6d4;

    --bg:           #eef1f6;
    --bg-card:      #ffffff;
    --bg-sidebar:   #ffffff;
    --bg-header:    linear-gradient(135deg, #4361ee, #3a0ca3);
    --bg-input:     #f5f6fa;

    --text:         #1a1a2e;
    --text-secondary:#6c757d;
    --text-muted:   #adb5bd;
    --text-on-primary:#ffffff;

    --border:       #e2e8f0;
    --border-light: #f1f3f5;

    --shadow-sm:    0 1px 3px rgba(0,0,0,0.06);
    --shadow:       0 2px 8px rgba(0,0,0,0.08);
    --shadow-lg:    0 8px 24px rgba(0,0,0,0.1);
    --shadow-glow:  0 0 20px rgba(67,97,238,0.25);
    --radius:       10px;
    --radius-sm:    6px;
    --radius-full:  50%;

    --font:         'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --font-size:    14px;
    --line-height:  1.55;
    --transition:   0.2s ease;

    --sidebar-w:    215px;
    --right-w:      235px;
}

/* === Dark Theme === */
[data-theme="dark"] {
    --bg:           #0d0d18;
    --bg-card:      #181830;
    --bg-sidebar:   #14142a;
    --bg-header:    linear-gradient(135deg, #3a0ca3, #1a0040);
    --bg-input:     #222244;
    --text:         #e4e4ef;
    --text-secondary:#9ca3af;
    --text-muted:   #6b7280;
    --border:       #2a2a48;
    --border-light: #222244;
    --shadow-sm:    0 1px 3px rgba(0,0,0,0.3);
    --shadow:       0 2px 8px rgba(0,0,0,0.35);
    --shadow-lg:    0 8px 24px rgba(0,0,0,0.4);
}

/* === Reset === */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { font-size:var(--font-size); scroll-behavior:smooth; }
body {
    font-family:var(--font);
    background:var(--bg);
    color:var(--text);
    line-height:var(--line-height);
    min-height:100vh;
}
a { color:var(--primary); text-decoration:none; transition:color var(--transition); }
a:hover { color:var(--primary-dark); }
img { max-width:100%; display:block; }

/* === HEADER === */
.header {
    background:var(--bg-header);
    color:var(--text-on-primary);
    position:sticky; top:0; z-index:100;
    box-shadow:0 2px 12px rgba(0,0,0,0.15);
}
.header__inner {
    max-width:1200px;
    margin:0 auto;
    display:flex;
    align-items:center;
    justify-content:space-between;
    padding:8px 16px;
}
.header__logo {
    font-size:1.25rem; font-weight:800;
    color:#fff; letter-spacing:1px;
    display:flex; align-items:center; gap:6px;
}
.header__nav {
    display:flex; align-items:center; gap:2px;
}
.header__link {
    color:rgba(255,255,255,0.82);
    padding:6px 10px; border-radius:var(--radius-sm);
    font-size:0.8rem; font-weight:500;
    transition:all var(--transition);
    position:relative; display:flex;
    align-items:center; gap:4px; white-space:nowrap;
}
.header__link:hover,
.header__link--active {
    background:rgba(255,255,255,0.13);
    color:#fff;
}
.header__badge {
    background:var(--accent); color:#fff;
    font-size:0.62rem; font-weight:700;
    padding:1px 5px; border-radius:8px;
    min-width:16px; text-align:center; line-height:1.3;
}
.header__burger {
    display:none; background:none; border:none;
    color:#fff; font-size:1.3rem; cursor:pointer; padding:6px;
}
.header__mobile-extra { display:none; }
.header__mobile-section { display:none; }

/* === 3-COLUMN LAYOUT === */
.layout {
    max-width:1200px;
    margin:0 auto;
    display:grid;
    grid-template-columns:var(--sidebar-w) 1fr var(--right-w);
    gap:12px;
    padding:12px;
    min-height:calc(100vh - 52px);
}
.layout__left { min-width:0; }
.layout__center { min-width:0; }
.layout__right { min-width:0; }

/* Full-width container for inner pages */
.container {
    max-width:760px;
    margin:0 auto;
    padding:16px 12px;
}

/* === SIDEBAR BLOCKS === */
.sb {
    background:var(--bg-sidebar);
    border-radius:var(--radius);
    border:1px solid var(--border);
    box-shadow:var(--shadow-sm);
    margin-bottom:10px;
    overflow:hidden;
}
.sb__title {
    padding:9px 12px;
    font-size:0.72rem;
    font-weight:700;
    text-transform:uppercase;
    letter-spacing:0.4px;
    color:var(--text-secondary);
    border-bottom:1px solid var(--border);
    display:flex; align-items:center; gap:6px;
}
.sb__title i { color:var(--primary); font-size:0.68rem; }

/* Sidebar navigation links */
.sb-nav a {
    display:flex; align-items:center; gap:8px;
    padding:7px 12px;
    font-size:0.8rem; font-weight:500;
    color:var(--text);
    border-bottom:1px solid var(--border-light);
    transition:all var(--transition);
}
.sb-nav a:last-child { border-bottom:none; }
.sb-nav a:hover { background:var(--bg-input); color:var(--primary); }
.sb-nav a.active { background:rgba(67,97,238,0.08); color:var(--primary); font-weight:600; }
.sb-nav__icon {
    width:22px; height:22px;
    display:flex; align-items:center; justify-content:center;
    border-radius:5px; font-size:0.65rem; color:#fff; flex-shrink:0;
}
.sb-nav__count {
    margin-left:auto;
    font-size:0.68rem; color:var(--text-muted);
    background:var(--bg-input); padding:1px 5px;
    border-radius:6px; font-weight:600;
}

/* Sidebar user panel */
.sb-user { padding:12px; text-align:center; }
.sb-user__avatar {
    width:64px; height:64px;
    border-radius:var(--radius-full);
    object-fit:cover;
    border:3px solid var(--primary);
    margin:0 auto 6px;
}
.sb-user__nick { font-weight:700; font-size:0.85rem; }
.sb-user__money { font-size:0.75rem; color:var(--warning); margin-top:2px; }
.sb-user__money i { display:inline; }
.sb-user__actions { display:flex; gap:4px; margin-top:8px; justify-content:center; flex-wrap:wrap; }

/* === MAIN CARDS === */
.card {
    background:var(--bg-card);
    border-radius:var(--radius);
    box-shadow:var(--shadow-sm);
    border:1px solid var(--border);
    overflow:hidden;
    transition:box-shadow var(--transition);
    margin-bottom:10px;
}
.card:hover { box-shadow:var(--shadow); }
.card__header {
    padding:10px 14px;
    border-bottom:1px solid var(--border);
    display:flex; align-items:center;
    justify-content:space-between;
    font-weight:600; font-size:0.85rem;
}
.card__header i { margin-right:5px; color:var(--primary); }
.card__body { padding:12px 14px; }
.card__footer {
    padding:8px 14px;
    border-top:1px solid var(--border);
    background:var(--bg-input);
    display:flex; align-items:center; justify-content:space-between;
}

/* === GRIDS === */
.grid { display:grid; gap:10px; }
.grid--2 { grid-template-columns:repeat(2,1fr); }
.grid--3 { grid-template-columns:repeat(3,1fr); }
.grid--4 { grid-template-columns:repeat(4,1fr); }

/* === MENU CARDS === */
.menu-card {
    background:var(--bg-card);
    border-radius:var(--radius);
    border:1px solid var(--border);
    padding:12px 8px;
    text-align:center;
    transition:all var(--transition);
    display:flex; flex-direction:column;
    align-items:center; gap:5px;
    cursor:pointer; text-decoration:none;
    color:var(--text);
}
.menu-card:hover {
    transform:translateY(-2px);
    box-shadow:var(--shadow);
    border-color:var(--primary);
    color:var(--primary);
}
.menu-card__icon {
    width:38px; height:38px;
    border-radius:9px;
    display:flex; align-items:center; justify-content:center;
    font-size:1rem; color:#fff;
}
.menu-card__icon--blue    { background:linear-gradient(135deg,#4361ee,#3a86ff); }
.menu-card__icon--purple  { background:linear-gradient(135deg,#7209b7,#560bad); }
.menu-card__icon--pink    { background:linear-gradient(135deg,#f72585,#e63988); }
.menu-card__icon--green   { background:linear-gradient(135deg,#10b981,#059669); }
.menu-card__icon--orange  { background:linear-gradient(135deg,#f59e0b,#d97706); }
.menu-card__icon--cyan    { background:linear-gradient(135deg,#06b6d4,#0891b2); }
.menu-card__icon--red     { background:linear-gradient(135deg,#ef4444,#dc2626); }
.menu-card__icon--teal    { background:linear-gradient(135deg,#14b8a6,#0d9488); }
.menu-card__title { font-weight:600; font-size:0.75rem; }
.menu-card__count { font-size:0.68rem; color:var(--text-muted); }

/* === BUTTONS === */
.btn {
    display:inline-flex; align-items:center; gap:5px;
    padding:7px 16px; border:none;
    border-radius:var(--radius-sm);
    font-family:var(--font);
    font-size:0.8rem; font-weight:600;
    cursor:pointer; transition:all var(--transition);
    text-decoration:none; line-height:1.4;
}
.btn--primary {
    background:linear-gradient(135deg,var(--primary),var(--primary-dark));
    color:#fff;
}
.btn--primary:hover { box-shadow:var(--shadow-glow); transform:translateY(-1px); color:#fff; }
.btn--secondary { background:var(--bg-input); color:var(--text); border:1px solid var(--border); }
.btn--secondary:hover { background:var(--border); color:var(--text); }
.btn--accent { background:linear-gradient(135deg,var(--accent),#d21f6a); color:#fff; }
.btn--accent:hover { box-shadow:0 0 16px rgba(247,37,133,0.25); color:#fff; }
.btn--success { background:var(--success); color:#fff; }
.btn--danger { background:var(--danger); color:#fff; }
.btn--sm { padding:4px 10px; font-size:0.72rem; }
.btn--full { width:100%; justify-content:center; }

/* === FORMS === */
.form-group { margin-bottom:14px; }
.form-group label {
    display:block; margin-bottom:4px;
    font-weight:600; font-size:0.78rem;
    color:var(--text-secondary);
}
.form-control {
    width:100%; padding:9px 12px;
    border:1px solid var(--border);
    border-radius:var(--radius-sm);
    font-family:var(--font); font-size:0.85rem;
    background:var(--bg-input); color:var(--text);
    transition:border-color var(--transition),box-shadow var(--transition);
}
.form-control:focus {
    outline:none;
    border-color:var(--primary);
    box-shadow:0 0 0 3px rgba(67,97,238,0.12);
}
textarea.form-control { resize:vertical; min-height:80px; }
select.form-control { cursor:pointer; }

/* === ALERTS === */
.alert {
    padding:10px 14px; border-radius:var(--radius-sm);
    margin-bottom:10px; font-size:0.8rem; font-weight:500;
}
.alert-success { background:rgba(16,185,129,0.1); color:var(--success); border:1px solid rgba(16,185,129,0.2); }
.alert-error { background:rgba(239,68,68,0.1); color:var(--danger); border:1px solid rgba(239,68,68,0.2); }
.alert-info { background:rgba(6,182,212,0.1); color:var(--info); border:1px solid rgba(6,182,212,0.2); }

/* === AVATAR === */
.avatar {
    width:38px; height:38px;
    border-radius:var(--radius-full);
    object-fit:cover;
    border:2px solid var(--border); flex-shrink:0;
}
.avatar--sm { width:28px; height:28px; }
.avatar--lg { width:64px; height:64px; }
.avatar--xl { width:100px; height:100px; }
.avatar--online { border-color:var(--success); box-shadow:0 0 0 2px rgba(16,185,129,0.2); }

/* === USER LINE === */
.user-line {
    display:flex; align-items:center; gap:8px; padding:6px 0;
}
.user-line__info { flex:1; min-width:0; }
.user-line__name { font-weight:600; font-size:0.85rem; display:block; }
.user-line__meta { font-size:0.72rem; color:var(--text-muted); }

/* === LIST === */
.list-item {
    display:flex; align-items:center; gap:10px;
    padding:10px 14px;
    border-bottom:1px solid var(--border-light);
    transition:background var(--transition);
}
.list-item:last-child { border-bottom:none; }
.list-item:hover { background:var(--bg-input); }
.list-item a { color:var(--text); font-weight:500; }
.list-item a:hover { color:var(--primary); }

/* === PAGINATION === */
.pagination {
    display:flex; align-items:center; justify-content:center;
    gap:3px; margin:14px 0; flex-wrap:wrap;
}
.pagination__link {
    padding:5px 10px; border-radius:var(--radius-sm);
    font-size:0.78rem; font-weight:500;
    color:var(--text-secondary);
    border:1px solid var(--border);
    background:var(--bg-card);
    transition:all var(--transition);
}
.pagination__link:hover { background:var(--primary); color:#fff; border-color:var(--primary); }
.pagination__link--active { background:var(--primary); color:#fff; border-color:var(--primary); }

/* === TABS === */
.tabs {
    display:flex; gap:2px;
    border-bottom:2px solid var(--border);
    margin-bottom:14px; overflow-x:auto;
}
.tab {
    padding:7px 14px; font-size:0.8rem;
    font-weight:500; color:var(--text-secondary);
    border-bottom:2px solid transparent;
    margin-bottom:-2px; white-space:nowrap;
    transition:all var(--transition);
}
.tab:hover, .tab--active {
    color:var(--primary); border-bottom-color:var(--primary);
}

/* === STATS BAR === */
.stats-bar { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:10px; }
.stat-item {
    flex:1; min-width:70px;
    background:var(--bg-card);
    border-radius:var(--radius);
    border:1px solid var(--border);
    padding:8px 6px; text-align:center;
}
.stat-item__value {
    font-size:1.2rem; font-weight:800;
    background:linear-gradient(135deg,var(--primary),var(--accent));
    -webkit-background-clip:text;
    -webkit-text-fill-color:transparent;
    background-clip:text;
}
.stat-item__label { font-size:0.68rem; color:var(--text-muted); margin-top:2px; }

/* === ONLINE DOT === */
.online-dot { width:8px; height:8px; border-radius:50%; display:inline-block; }
.online-dot--on { background:var(--success); box-shadow:0 0 4px rgba(16,185,129,0.4); }
.online-dot--off { background:var(--text-muted); }

/* === PROFILE CARD === */
.profile { text-align:center; padding:20px 14px; }
.profile__avatar {
    width:100px; height:100px;
    border-radius:var(--radius-full);
    object-fit:cover;
    border:3px solid var(--primary);
    box-shadow:var(--shadow-glow);
    margin:0 auto 10px;
}
.profile__name { font-size:1.15rem; font-weight:700; margin-bottom:4px; }
.profile__status { color:var(--text-secondary); font-size:0.82rem; margin-bottom:12px; }
.profile__stats { display:flex; justify-content:center; gap:20px; margin-bottom:14px; }
.profile__stat-num { font-size:1rem; font-weight:700; color:var(--primary); }
.profile__stat-lbl { font-size:0.7rem; color:var(--text-muted); }

/* === MESSAGE BUBBLE === */
.msg { display:flex; gap:8px; margin-bottom:8px; }
.msg--own { flex-direction:row-reverse; }
.msg__bubble {
    max-width:75%; padding:8px 12px;
    border-radius:14px; font-size:0.82rem; line-height:1.45;
}
.msg__bubble--in { background:var(--bg-input); border-bottom-left-radius:4px; }
.msg__bubble--out {
    background:linear-gradient(135deg,var(--primary),var(--primary-dark));
    color:#fff; border-bottom-right-radius:4px;
}
.msg__time { font-size:0.65rem; color:var(--text-muted); margin-top:2px; }

/* === WHATSAPP-STYLE CHAT === */
.wa-chat { display:flex; flex-direction:column; height:calc(100vh - 56px); width:100%; max-width:100%; margin:0 auto; background:var(--bg-card); overflow:hidden; position:relative; }
@media(min-width:1025px){ .wa-chat { max-width:100%; border-radius:var(--radius); box-shadow:var(--shadow-lg); } }
@media(max-width:768px){ .wa-chat { height:calc(100dvh - 50px); border-radius:0; } }
.wa-header { display:flex; align-items:center; gap:10px; padding:8px 14px; background:var(--bg-header); color:#fff; flex-shrink:0; min-height:56px; }
.wa-header a { color:#fff; text-decoration:none; }
.wa-header__back { font-size:1.2rem; padding:4px; opacity:0.85; }
.wa-header__back:hover { opacity:1; }
.wa-header__avatar { width:40px; height:40px; border-radius:50%; object-fit:cover; border:2px solid rgba(255,255,255,0.3); flex-shrink:0; }
.wa-header__info { flex:1; min-width:0; }
.wa-header__name { font-size:0.92rem; font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.wa-header__status { font-size:0.72rem; opacity:0.8; }
.wa-header__status--online { opacity:1; color:#4ade80; }
.wa-header__actions { display:flex; gap:12px; }
.wa-header__actions button, .wa-header__actions a { background:none; border:none; color:#fff; opacity:0.7; font-size:1rem; cursor:pointer; padding:4px; }
.wa-header__actions button:hover, .wa-header__actions a:hover { opacity:1; }

.wa-body { flex:1; overflow-y:auto; padding:12px 16px; background:var(--bg); background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M30 5c2 0 3 2 3 4s-1 4-3 4-3-2-3-4 1-4 3-4zm15 20c-1 0-2-1-2-2s1-2 2-2 2 1 2 2-1 2-2 2zm-30 0c-1 0-2-1-2-2s1-2 2-2 2 1 2 2-1 2-2 2zm15 20c-1 0-2-1-2-2s1-2 2-2 2 1 2 2-1 2-2 2z' fill='%234361ee' opacity='.04'/%3E%3C/svg%3E"); }
[data-theme="dark"] .wa-body { background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M30 5c2 0 3 2 3 4s-1 4-3 4-3-2-3-4 1-4 3-4zm15 20c-1 0-2-1-2-2s1-2 2-2 2 1 2 2-1 2-2 2zm-30 0c-1 0-2-1-2-2s1-2 2-2 2 1 2 2-1 2-2 2zm15 20c-1 0-2-1-2-2s1-2 2-2 2 1 2 2-1 2-2 2z' fill='%23ffffff' opacity='.03'/%3E%3C/svg%3E"); }

.wa-bubble { max-width:80%; padding:6px 8px 3px; border-radius:10px; font-size:0.88rem; line-height:1.5; position:relative; word-break:break-word; box-shadow:0 1px 1px rgba(0,0,0,0.08); }
.wa-bubble--in { background:var(--bg-card); border-top-left-radius:2px; margin-left:0; }
.wa-bubble--out { background:linear-gradient(135deg,#d9c8f4,#c3b0e8); color:#1a1a2e; border-top-right-radius:2px; margin-left:auto; }
[data-theme="dark"] .wa-bubble--out { background:linear-gradient(135deg,#3a2d6b,#2d2252); color:#e4e4ef; }
.wa-bubble img.wa-img { max-width:260px; border-radius:8px; cursor:pointer; margin-bottom:4px; }
@media(max-width:480px){ .wa-bubble img.wa-img { max-width:200px; } }
.wa-bubble .wa-file { display:flex; align-items:center; gap:8px; padding:8px 12px; background:rgba(0,0,0,0.06); border-radius:8px; margin-bottom:4px; text-decoration:none; color:inherit; }
.wa-bubble .wa-file i { font-size:1.4rem; opacity:0.7; }
.wa-bubble .wa-file-info { font-size:0.78rem; }

.wa-row { display:flex; margin-bottom:6px; padding:0 4px; }
.wa-row--own { justify-content:flex-end; }
.wa-row--system { justify-content:center; }

.wa-meta { display:flex; align-items:center; justify-content:flex-end; gap:4px; margin-top:2px; padding:0 2px; }
.wa-meta__time { font-size:0.65rem; color:var(--text-muted); }
.wa-bubble--out .wa-meta__time { color:rgba(26,26,46,0.5); }
[data-theme="dark"] .wa-bubble--out .wa-meta__time { color:rgba(228,228,239,0.5); }
.wa-meta__check { font-size:0.6rem; }
.wa-meta__check--read { color:var(--primary); }
.wa-meta__check--sent { color:var(--text-muted); }

.wa-actions { display:none; position:absolute; top:2px; right:2px; gap:2px; }
.wa-bubble:hover .wa-actions { display:flex; }
.wa-actions button { background:rgba(0,0,0,0.08); border:none; border-radius:50%; width:22px; height:22px; font-size:0.6rem; cursor:pointer; display:flex; align-items:center; justify-content:center; color:var(--text-muted); }
.wa-actions button:hover { background:rgba(0,0,0,0.15); }

.wa-date-sep { text-align:center; margin:16px 0 10px; }
.wa-date-sep span { background:var(--bg-card); color:var(--text-muted); font-size:0.72rem; padding:4px 14px; border-radius:8px; box-shadow:0 1px 2px rgba(0,0,0,0.06); }

.wa-footer { flex-shrink:0; padding:8px 10px; background:var(--bg-card); border-top:1px solid var(--border); }
.wa-send { display:flex; align-items:flex-end; gap:6px; }
.wa-send__btn { width:38px; height:38px; border-radius:50%; border:none; display:flex; align-items:center; justify-content:center; cursor:pointer; flex-shrink:0; font-size:1.05rem; transition:all 0.15s; }
.wa-send__attach { background:transparent; color:var(--text-muted); }
.wa-send__attach:hover { color:var(--primary); }
.wa-send__emoji { background:transparent; color:var(--text-muted); }
.wa-send__emoji:hover { color:var(--warning); }
.wa-send__go { background:var(--primary); color:#fff; box-shadow:0 2px 6px rgba(67,97,238,0.35); }
.wa-send__go:hover { background:var(--primary-dark); transform:scale(1.05); }
.wa-send__input { flex:1; border:none; background:var(--bg-input); color:var(--text); border-radius:20px; padding:8px 16px; font-size:0.88rem; font-family:var(--font); outline:none; resize:none; max-height:100px; min-height:38px; line-height:1.4; }
.wa-send__input::placeholder { color:var(--text-muted); }

.wa-file-preview { display:flex; align-items:center; gap:8px; padding:6px 12px; margin-bottom:6px; background:var(--bg-input); border-radius:12px; font-size:0.78rem; color:var(--text-secondary); }
.wa-file-preview__close { background:none; border:none; color:var(--danger); cursor:pointer; font-size:0.9rem; padding:0 2px; }

.wa-empty { display:flex; flex-direction:column; align-items:center; justify-content:center; height:100%; opacity:0.5; }
.wa-empty i { font-size:3rem; margin-bottom:12px; }
.wa-empty p { font-size:0.9rem; }

.wa-video { max-width:260px; border-radius:8px; margin-bottom:4px; }
.wa-audio { width:220px; margin-bottom:4px; }

/* Scroll-to-bottom */
.wa-scroll-btn { position:absolute; bottom:80px; right:16px; width:40px; height:40px; border-radius:50%; background:var(--bg-card); color:var(--text-secondary); border:1px solid var(--border); box-shadow:var(--shadow); cursor:pointer; display:flex; align-items:center; justify-content:center; font-size:0.9rem; z-index:10; transition:transform 0.2s, opacity 0.2s; }
.wa-scroll-btn:hover { transform:scale(1.1); color:var(--primary); }

/* Message entrance animation */
.wa-row--new { animation:waSlideIn 0.25s ease-out; }
@keyframes waSlideIn { from { opacity:0; transform:translateY(12px); } to { opacity:1; transform:translateY(0); } }
.wa-row--sending { opacity:0.6; }
.wa-meta__check--pending { color:var(--text-muted); font-size:0.58rem; }
.wa-file-hint { font-size:0.78rem; opacity:0.7; margin-bottom:2px; }
.wa-file-hint i { margin-right:3px; }

/* Image lightbox */
.wa-lightbox { position:fixed; top:0; left:0; width:100%; height:100%; background:rgba(0,0,0,0.88); z-index:9999; display:flex; align-items:center; justify-content:center; cursor:zoom-out; }
.wa-lightbox img { max-width:92%; max-height:90vh; border-radius:6px; object-fit:contain; box-shadow:0 4px 30px rgba(0,0,0,0.5); }
.wa-lightbox__close { position:absolute; top:16px; right:16px; background:rgba(255,255,255,0.15); border:none; color:#fff; width:40px; height:40px; border-radius:50%; font-size:1.2rem; cursor:pointer; display:flex; align-items:center; justify-content:center; }
.wa-lightbox__close:hover { background:rgba(255,255,255,0.3); }

.wa-typing { display:inline-flex; gap:3px; align-items:center; padding:10px 16px; background:var(--bg-card); border-radius:14px; border-top-left-radius:2px; box-shadow:0 1px 1px rgba(0,0,0,0.08); }
.wa-typing span { width:6px; height:6px; background:var(--text-muted); border-radius:50%; animation:waTyping 1.4s infinite; }
.wa-typing span:nth-child(2) { animation-delay:0.2s; }
.wa-typing span:nth-child(3) { animation-delay:0.4s; }
@keyframes waTyping { 0%,60%,100%{transform:translateY(0);opacity:0.4} 30%{transform:translateY(-4px);opacity:1} }

/* === MESSENGER LIST (Telegram-style) === */
.msn { display:flex; flex-direction:column; height:calc(100vh - 56px); width:100%; max-width:100%; margin:0 auto; background:var(--bg-card); overflow:hidden; position:relative; }
@media(min-width:1025px){ .msn { max-width:100%; border-radius:var(--radius); box-shadow:var(--shadow-lg); } }
@media(max-width:768px){ .msn { height:calc(100dvh - 50px); border-radius:0; } }
.msn__header { display:flex; align-items:center; gap:10px; padding:10px 16px; background:var(--bg-header); color:#fff; flex-shrink:0; min-height:56px; }
.msn__header-title { font-size:1.05rem; font-weight:700; flex:1; }
.msn__header-actions { display:flex; gap:6px; }
.msn__header-actions a, .msn__header-actions button { background:rgba(255,255,255,0.12); border:none; color:#fff; width:36px; height:36px; border-radius:50%; display:flex; align-items:center; justify-content:center; cursor:pointer; font-size:0.95rem; transition:background 0.15s; text-decoration:none; }
.msn__header-actions a:hover, .msn__header-actions button:hover { background:rgba(255,255,255,0.22); }
.msn__header-actions a.active, .msn__header-actions button.active { background:rgba(255,255,255,0.3); }

.msn__search { padding:8px 12px; border-bottom:1px solid var(--border); flex-shrink:0; }
.msn__search form { display:flex; gap:6px; }
.msn__search input { flex:1; border:none; background:var(--bg-input); color:var(--text); border-radius:20px; padding:8px 16px; font-size:0.85rem; font-family:var(--font); outline:none; }
.msn__search input::placeholder { color:var(--text-muted); }
.msn__search button { background:var(--primary); color:#fff; border:none; border-radius:50%; width:36px; height:36px; cursor:pointer; display:flex; align-items:center; justify-content:center; }

.msn__tabs { display:flex; border-bottom:1px solid var(--border); flex-shrink:0; }
.msn__tab { flex:1; text-align:center; padding:10px 0; font-size:0.82rem; font-weight:600; color:var(--text-muted); text-decoration:none; border-bottom:2px solid transparent; transition:all 0.2s; }
.msn__tab:hover { color:var(--text); background:var(--bg-input); }
.msn__tab--active { color:var(--primary); border-bottom-color:var(--primary); }

.msn__list { flex:1; overflow-y:auto; }
.msn__empty { display:flex; flex-direction:column; align-items:center; justify-content:center; height:100%; opacity:0.45; }
.msn__empty i { font-size:3rem; margin-bottom:12px; }
.msn__empty p { font-size:0.9rem; }

.msn__thread { display:flex; align-items:center; gap:12px; padding:12px 16px; border-bottom:1px solid var(--border-light); text-decoration:none; color:inherit; transition:background 0.15s; position:relative; cursor:pointer; }
.msn__thread:hover { background:var(--bg-input); }
.msn__thread--unread { background:rgba(67,97,238,0.04); }
.msn__thread--unread:hover { background:rgba(67,97,238,0.08); }
.msn__thread-avatar { position:relative; flex-shrink:0; }
.msn__thread-avatar img { width:50px; height:50px; border-radius:50%; object-fit:cover; }
.msn__thread-avatar .msn__online { position:absolute; bottom:1px; right:1px; width:12px; height:12px; border-radius:50%; background:var(--success); border:2px solid var(--bg-card); }
.msn__thread-body { flex:1; min-width:0; }
.msn__thread-top { display:flex; align-items:center; justify-content:space-between; gap:8px; margin-bottom:3px; }
.msn__thread-name { font-size:0.92rem; font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.msn__thread-time { font-size:0.7rem; color:var(--text-muted); flex-shrink:0; }
.msn__thread-preview { font-size:0.82rem; color:var(--text-secondary); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; display:flex; align-items:center; gap:4px; }
.msn__thread-preview .you { color:var(--text-muted); }
.msn__thread-right { display:flex; flex-direction:column; align-items:flex-end; gap:4px; flex-shrink:0; }
.msn__badge { background:var(--primary); color:#fff; font-size:0.68rem; font-weight:700; min-width:20px; height:20px; border-radius:10px; display:flex; align-items:center; justify-content:center; padding:0 6px; }
.msn__thread-del { opacity:0; background:none; border:none; color:var(--danger); cursor:pointer; font-size:0.8rem; padding:4px; transition:opacity 0.15s; }
.msn__thread:hover .msn__thread-del { opacity:0.6; }
.msn__thread:hover .msn__thread-del:hover { opacity:1; }

.msn__result { display:flex; align-items:center; gap:12px; padding:10px 16px; border-bottom:1px solid var(--border-light); text-decoration:none; color:inherit; transition:background 0.15s; }
.msn__result:hover { background:var(--bg-input); }
.msn__result .msn__thread-avatar img { width:40px; height:40px; }
.msn__result .msn__online { width:10px; height:10px; }
.msn__result-body { flex:1; min-width:0; }
.msn__result-nick { font-size:0.85rem; font-weight:600; }
.msn__result-text { font-size:0.8rem; color:var(--text-secondary); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; margin-top:2px; }
.msn__result-time { font-size:0.7rem; color:var(--text-muted); flex-shrink:0; }

/* Compose FAB */
.msn__fab { position:absolute; bottom:20px; right:20px; width:52px; height:52px; border-radius:50%; background:var(--primary); color:#fff; display:flex; align-items:center; justify-content:center; font-size:1.15rem; box-shadow:0 4px 12px rgba(67,97,238,0.4); text-decoration:none; z-index:20; transition:transform 0.2s, box-shadow 0.2s; }
.msn__fab:hover { transform:scale(1.08); box-shadow:0 6px 18px rgba(67,97,238,0.5); }

/* Compose overlay */
.msn__compose-overlay { position:fixed; top:0; left:0; width:100%; height:100%; background:rgba(0,0,0,0.5); z-index:1000; display:flex; align-items:center; justify-content:center; animation:fadeIn 0.2s ease-out; }
.msn__compose-box { background:var(--bg-card); border-radius:14px; width:90%; max-width:380px; box-shadow:var(--shadow-lg); overflow:hidden; }
.msn__compose-head { display:flex; align-items:center; justify-content:space-between; padding:12px 16px; font-weight:600; font-size:0.95rem; border-bottom:1px solid var(--border); }
.msn__compose-head button { background:none; border:none; font-size:1.1rem; cursor:pointer; color:var(--text-muted); padding:2px 6px; }
.msn__compose-box input { width:100%; border:none; padding:12px 16px; font-size:0.9rem; font-family:var(--font); outline:none; background:var(--bg); color:var(--text); }
.msn__compose-results { max-height:260px; overflow-y:auto; }
.msn__compose-user { display:flex; align-items:center; gap:10px; padding:10px 16px; text-decoration:none; color:var(--text); transition:background 0.15s; }
.msn__compose-user:hover { background:var(--bg-input); }
.msn__compose-user img { width:36px; height:36px; border-radius:50%; object-fit:cover; }
.msn__compose-user span { font-size:0.88rem; font-weight:500; }
.msn__compose-empty { padding:16px; text-align:center; color:var(--text-muted); font-size:0.85rem; }
@keyframes fadeIn { from { opacity:0; } to { opacity:1; } }

/* === EMPTY STATE === */
.empty { text-align:center; padding:28px 14px; color:var(--text-muted); }
.empty i { font-size:2.2rem; margin-bottom:8px; display:block; opacity:0.4; }
.empty p { font-size:0.85rem; }

/* === RIGHT SIDEBAR widgets === */
.online-widget {
    display:grid;
    grid-template-columns:repeat(2,1fr);
    gap:6px; padding:8px 10px;
}
.online-widget__user {
    display:flex; align-items:center; gap:5px;
    text-decoration:none; color:var(--text);
    font-size:0.72rem; font-weight:500;
    padding:3px;
    border-radius:var(--radius-sm);
    transition:background var(--transition);
    overflow:hidden; white-space:nowrap;
    text-overflow:ellipsis;
}
.online-widget__user:hover { background:var(--bg-input); }
.online-widget__user img {
    width:26px; height:26px;
    border-radius:50%; object-fit:cover;
    border:2px solid var(--success); flex-shrink:0;
}

/* Daily leader */
.leader-widget { text-align:center; padding:12px; }
.leader-widget img {
    width:50px; height:50px;
    border-radius:50%; object-fit:cover;
    border:3px solid var(--warning);
    margin:0 auto 5px;
}
.leader-widget__nick { font-weight:700; font-size:0.82rem; }
.leader-widget__badge {
    display:inline-block;
    background:linear-gradient(135deg,var(--warning),#d97706);
    color:#fff; font-size:0.65rem; font-weight:700;
    padding:2px 8px; border-radius:6px; margin-top:3px;
}

/* Section more-link */
.sb__more {
    display:block; text-align:center;
    padding:7px; font-size:0.72rem; font-weight:600;
    color:var(--primary);
    border-top:1px solid var(--border);
}
.sb__more:hover { background:var(--bg-input); }

/* Widget mini cards */
.widget-mini {
    display:flex; align-items:center; gap:8px;
    padding:7px 12px;
    border-bottom:1px solid var(--border-light);
    font-size:0.78rem;
    text-decoration:none; color:var(--text);
    transition:background var(--transition);
}
.widget-mini:last-child { border-bottom:none; }
.widget-mini:hover { background:var(--bg-input); }
.widget-mini__icon {
    width:28px; height:28px;
    border-radius:6px;
    display:flex; align-items:center; justify-content:center;
    font-size:0.7rem; color:#fff; flex-shrink:0;
}
.widget-mini__text { flex:1; min-width:0; font-weight:500; }
.widget-mini__count {
    font-size:0.68rem; color:var(--text-muted);
    font-weight:600;
}

/* === FOOTER === */
.footer {
    text-align:center; padding:14px 10px;
    color:var(--text-muted); font-size:0.72rem;
    border-top:1px solid var(--border); margin-top:16px;
}
.footer a { color:var(--text-secondary); }

/* === RESPONSIVE === */
@media (max-width:1024px) {
    .layout {
        grid-template-columns:var(--sidebar-w) 1fr;
    }
    .layout__right { display:none; }
}

@media (max-width:768px) {
    .layout {
        grid-template-columns:1fr;
        padding:8px;
    }
    .layout__left { display:none; }
    .layout__right { display:none; }

    .header__nav {
        display:none;
        position:fixed;
        top:48px; left:0; right:0; bottom:0;
        background:var(--bg-card);
        flex-direction:column;
        padding:14px; gap:2px;
        overflow-y:auto; z-index:99;
    }
    .header__nav.open { display:flex; }
    .header__nav .header__link {
        color:var(--text); padding:10px 14px;
        border-radius:var(--radius-sm); font-size:0.88rem;
    }
    .header__nav .header__link:hover,
    .header__nav .header__link--active {
        background:var(--bg-input); color:var(--primary);
    }
    .header__burger { display:block; }
    .header__mobile-extra {
        border-top:1px solid var(--border-light);
        margin-top:8px;
        padding-top:8px;
        display:block;
    }
    .header__mobile-section {
        font-size:0.75rem;
        font-weight:700;
        color:var(--text-muted);
        text-transform:uppercase;
        letter-spacing:0.5px;
        padding:10px 14px 4px;
        display:block;
    }
    .container { padding:12px 8px; }
    .grid--3, .grid--4 { grid-template-columns:repeat(2,1fr); }

    /* Fix mobile sidebar content visibility */
    .mobile-sidebar .layout__left { display:block !important; }
    /* Hide dialog FAB and old sidebar btn on mobile */
    #dialog-fab, #dialog-modal { display:none !important; }
    .mobile-sidebar-btn { display:none !important; }
}

/* === სქესთა ბრძოლა / Battle === */
.battle-scoreboard {
    display:flex; align-items:center; gap:16px; justify-content:center; padding:20px 0;
}
.battle-team { text-align:center; min-width:80px; }
.battle-team__icon { font-size:2rem; margin-bottom:4px; }
.battle-team--male .battle-team__icon { color:#4361ee; }
.battle-team--female .battle-team__icon { color:#f72585; }
.battle-team__label { font-size:0.85rem; font-weight:600; color:var(--text-secondary); }
.battle-team__score { font-size:2.5rem; font-weight:800; line-height:1.1; }
.battle-team--male .battle-team__score { color:#4361ee; }
.battle-team--female .battle-team__score { color:#f72585; }
.battle-vs { text-align:center; flex:1; max-width:200px; }
.battle-vs__text { font-size:1.4rem; font-weight:800; color:var(--text-muted); }
.battle-vs__target { font-size:0.75rem; color:var(--text-secondary); margin:4px 0 8px; }
.battle-vs__progress { display:flex; height:8px; border-radius:4px; overflow:hidden; background:var(--border); gap:2px; }
.battle-vs__bar { height:100%; transition:width .5s ease; border-radius:4px; }
.battle-vs__bar--male { background:linear-gradient(90deg,#4361ee,#3a86ff); }
.battle-vs__bar--female { background:linear-gradient(90deg,#f72585,#e63988); }
.battle-question { margin-top:16px; border:1px solid var(--border); border-radius:var(--radius); background:var(--bg); }
.bc-msg { padding:4px 0; font-size:0.88rem; word-break:break-word; }
.bc-msg--system { color:var(--primary); font-style:italic; text-align:center; padding:6px 0; }
.bc-msg__nick { font-weight:600; margin-right:4px; }
.battle-top-item { display:flex; align-items:center; gap:8px; padding:4px 0; }
.battle-top-rank { font-weight:700; color:var(--primary); min-width:20px; text-align:center; }
.battle-top-pts { color:var(--text-secondary); font-size:0.85rem; }

/* === მუსიკა / Music === */
.music-tab {
    flex:1; text-align:center; padding:12px; font-weight:600; font-size:0.9rem;
    color:var(--text-secondary); text-decoration:none; transition:all .2s;
    border-bottom:3px solid transparent;
}
.music-tab:hover { color:var(--primary); background:var(--bg); }
.music-tab--active { color:var(--primary); border-bottom-color:var(--primary); }
.music-player {
    position:sticky; top:0; z-index:50; background:var(--bg-card);
    border-bottom:1px solid var(--border); padding:12px 16px;
    display:flex; align-items:center; gap:12px; flex-wrap:wrap;
}
.music-player__info { flex:1; min-width:120px; }
.music-player__title { font-weight:700; font-size:0.95rem; }
.music-player__artist { font-size:0.8rem; color:var(--text-secondary); }
.music-player__controls { display:flex; align-items:center; gap:8px; }
.music-ctrl {
    background:none; border:none; font-size:1rem; color:var(--text);
    cursor:pointer; padding:6px; border-radius:50%; transition:all .2s;
}
.music-ctrl:hover { color:var(--primary); background:var(--bg); }
.music-ctrl--play { font-size:1.3rem; width:40px; height:40px; display:flex; align-items:center; justify-content:center; background:var(--primary); color:white; border-radius:50%; }
.music-ctrl--play:hover { background:var(--primary-dark); color:white; }
.music-player__progress { display:flex; align-items:center; gap:6px; font-size:0.8rem; color:var(--text-secondary); flex:1; min-width:150px; }
.music-seek { -webkit-appearance:none; appearance:none; height:4px; border-radius:2px; background:var(--border); outline:none; flex:1; cursor:pointer; }
.music-seek::-webkit-slider-thumb { -webkit-appearance:none; width:12px; height:12px; border-radius:50%; background:var(--primary); cursor:pointer; }
.music-player__volume { display:flex; align-items:center; gap:6px; font-size:0.85rem; color:var(--text-secondary); }
.music-list { /* container */ }
.music-item {
    display:flex; align-items:center; gap:10px; padding:10px 16px;
    border-bottom:1px solid var(--border-light); transition:background .15s; cursor:default;
}
.music-item:hover { background:var(--bg); }
.music-item--playing { background:rgba(67,97,238,.08); }
.music-item--playing .music-item__num { display:none; }
.music-item--playing .music-item__play { display:flex !important; }
.music-item__num { font-size:0.85rem; color:var(--text-secondary); min-width:28px; text-align:center; cursor:pointer; }
.music-item__play {
    display:none; min-width:28px; height:28px; border-radius:50%;
    background:var(--primary); color:white; align-items:center; justify-content:center;
    font-size:0.7rem; cursor:pointer;
}
.music-item:hover .music-item__num { display:none; }
.music-item:hover .music-item__play { display:flex; }
.music-item__info { flex:1; min-width:0; cursor:pointer; }
.music-item__title { font-weight:600; font-size:0.95rem; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.music-item__meta { font-size:0.8rem; color:var(--text-secondary); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.music-item__actions { display:flex; align-items:center; gap:6px; }
.music-like {
    background:none; border:none; color:var(--text-muted); cursor:pointer;
    font-size:0.85rem; padding:4px 8px; border-radius:var(--radius); transition:all .2s;
}
.music-like:hover { color:var(--danger); }
.music-like--active { color:var(--danger); }

/* === ვიდეო / Video === */
.video-card {
    display:block; border-radius:var(--radius); overflow:hidden;
    background:var(--bg-card); border:1px solid var(--border);
    text-decoration:none; color:var(--text); transition:transform .2s, box-shadow .2s;
}
.video-card:hover { transform:translateY(-2px); box-shadow:0 4px 12px rgba(0,0,0,.1); }
.video-card__thumb { position:relative; aspect-ratio:16/9; background:#000; overflow:hidden; }
.video-card__thumb img { width:100%; height:100%; object-fit:cover; }
.video-card__placeholder {
    width:100%; height:100%; display:flex; align-items:center; justify-content:center;
    font-size:3rem; color:rgba(255,255,255,.3); background:linear-gradient(135deg,#1a1a2e,#16213e);
}
.video-card__overlay {
    position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
    background:rgba(0,0,0,.2); opacity:0; transition:opacity .2s;
    font-size:2rem; color:white;
}
.video-card:hover .video-card__overlay { opacity:1; }
.video-card__info { padding:10px 12px; }
.video-card__title { font-weight:600; font-size:0.95rem; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.video-card__meta { font-size:0.8rem; color:var(--text-secondary); margin-top:4px; }
.video-player-wrap { background:#000; }

@media (max-width:600px) {
    .battle-scoreboard { gap:8px; }
    .battle-team__score { font-size:1.8rem; }
    .battle-vs { max-width:120px; }
    .music-player { flex-direction:column; gap:8px; }
    .music-player__progress { width:100%; }
    .video-grid { grid-template-columns:1fr !important; }
}

@media (max-width:480px) {
    .grid--2, .grid--4 { grid-template-columns:1fr; }
    .profile__stats { gap:12px; }

    /* Mobile messaging tweaks */
    .wa-bubble { max-width:88%; padding:6px 10px 4px; font-size:0.85rem; }
    .wa-body { padding:8px; -webkit-overflow-scrolling:touch; }
    .wa-send__btn { width:40px; height:40px; }
    .wa-send__input { padding:10px 14px; font-size:0.9rem; min-height:40px; }
    .wa-header { padding:6px 10px; gap:8px; min-height:50px; }
    .wa-header__avatar { width:36px; height:36px; }
    .wa-footer { padding:6px 8px; }
    .wa-row { padding:0 2px; }
    .wa-bubble img.wa-img { max-width:70vw; }
    .wa-video { max-width:70vw; }
    .wa-audio { width:70vw; max-width:260px; }
    .wa-scroll-btn { bottom:70px; right:10px; width:36px; height:36px; }
    .wa-lightbox img { max-width:96%; }

    .msn__thread { padding:10px 12px; gap:10px; }
    .msn__thread-avatar img { width:46px; height:46px; }
    .msn__header { padding:8px 12px; min-height:50px; }
    .msn__list { -webkit-overflow-scrolling:touch; }
    .msn__thread-del { opacity:0.5; } /* Always visible on touch */
    .msn__fab { width:46px; height:46px; bottom:14px; right:14px; font-size:1rem; }
    .msn__compose-box { width:94%; max-width:340px; }
}

/* Mobile sidebar toggle */
.mobile-sidebar-btn {
    display:none;
    position:fixed; bottom:14px; left:14px;
    width:42px; height:42px; border-radius:50%;
    background:var(--primary); color:#fff;
    border:none; font-size:1rem;
    box-shadow:var(--shadow-lg); z-index:90; cursor:pointer;
    align-items:center; justify-content:center;
}
@media (max-width:768px) {
    .mobile-sidebar-btn { display:flex; }
}
.mobile-sidebar-overlay {
    display:none;
    position:fixed; top:0; left:0; right:0; bottom:0;
    background:rgba(0,0,0,0.5); z-index:91;
}
.mobile-sidebar-overlay.open { display:block; }
.mobile-sidebar {
    position:fixed; top:0; left:-280px; bottom:0;
    width:260px;
    background:var(--bg-sidebar);
    z-index:92; overflow-y:auto;
    transition:left 0.25s ease;
    box-shadow:var(--shadow-lg);
    padding:10px;
}
.mobile-sidebar.open { left:0; }

/* Theme toggle */
.theme-toggle {
    background:var(--bg-input);
    border:1px solid var(--border);
    color:var(--text);
    border-radius:var(--radius-sm);
    padding:5px 8px; cursor:pointer;
    font-size:0.75rem;
}

/* ============ CHEST (ჯადოსნური სკივრი) ============ */
.chest-box {
    width:120px; height:120px; margin:0 auto;
    background:linear-gradient(135deg,#f59e0b,#ea580c);
    border-radius:16px; display:flex; align-items:center; justify-content:center;
    font-size:3.5rem; cursor:pointer; transition:transform 0.3s;
    box-shadow:0 8px 24px rgba(245,158,11,0.3);
}
.chest-box:hover { transform:scale(1.08) rotate(-3deg); }
.chest-box.opened { animation:chestOpen 0.6s ease forwards; pointer-events:none; }
@keyframes chestOpen { 0%{transform:scale(1)} 30%{transform:scale(1.2) rotate(5deg)} 50%{transform:scale(0.95)} 100%{transform:scale(1.1)} }
.chest-reward { animation:rewardPop 0.5s ease; }
@keyframes rewardPop { 0%{opacity:0;transform:translateY(20px) scale(0.8)} 100%{opacity:1;transform:translateY(0) scale(1)} }
.chest-tier { display:inline-block; padding:3px 10px; border-radius:12px; font-size:0.8rem; font-weight:700; color:#fff; }
.chest-tier--jackpot { background:linear-gradient(135deg,#f59e0b,#ef4444); }
.chest-tier--big { background:linear-gradient(135deg,#8b5cf6,#6d28d9); }
.chest-tier--medium { background:linear-gradient(135deg,#3b82f6,#2563eb); }
.chest-tier--small { background:linear-gradient(135deg,#6b7280,#4b5563); }

/* ============ BUILDING (გიჟური მშენებლობა) ============ */
.building-visual {
    position:relative; width:120px; height:200px; margin:0 auto;
    border:2px solid var(--border); border-bottom:3px solid #6b7280;
    border-radius:4px 4px 0 0; overflow:hidden; background:var(--bg);
}
.building-structure {
    position:absolute; bottom:0; left:0; right:0;
    background:linear-gradient(135deg,#f97316,#dc2626);
    transition:height 0.5s ease; display:flex; flex-direction:column-reverse;
}
.building-floor {
    height:10%; border-top:1px dashed rgba(255,255,255,0.3);
    background:rgba(255,255,255,0.05);
}
.building-crane {
    position:absolute; top:-8px; right:4px; font-size:1.5rem;
    animation:craneSway 3s infinite ease-in-out;
}
@keyframes craneSway { 0%,100%{transform:rotate(-5deg)} 50%{transform:rotate(5deg)} }
.building-progress-bar {
    width:100%; height:20px; background:var(--bg); border-radius:10px;
    overflow:hidden; border:1px solid var(--border);
}
.building-progress-fill {
    height:100%; background:linear-gradient(90deg,#f97316,#dc2626);
    transition:width 0.5s ease; border-radius:10px;
}
.building-click-btn {
    width:100px; height:100px; border-radius:50%; border:none;
    background:linear-gradient(135deg,#f97316,#dc2626); color:#fff;
    cursor:pointer; font-size:1.5rem; transition:transform 0.15s, box-shadow 0.15s;
    box-shadow:0 6px 20px rgba(249,115,22,0.3);
}
.building-click-btn:hover { transform:scale(1.05); box-shadow:0 8px 28px rgba(249,115,22,0.4); }
.building-click-btn:active { transform:scale(0.95); }
.building-prize {
    padding:8px 16px; border-radius:10px; font-weight:700; font-size:0.85rem;
}
.building-prize--1 { background:linear-gradient(135deg,#fef3c7,#fde68a); color:#92400e; }
.building-prize--2 { background:linear-gradient(135deg,#e2e8f0,#cbd5e1); color:#475569; }
.building-prize--3 { background:linear-gradient(135deg,#fed7aa,#fdba74); color:#9a3412; }

/* ============ SHOOTING (სროლა) ============ */
.shooting-arena { position:relative; }
.shooting-hud {
    display:flex; justify-content:space-between; padding:12px 16px;
    background:linear-gradient(135deg,#1e293b,#0f172a); color:#fff; font-size:1rem;
}
.shooting-zone {
    position:relative; width:100%; height:400px;
    background:linear-gradient(180deg,#87ceeb 0%,#e0f2fe 50%,#86efac 50%,#22c55e 100%);
    overflow:hidden; cursor:crosshair; user-select:none;
}
.shooting-target {
    position:absolute; border-radius:50%;
    background:radial-gradient(circle, #fff 15%, #ef4444 15%, #ef4444 35%, #fff 35%, #fff 45%, #ef4444 45%);
    cursor:crosshair; animation:targetAppear 0.3s ease;
    box-shadow:0 2px 8px rgba(0,0,0,0.2);
    display:flex; align-items:center; justify-content:center;
}
.target-pts {
    font-size:0.65rem; font-weight:700; color:#fff;
    text-shadow:0 1px 2px rgba(0,0,0,0.5); pointer-events:none;
}
@keyframes targetAppear { 0%{transform:scale(0)} 100%{transform:scale(1)} }
.target-hit { animation:targetHit 0.2s ease forwards; }
@keyframes targetHit { 0%{transform:scale(1);opacity:1} 100%{transform:scale(1.5);opacity:0} }
.target-miss { animation:targetMiss 0.3s ease forwards; }
@keyframes targetMiss { 0%{opacity:1} 100%{opacity:0;transform:translateY(20px)} }
@keyframes floatUp { 0%{opacity:1;transform:translateY(0)} 100%{opacity:0;transform:translateY(-40px)} }
.mini-stat {
    padding:8px; border-radius:var(--radius-sm); background:var(--bg);
    border:1px solid var(--border-light);
}

/* ============ QUIZ (ვიქტორინა) ============ */
.quiz-cat-label {
    display:inline-block; padding:3px 10px; border-radius:12px; font-size:0.8rem;
    background:var(--primary); color:#fff; font-weight:600;
}
.quiz-diff { margin-left:8px; color:#f59e0b; font-size:0.9rem; }
.quiz-option-btn {
    width:100%; padding:14px 18px; border:2px solid var(--border);
    border-radius:var(--radius); background:var(--bg-card); color:var(--text);
    font-size:1rem; cursor:pointer; transition:all 0.2s; text-align:left;
}
.quiz-option-btn:hover:not(:disabled) { border-color:var(--primary); background:rgba(67,97,238,0.05); }
.quiz-option--correct { border-color:var(--success) !important; background:rgba(16,185,129,0.1) !important; }
.quiz-option--wrong { border-color:var(--danger) !important; background:rgba(239,68,68,0.1) !important; }

/* ============ BADGES (ბეჯები) ============ */
.badge-my-grid {
    display:flex; flex-wrap:wrap; gap:10px;
}
.badge-item {
    display:flex; align-items:center; gap:8px;
    padding:6px 12px; border-radius:var(--radius); border:2px solid var(--border);
    background:var(--bg); font-size:0.9rem;
}
.badge-item--owned { border-style:solid; }
.badge-icon {
    width:32px; height:32px; border-radius:50%; display:flex;
    align-items:center; justify-content:center; font-size:1rem; color:#fff;
    flex-shrink:0;
}
.badge-icon-sm {
    width:24px; height:24px; border-radius:50%; display:inline-flex;
    align-items:center; justify-content:center; font-size:0.75rem; color:#fff;
}
.badge-name { font-weight:600; }
.badge-shop-grid {
    display:grid; grid-template-columns:repeat(auto-fill,minmax(180px,1fr)); gap:16px;
}
.badge-shop-card {
    border:2px solid var(--border-light); border-radius:var(--radius);
    padding:16px; text-align:center; transition:transform 0.2s, box-shadow 0.2s;
    background:var(--bg-card);
}
.badge-shop-card:hover { transform:translateY(-2px); box-shadow:0 4px 12px rgba(0,0,0,0.08); }
.badge-shop-card--owned { border-color:var(--success); background:rgba(16,185,129,0.03); }
.badge-shop-icon {
    width:48px; height:48px; border-radius:50%; display:flex;
    align-items:center; justify-content:center; font-size:1.5rem; color:#fff;
    margin:0 auto 8px;
}
.badge-shop-name { font-weight:700; font-size:1rem; margin-bottom:4px; }
.badge-shop-desc { font-size:0.8rem; color:var(--text-secondary); margin-bottom:8px; min-height:32px; }
.badge-shop-price { font-weight:700; color:var(--primary); margin-bottom:10px; }
.badge-shop-status { font-size:0.85rem; font-weight:600; }
.badge-shop-status--owned { color:var(--success); }
.badge-shop-status--locked { color:var(--text-muted); }

@media (max-width:600px) {
    .shooting-zone { height:300px; }
    .building-visual { width:80px; height:140px; }
    .building-click-btn { width:80px; height:80px; font-size:1.2rem; }
    .badge-shop-grid { grid-template-columns:repeat(auto-fill,minmax(140px,1fr)); gap:10px; }
    .badge-shop-card { padding:12px; }
}

/* === MOBILE HEADER ICONS === */
.header__mobile-icons { display:none; }
.header__micon {
    color:rgba(255,255,255,0.8); padding:6px 7px;
    font-size:0.85rem; position:relative;
    display:flex; align-items:center; text-decoration:none;
}
.header__micon:hover { color:#fff; }
.header__mbadge {
    position:absolute; top:0; right:0;
    background:var(--accent); color:#fff;
    font-size:0.55rem; font-weight:700;
    min-width:14px; height:14px; border-radius:7px;
    display:flex; align-items:center; justify-content:center;
    padding:0 3px; line-height:1;
}
@media (max-width:768px) {
    .header__mobile-icons {
        display:flex; align-items:center; gap:0; margin-left:auto;
    }
}

/* === BOTTOM NAV === */
.bottom-nav {
    display:none;
    position:fixed; bottom:0; left:0; right:0;
    background:var(--bg-card);
    border-top:1px solid var(--border);
    box-shadow:0 -2px 8px rgba(0,0,0,0.08);
    z-index:95;
}
.bottom-nav__item {
    flex:1; display:flex; flex-direction:column;
    align-items:center; justify-content:center;
    padding:8px 0; font-size:0.62rem; font-weight:500;
    color:var(--text-muted); text-decoration:none;
    transition:color 0.2s; position:relative;
    cursor:pointer; background:none; border:none;
    font-family:var(--font);
}
.bottom-nav__item i { font-size:1.1rem; margin-bottom:2px; }
.bottom-nav__item:hover, .bottom-nav__item--active { color:var(--primary); }
.bottom-nav__badge {
    position:absolute; top:2px; right:calc(50% - 16px);
    background:var(--danger); color:#fff;
    font-size:0.55rem; font-weight:700;
    min-width:14px; height:14px; border-radius:7px;
    display:flex; align-items:center; justify-content:center;
    padding:0 3px;
}
@media (max-width:768px) {
    .bottom-nav { display:flex; }
    body { padding-bottom:56px; }
}
