
:root{
  --bg:#f5f7fb;
  --surface:#ffffff;
  --surface-2:#f8fafc;
  --surface-3:#eef2f7;
  --text:#0f172a;
  --muted:#64748b;
  --line:#e2e8f0;
  --line-strong:#cbd5e1;
  --primary:#2294ff;
  --primary-strong:#1570ef;
  --primary-soft:#e8f3ff;
  --success:#0f9f6e;
  --danger:#dc2626;
  --shadow-sm:0 8px 24px rgba(15,23,42,.06);
  --shadow-md:0 18px 40px rgba(15,23,42,.08);
  --shadow-lg:0 28px 60px rgba(15,23,42,.10);
  --radius-sm:14px;
  --radius-md:18px;
  --radius-lg:24px;
  --radius-xl:30px;
  --radius-2xl:36px;
  --content-max:1240px;
  --feed-max:820px;
  --right-rail:320px;
  --desktop-rail: 215px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;min-height:100%}
body{font-family:"Inter",system-ui,sans-serif;background:linear-gradient(180deg,#f8fbff 0%,#f4f7fb 100%);color:var(--text);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
a{color:var(--primary-strong);text-decoration:none}
a:hover{color:var(--primary)}
img{display:block;max-width:100%}
button,input,textarea,select{font:inherit}
button{cursor:pointer}
textarea{resize:vertical;min-height:140px}
.material-symbols-rounded{font-variation-settings:'FILL' 0,'wght' 500,'GRAD' 0,'opsz' 24;font-size:20px;line-height:1}
body::before{content:"";position:fixed;inset:0;background:radial-gradient(circle at top right,rgba(34,148,255,.12),transparent 28%),radial-gradient(circle at top left,rgba(59,130,246,.08),transparent 20%);pointer-events:none;z-index:-1}
.shell{width:min(100%,calc(var(--content-max) + 40px));margin:0 auto;padding:0 20px}
.page{padding:28px 0 110px}
.page-grid{display:grid;grid-template-columns:minmax(0,1fr);gap:24px;align-items:start}
.page-auth{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:28px}
.page-auth::before{content:"";position:fixed;inset:0;background:radial-gradient(circle at 12% 18%,rgba(34,148,255,.14),transparent 18%),radial-gradient(circle at 86% 8%,rgba(59,130,246,.12),transparent 18%),linear-gradient(180deg,#f8fbff 0%,#f3f7fb 100%);z-index:-2}
.auth-shell{width:min(1220px,100%);}
.auth-shell-inner{max-width:560px;width:100%}
.auth-showcase{display:none;position:relative;overflow:hidden;padding:38px;border-radius:40px;background:linear-gradient(180deg,#0b1220 0%,#101a2f 100%);color:#fff;box-shadow:var(--shadow-lg)}
.auth-showcase::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 20%,rgba(56,189,248,.14),transparent 22%),radial-gradient(circle at 80% 18%,rgba(96,165,250,.18),transparent 22%),radial-gradient(circle at 50% 100%,rgba(255,255,255,.08),transparent 38%)}
.showcase-inner{position:relative;z-index:1;display:flex;flex-direction:column;height:100%}
.brand-mark{display:flex;align-items:center;gap:14px;font-weight:800;font-size:22px;letter-spacing:-.03em}
.brand-mark img{width:52px;height:52px}
.showcase-title{margin:54px 0 16px;font-size:50px;line-height:1.02;font-weight:900;letter-spacing:-.06em;max-width:8ch}
.showcase-copy{margin:0;max-width:430px;color:rgba(255,255,255,.76);font-size:17px;line-height:1.7}
.showcase-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:auto;padding-top:34px}
.glass-card{padding:18px;border-radius:22px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.10);backdrop-filter:blur(10px)}
.glass-card strong{display:block;font-size:15px;margin-bottom:8px;color:#fff}
.glass-card span{display:block;font-size:14px;line-height:1.6;color:rgba(255,255,255,.74)}
.auth-card,.card,.composer-modal,.comments-sheet,.sidebar-card{background:rgba(255,255,255,.92);backdrop-filter:blur(16px);border:1px solid rgba(226,232,240,.95);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm)}
.auth-card{padding:34px 30px}
.auth-card-telegram{display:flex;flex-direction:column;gap:18px}
.logo-wrap{display:flex;align-items:center;justify-content:center;margin-bottom:8px}
.logo{width:74px;height:74px}
.auth-title{margin:0;font-size:clamp(38px,7vw,60px);line-height:1;font-weight:900;letter-spacing:-.06em}
.auth-subtitle{margin:0;color:var(--muted);font-size:17px;line-height:1.7}
.auth-actions-stack{display:grid;gap:12px}
.auth-center-note{text-align:center}
.auth-warning{padding:14px 16px;border-radius:18px;background:#fff7ed;border:1px solid #fed7aa;color:#9a3412}
.telegram-auth-card,.telegram-inline-note{display:flex;align-items:flex-start;gap:14px;padding:18px 18px;border-radius:22px;background:var(--surface-2);border:1px solid var(--line)}
.telegram-auth-card h3{margin:0 0 6px;font-size:18px}
.telegram-auth-card p,.telegram-inline-note span:last-child{margin:0;color:var(--muted);line-height:1.6}
.telegram-auth-icon,.telegram-inline-note .material-symbols-rounded{width:42px;height:42px;border-radius:14px;display:grid;place-items:center;background:var(--primary-soft);color:var(--primary-strong);flex:0 0 42px}
.telegram-widget-wrap{display:flex;justify-content:center;padding:6px 0}
.field{margin-bottom:16px}
.field label{display:block;margin-bottom:10px;font-size:14px;font-weight:700;color:#1e293b}
.field-note,.page-note{margin:8px 0 0;color:var(--muted);font-size:13px;line-height:1.6}
.input,.textarea,.code-input,input[type="file"]{width:100%;border:1px solid var(--line);background:#fff;border-radius:18px;padding:15px 16px;color:var(--text);outline:none;transition:border-color .16s ease, box-shadow .16s ease, transform .16s ease}
.input:focus,.textarea:focus,.code-input:focus,input[type="file"]:focus{border-color:#9ec5ff;box-shadow:0 0 0 4px rgba(34,148,255,.12);transform:translateY(-1px)}
.field-row{display:flex;gap:12px;align-items:center}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;border:none;border-radius:999px;padding:14px 20px;font-weight:700;line-height:1;transition:transform .12s ease,box-shadow .18s ease,background .18s ease,color .18s ease,border-color .18s ease}
.btn:active{transform:translateY(1px) scale(.99)}
.btn-primary{background:linear-gradient(180deg,var(--primary) 0%,var(--primary-strong) 100%);color:#fff;box-shadow:0 12px 24px rgba(21,112,239,.22)}
.btn-primary:hover{box-shadow:0 16px 32px rgba(21,112,239,.28)}
.btn-secondary{background:#fff;color:var(--text);border:1px solid var(--line)}
.btn-ghost{background:var(--surface-2);color:var(--text);border:1px solid var(--line)}
.btn-light{background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.16)}
.btn-block{width:100%}
.link-row{display:flex;justify-content:space-between;align-items:center;gap:12px;margin:12px 0 24px}
.muted{color:var(--muted);text-align:center}.center{text-align:center}.small{font-size:14px}
.code-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:10px;margin:18px 0 24px}
.code-input{height:72px;text-align:center;font-size:28px;font-weight:900;border-radius:22px;padding:0}
.stepper{display:flex;align-items:center;gap:12px;margin:0 0 24px}.step-dot{width:48px;height:48px;border-radius:50%;display:grid;place-items:center;background:#e8eef7;color:#5b6a83;font-weight:800}.step-dot.is-active{background:linear-gradient(180deg,var(--primary),var(--primary-strong));color:#fff}.step-line{height:4px;flex:1;border-radius:999px;background:#dbe4f1}.step-line.is-active{background:linear-gradient(90deg,#60a5fa,#2563eb)}
.topics{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.topic-chip{padding:15px 16px;border-radius:18px;background:#fff;border:1px solid var(--line);font-weight:700;color:var(--text)}.topic-chip.is-active{background:var(--primary-soft);border-color:#bfdbfe;color:var(--primary-strong)}
.page-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:20px}.page-eyebrow{display:inline-flex;align-items:center;gap:8px;padding:9px 14px;border-radius:999px;background:#fff;border:1px solid var(--line);color:var(--primary-strong);font-size:12px;font-weight:800;letter-spacing:.06em;text-transform:uppercase}.page-title{margin:10px 0 0;font-size:clamp(34px,6vw,58px);line-height:.98;font-weight:900;letter-spacing:-.06em}.page-subtitle{margin:14px 0 0;color:var(--muted);line-height:1.7;font-size:17px;max-width:48ch}.page-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.hero-card{padding:24px 24px 22px;background:linear-gradient(180deg,#fff 0%,#f8fbff 100%);border-radius:var(--radius-xl)}.hero-grid{display:grid;gap:16px}.inline-stats{display:flex;gap:10px;flex-wrap:wrap}.badge{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:999px;background:var(--surface-2);border:1px solid var(--line);font-size:13px;font-weight:700;color:var(--text)}.badge-soft{background:var(--primary-soft);border-color:#dbeafe;color:var(--primary-strong)}
.feed-list,.list{display:grid;gap:16px}.feed-list{margin-top:22px;display:grid;gap:18px}
.post-card,.user-card,.event-card,.notice-card,.sidebar-card{padding:22px;border-radius:28px}.post-head{display:flex;gap:14px;align-items:flex-start}.avatar{width:52px;height:52px;border-radius:18px;display:grid;place-items:center;background:linear-gradient(180deg,#eef5ff,#e6eefb);color:var(--primary-strong);font-weight:800;overflow:hidden}.avatar img{width:100%;height:100%;object-fit:cover}.avatar-xl{width:124px;height:124px;border-radius:34px;border:6px solid rgba(255,255,255,.96);box-shadow:var(--shadow-md)}.post-meta{flex:1;min-width:0}.post-name{display:inline-block;color:var(--text);font-size:17px;font-weight:800;margin-bottom:4px}.post-user{color:var(--muted);font-size:14px;line-height:1.5}.post-body{margin:16px 0 12px;font-size:15px;line-height:1.78;color:#1e293b;white-space:pre-wrap;word-break:break-word}.post-tags{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}.post-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}.action-btn{display:inline-flex;align-items:center;gap:8px;border:none;background:var(--surface-2);border:1px solid var(--line);border-radius:999px;padding:11px 14px;font-weight:700;color:var(--text)}.action-btn.is-active{background:#0f172a;color:#fff;border-color:#0f172a}.action-btn .material-symbols-rounded{font-size:18px}.comments-inline{color:var(--muted);font-size:14px}
.cover{position:relative;height:220px;border-radius:34px;background:linear-gradient(135deg,#0f172a 0%,#0f1b33 58%,#1570ef 100%);box-shadow:var(--shadow-md);overflow:hidden}.cover::before,.cover::after{content:"";position:absolute;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.16),transparent 62%)}.cover::before{width:260px;height:260px;top:-70px;right:-50px}.cover::after{width:220px;height:220px;left:-60px;bottom:-80px}
.profile-head{margin-top:-76px;position:relative;z-index:2;padding:0 18px 0}.profile-avatar-wrap{display:flex;justify-content:center}.profile-main{text-align:center;margin-top:18px}.profile-name{margin:0;font-size:clamp(28px,5vw,40px);line-height:1.06;font-weight:900;letter-spacing:-.04em}.profile-username{margin:8px 0 0;color:var(--muted);font-size:18px}.profile-stats{display:flex;justify-content:center;gap:14px;flex-wrap:wrap;margin:22px 0}.profile-stat{min-width:120px;padding:14px 18px;border-radius:20px;background:#fff;border:1px solid var(--line)}.profile-stat strong{display:block;font-size:24px}.profile-stat span{display:block;margin-top:6px;color:var(--muted);font-size:13px}.profile-actions{display:flex;justify-content:center;gap:10px;flex-wrap:wrap}.meta-row{display:flex;gap:14px;align-items:center;flex-wrap:wrap;color:var(--muted);font-size:14px}.segmented{display:inline-flex;gap:8px;padding:6px;border-radius:999px;background:#eef3f8;border:1px solid var(--line)}.segmented button{border:none;background:transparent;padding:12px 16px;border-radius:999px;font-weight:700;color:var(--muted)}.segmented .is-active{background:#fff;color:var(--text);box-shadow:var(--shadow-sm)}
.rail-note{display:grid;gap:8px}.rail-note strong{font-size:15px}.rail-list{display:grid;gap:10px;margin-top:4px}.rail-list-item{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;border-radius:18px;background:var(--surface-2);border:1px solid var(--line)}.rail-list-item .material-symbols-rounded{color:var(--primary-strong)}.hero-card{padding:24px 26px}.hero-grid{display:grid;gap:18px}.hero-card .page-head img{height:52px!important}.hero-card .inline-stats{display:flex;flex-wrap:wrap;gap:10px}.hero-card .badge{padding:12px 16px}.page-actions{display:flex;justify-content:flex-start}.feed-column{display:grid;gap:18px}.right-column{display:none}
.empty-state{padding:22px;text-align:center;color:var(--muted);border-radius:24px;background:#fff;border:1px dashed var(--line-strong)}.sidebar-stack{display:grid;gap:16px;position:sticky;top:28px}.sidebar-card h3{margin:0 0 10px;font-size:18px}.sidebar-card p{margin:0;color:var(--muted);line-height:1.7}.telegram-rail-card{display:grid;gap:14px;padding:22px;border-radius:28px;background:linear-gradient(180deg,#0f172a 0%,#12213d 100%);color:#fff;border:1px solid rgba(255,255,255,.08);box-shadow:var(--shadow-md)}.telegram-rail-card p{color:rgba(255,255,255,.78)}.telegram-rail-head{display:flex;align-items:center;gap:10px;color:#fff}.telegram-rail-head .material-symbols-rounded{width:38px;height:38px;display:grid;place-items:center;border-radius:12px;background:rgba(255,255,255,.12)}
.desktop-nav{    display: none;
    position: fixed;
    left: 24px;
    top: 24px;
    bottom: 24px;
    width: var(--desktop-rail);
    padding: 22px;
    background: #f7fafe;
    border-radius: 32px;
    z-index: 40;
    color: #cbd5e1;
    display: flex;
    flex-direction: column;
    justify-content: space-between;}.desktop-brand{display:flex;align-items:center;gap:14px;color:#fff}.desktop-brand img{width:52px;height:52px}.desktop-brand strong{display:block;font-size:28px;line-height:1;font-weight:800;letter-spacing:-.05em}.desktop-brand span{display:block;font-size:13px;color:#94a3b8;margin-top:4px}.desktop-menu{display:grid;gap:8px;margin-top:28px}.desktop-menu a{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:18px;color: #000000;font-weight:700}.desktop-menu a:hover,.desktop-menu a.is-active{background: rgb(255 255 255 / 8%);color: #0384e9;}.desktop-meta{padding:18px;border-radius:22px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.09);color:#cbd5e1}.desktop-meta p{margin:0}.desktop-meta .btn{margin-top:14px;width:100%;justify-content:center}
.bottom-nav{position:fixed;left:12px;right:12px;bottom:12px;display:flex;gap:8px;justify-content:space-between;padding:10px;background:rgba(255,255,255,.96);backdrop-filter:blur(18px);border:1px solid rgba(226,232,240,.96);border-radius:26px;box-shadow:var(--shadow-md);z-index:45}.nav-item{flex:1;min-width:0;display:flex;flex-direction:column;align-items:center;gap:6px;padding:10px 8px;border-radius:18px;color:var(--muted);font-size:11px;font-weight:700;text-align:center}.nav-item.is-active{background:var(--primary-soft);color:var(--primary-strong)}
.floating-create{position:fixed;right:18px;bottom:90px;width:62px;height:62px;border:none;border-radius:22px;background:linear-gradient(180deg,var(--primary) 0%,var(--primary-strong) 100%);color:#fff;display:grid;place-items:center;box-shadow:0 18px 34px rgba(21,112,239,.28);z-index:44}.floating-create .material-symbols-rounded{font-size:28px}
.composer-overlay,.comments-overlay{position:fixed;inset:0;background:rgba(15,23,42,.40);display:none;align-items:flex-end;justify-content:center;padding:16px;z-index:60}.composer-overlay.is-open,.comments-overlay.is-open{display:flex}.composer-modal,.comments-sheet{width:min(100%,720px);max-height:min(92vh,920px);overflow:auto;padding:18px 18px 20px;border-radius:30px 30px 24px 24px}.sheet-grabber{width:58px;height:6px;border-radius:999px;background:#d7deea;margin:0 auto 16px}.modal-head{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px}.modal-title{margin:0;font-size:24px;font-weight:800;letter-spacing:-.04em}.comment-item{display:grid;grid-template-columns:52px minmax(0,1fr);gap:14px;padding:14px 0}.hr{height:1px;background:var(--line);margin:18px 0}.toast{position:fixed;left:50%;bottom:96px;transform:translateX(-50%);background:#0f172a;color:#fff;padding:12px 18px;border-radius:999px;box-shadow:var(--shadow-md);display:none;z-index:70}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.hide{display:none!important}.desktop-only{display:none!important}
@media (min-width:1024px){
  .desktop-nav{display:flex}
  body.has-app-nav .page{padding-left:calc(var(--desktop-rail) + 56px);padding-right:28px}
  .bottom-nav,.floating-create.mobile-only{display:none}
  .shell{width:min(100%,calc(var(--content-max) + 40px));}
  .page-grid{
    width: 711px;
    margin: 0 auto;
}
  .desktop-only{display:block!important}
  .floating-create{right:36px;bottom:36px}
}
@media (min-width:1100px){
  .auth-showcase{display:block}
  .auth-shell{grid-template-columns:minmax(0,1fr) 560px}
}
@media (max-width:1023px){
  .page{padding-bottom:120px}
  .right-column{display:none}
}
@media (max-width:1023px){
  .hero-card{padding:20px}
}
@media (max-width:767px){
  .page-title{font-size:40px}
  .page-subtitle,.auth-subtitle{font-size:16px}
  .auth-card{padding:26px 20px}
  .cover{height:170px;border-radius:28px}
  .profile-head{margin-top:-56px;padding:0 8px}
  .avatar-xl{width:98px;height:98px;border-radius:28px}
  .profile-stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
  .profile-stat{min-width:0}
  .composer-modal,.comments-sheet{padding:16px}
  .page-head{flex-direction:column}
  .post-actions,.profile-actions{justify-content:flex-start}
  .hero-card .page-head img{height:42px!important}
}

.composer-form {
    display: flex;
    flex-direction: column;
    gap: 22px;
}

.field {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.field-label {
    font-size: 15px;
    font-weight: 700;
    color: #0f172a;
    margin: 0;
}

.textarea {
    width: 100%;
    min-height: 170px;
    padding: 18px 20px;
    border: 1px solid #d7dfeb;
    border-radius: 24px;
    background: #ffffff;
    font-family: inherit;
    font-size: 17px;
    line-height: 1.6;
    color: #0f172a;
    resize: vertical;
    outline: none;
    transition: border-color .2s ease, box-shadow .2s ease, transform .2s ease;
    box-sizing: border-box;
}

.textarea::placeholder {
    color: #94a3b8;
}

.textarea:focus {
    border-color: #3b82f6;
    box-shadow: 0 0 0 4px rgba(59, 130, 246, 0.12);
}

.upload-card {
    border: 1px solid #d7dfeb;
    border-radius: 24px;
    background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
    padding: 14px;
}

.file-input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.upload-box {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 18px;
    border: 1px dashed #c7d4e8;
    border-radius: 20px;
    background: #f8fbff;
    cursor: pointer;
    transition: border-color .2s ease, background .2s ease, transform .2s ease;
}

.upload-box:hover {
    border-color: #3b82f6;
    background: #f3f8ff;
    transform: translateY(-1px);
}

.upload-box-icon {
    width: 52px;
    height: 52px;
    min-width: 52px;
    border-radius: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, #2f8cff 0%, #2563eb 100%);
    color: #ffffff;
    box-shadow: 0 12px 30px rgba(37, 99, 235, 0.18);
}

.upload-box-icon .material-symbols-rounded {
    font-size: 26px;
    line-height: 1;
}

.upload-box-content {
    flex: 1;
    min-width: 0;
}

.upload-box-title {
    font-size: 16px;
    font-weight: 700;
    color: #0f172a;
    margin-bottom: 4px;
}

.upload-box-text {
    font-size: 14px;
    line-height: 1.45;
    color: #64748b;
}

.upload-box-action {
    padding: 12px 18px;
    border-radius: 14px;
    background: #ffffff;
    border: 1px solid #d7dfeb;
    color: #0f172a;
    font-size: 14px;
    font-weight: 700;
    white-space: nowrap;
    transition: background .2s ease, border-color .2s ease;
}

.upload-box:hover .upload-box-action {
    border-color: #bfd3f5;
    background: #f9fbff;
}

.upload-meta {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-top: 12px;
    padding: 0 4px;
    font-size: 14px;
    color: #475569;
}

.upload-meta .material-symbols-rounded {
    font-size: 18px;
    color: #2563eb;
}

.upload-preview {
    margin-top: 14px;
    border-radius: 20px;
    overflow: hidden;
    border: 1px solid #d7dfeb;
    background: #eef4fb;
}

.upload-preview img {
    display: block;
    width: 100%;
    max-height: 320px;
    object-fit: cover;
}

.field-note {
    margin: 8px 4px 0;
    font-size: 14px;
    line-height: 1.5;
    color: #64748b;
}

@media (max-width: 768px) {
    .upload-box {
        flex-direction: column;
        align-items: flex-start;
    }

    .upload-box-action {
        width: 100%;
        text-align: center;
    }

    .textarea {
        min-height: 150px;
        font-size: 16px;
    }
}
/* 2026-04-08 product upgrade */
.desktop-nav{display:none !important}
@media (min-width:1024px){.desktop-nav{display:flex !important}.right-column{display:block}}
.right-column{display:none}
.post-title-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.premium-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;background:linear-gradient(135deg,#fef3c7 0%,#fde68a 100%);color:#7c2d12;border:1px solid rgba(245,158,11,.35);font-size:12px;font-weight:800;white-space:nowrap}
.premium-badge .material-symbols-rounded{font-size:16px}
.post-media{display:block;width:100%;border-radius:24px;border:1px solid var(--line);max-height:520px;object-fit:cover}
.post-menu-btn{border:none;background:transparent;color:#94a3b8;padding:10px;border-radius:14px;cursor:pointer;transition:.2s}.post-menu-btn:hover{background:#fff1f2;color:#dc2626}
.action-like{color:#475569}.action-like.is-active{color:#dc2626;border-color:#fecdd3;background:#fff1f2}.action-like .material-symbols-rounded{transition:transform .2s ease, color .2s ease}.action-like.is-active .material-symbols-rounded{font-variation-settings:'FILL' 1;transform:scale(1.08);color:#dc2626}.pulse-once .material-symbols-rounded{animation:likePulse .45s ease}
@keyframes likePulse{0%{transform:scale(.85)}55%{transform:scale(1.28)}100%{transform:scale(1.06)}}
.btn[disabled]{opacity:.8;cursor:not-allowed}.btn-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.5);border-top-color:#fff;border-radius:50%;display:inline-block;animation:spin .8s linear infinite}.btn-secondary .btn-spinner,.btn-ghost .btn-spinner{border-color:rgba(15,23,42,.18);border-top-color:#0f172a}.is-loading{pointer-events:none}
@keyframes spin{to{transform:rotate(360deg)}}
.filter-card,.settings-card{padding:22px;border-radius:28px;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-sm)}
.filter-pills{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px}.filter-pill{display:inline-flex;align-items:center;justify-content:center;padding:12px 16px;border-radius:999px;border:1px solid var(--line);background:#f8fafc;color:#334155;font-weight:700}.filter-pill.is-active{background:#e9f2ff;border-color:#bfdbfe;color:#1d4ed8}
.filter-list{display:grid;gap:10px;margin-top:16px}.filter-list a,.filter-list span{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;border-radius:18px;background:#f8fafc;color:#334155;border:1px solid var(--line)}
.filter-list small{color:#64748b}
.composer-modal,.comments-sheet{background:#fff;box-shadow:0 35px 70px rgba(15,23,42,.24)}
.settings-grid{display:grid;gap:20px}.settings-section-title{margin:0 0 10px;font-size:18px;font-weight:800}.settings-note{margin:0;color:var(--muted);line-height:1.65}.settings-actions{display:flex;gap:10px;flex-wrap:wrap}.field select.input{appearance:none;background-image:linear-gradient(45deg,transparent 50%,#64748b 50%),linear-gradient(135deg,#64748b 50%,transparent 50%);background-position:calc(100% - 22px) calc(50% - 3px),calc(100% - 16px) calc(50% - 3px);background-size:6px 6px,6px 6px;background-repeat:no-repeat}
.profile-top-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-top:12px}.logout-link{display:inline-flex;align-items:center;gap:8px;color:#475569}
.insight-row{display:flex;align-items:center;justify-content:space-between;gap:12px}
.feed-list{display:grid;gap:18px}
@media (max-width:767px){.filter-card,.settings-card{padding:18px}.premium-badge{font-size:11px;padding:5px 8px}}

/* ===== Search page upgrade ===== */
.search-subtitle{
    max-width: 56ch;
}

.search-hero-card{
    overflow: hidden;
}

.search-hero-grid{
    display:grid;
    gap:18px;
}

.search-form-wrap{
    display:grid;
    gap:12px;
    min-width:0;
}

.search-label{
    font-size:14px;
    font-weight:800;
    color:#334155;
}

.search-bar{
    display:grid;
    grid-template-columns:minmax(0,1fr) auto;
    gap:12px;
    align-items:stretch;
    width:100%;
}

.search-input-wrap{
    position:relative;
    min-width:0;
}

.search-input-wrap .material-symbols-rounded{
    position:absolute;
    left:18px;
    top:50%;
    transform:translateY(-50%);
    font-size:22px;
    color:#64748b;
    pointer-events:none;
}

.search-input{
    height:64px;
    padding-left:54px;
    padding-right:18px;
    border-radius:22px;
    font-size:17px;
}

.search-submit-btn{
    min-width:156px;
    height:64px;
    padding:0 24px;
    white-space:nowrap;
    flex-shrink:0;
}

.search-tabs-wrap{
    display:flex;
    align-items:center;
    justify-content:flex-start;
}

.search-segmented{
    display:inline-flex;
    align-items:center;
    gap:8px;
    padding:6px;
    border-radius:999px;
    background:#eef3f8;
    border:1px solid var(--line);
}

.search-segmented button{
    display:inline-flex;
    align-items:center;
    gap:8px;
    border:none;
    background:transparent;
    padding:12px 18px;
    border-radius:999px;
    font-weight:800;
    color:var(--muted);
}

.search-segmented button.is-active{
    background:#fff;
    color:var(--text);
    box-shadow:var(--shadow-sm);
}

.search-results-head{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:14px;
}

.search-results-title{
    margin:0;
    font-size:28px;
    line-height:1.1;
    font-weight:900;
    letter-spacing:-.04em;
}

.search-results-meta{
    margin-top:8px;
    color:var(--muted);
    font-size:14px;
    font-weight:600;
}

.search-results-grid{
    display:block;
}

.search-users-grid,
.search-posts-grid{
    display:grid;
    gap:18px;
}

.search-users-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
}

.search-user-card{
    position:relative;
    overflow:hidden;
    padding:0;
    border-radius:30px;
    min-height:100%;
}

.search-user-cover{
    position:relative;
    height:120px;
    background:linear-gradient(135deg,#dbeafe 0%,#eff6ff 45%,#eef2ff 100%);
    overflow:hidden;
}

.search-user-cover img{
    width:100%;
    height:100%;
    object-fit:cover;
    filter:blur(18px) saturate(1.15);
    transform:scale(1.18);
    opacity:.72;
}

.search-user-cover--fallback::before,
.search-user-cover--fallback::after{
    content:"";
    position:absolute;
    border-radius:999px;
    background:rgba(59,130,246,.14);
}

.search-user-cover--fallback::before{
    width:220px;
    height:220px;
    top:-120px;
    right:-40px;
}

.search-user-cover--fallback::after{
    width:180px;
    height:180px;
    bottom:-100px;
    left:-40px;
}

.search-user-card-inner{
    padding:0 22px 22px;
}

.search-user-top{
    display:flex;
    gap:16px;
    align-items:flex-end;
    margin-top:-34px;
    position:relative;
    z-index:2;
}

.search-user-avatar-wrap .avatar{
    width:84px;
    height:84px;
    border-radius:26px;
    border:4px solid rgba(255,255,255,.96);
    box-shadow:var(--shadow-md);
    font-size:26px;
}

.search-user-main{
    min-width:0;
    flex:1;
    padding-bottom:6px;
}

.search-user-name-row{
    display:flex;
    align-items:center;
    gap:8px;
    flex-wrap:wrap;
}

.search-user-name{
    color:var(--text);
    font-size:22px;
    line-height:1.15;
    font-weight:900;
    letter-spacing:-.03em;
}

.search-user-name:hover{
    color:var(--primary-strong);
}

.search-user-username{
    margin-top:6px;
    color:#64748b;
    font-size:15px;
    line-height:1.4;
    word-break:break-word;
}

.search-user-bio{
    margin-top:18px;
    color:#334155;
    font-size:15px;
    line-height:1.7;
    min-height:76px;
    word-break:break-word;
}

.search-user-actions{
    display:flex;
    gap:10px;
    flex-wrap:wrap;
    margin-top:18px;
}

.search-post-item .post-card{
    border-radius:30px;
    overflow:hidden;
}

.search-empty-state,
.search-loading-state{
    display:grid;
    place-items:center;
    gap:10px;
    min-height:180px;
    text-align:center;
}

.search-empty-icon{
    width:64px;
    height:64px;
    border-radius:20px;
    display:grid;
    place-items:center;
    background:#eff6ff;
    color:#2563eb;
    margin:0 auto;
}

.search-empty-icon .material-symbols-rounded{
    font-size:30px;
}

.search-empty-title{
    font-size:16px;
    font-weight:700;
    color:#475569;
}

.search-inline-spinner{
    width:18px;
    height:18px;
    border:2px solid rgba(15,23,42,.18);
    border-top-color:#0f172a;
    border-radius:50%;
    display:inline-block;
    animation:spin .8s linear infinite;
}

@media (max-width: 900px){
    .search-users-grid{
        grid-template-columns:1fr;
    }
}

@media (max-width: 767px){
    .search-bar{
        grid-template-columns:1fr;
    }

    .search-submit-btn{
        width:100%;
        min-width:0;
    }

    .search-segmented{
        width:100%;
        justify-content:space-between;
    }

    .search-segmented button{
        justify-content:center;
        flex:1 1 0;
    }

    .search-user-card-inner{
        padding:0 18px 18px;
    }

    .search-user-top{
        gap:12px;
        margin-top:-28px;
    }

    .search-user-avatar-wrap .avatar{
        width:72px;
        height:72px;
        border-radius:22px;
    }

    .search-user-name{
        font-size:20px;
    }

    .search-user-bio{
        min-height:auto;
    }

    .search-results-title{
        font-size:24px;
    }
}
img.icon_telegram_premium {
    width: 18px;
}

/* 2026-04-08 notifications + nav unread badge */
.nav-link-with-badge{justify-content:flex-start}
.nav-unread-badge{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 7px;border-radius:999px;background:linear-gradient(180deg,#ef4444 0%,#dc2626 100%);color:#fff;font-size:11px;font-weight:800;line-height:1;box-shadow:0 10px 20px rgba(220,38,38,.18)}
.nav-mobile-label{display:inline-flex;align-items:center;gap:6px;justify-content:center;flex-wrap:wrap}
.notice-card-link{display:grid;grid-template-columns:64px minmax(0,1fr) 24px;gap:16px;align-items:center;color:var(--text);text-decoration:none;transition:transform .16s ease, box-shadow .18s ease,border-color .18s ease}
.notice-card-link:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:#d6e4f5;color:var(--text)}
.notice-card-avatar-wrap{position:relative;width:64px;height:64px}
.notice-card-avatar-wrap .avatar{width:64px;height:64px;border-radius:22px}
.notice-icon-badge{position:absolute;right:-4px;bottom:-4px;width:28px;height:28px;border-radius:12px;display:grid;place-items:center;background:linear-gradient(180deg,var(--primary) 0%,var(--primary-strong) 100%);color:#fff;border:3px solid #fff;box-shadow:0 10px 18px rgba(21,112,239,.24)}
.notice-icon-badge .material-symbols-rounded{font-size:16px}
.notice-card-main{min-width:0}
.notice-card-text{margin-top:6px;font-size:15px;line-height:1.65;color:#334155;word-break:break-word}
.notice-card-arrow{display:flex;align-items:center;justify-content:flex-end;color:#94a3b8}
@media (max-width:767px){.notice-card-link{grid-template-columns:56px minmax(0,1fr) 20px;gap:12px}.notice-card-avatar-wrap{width:56px;height:56px}.notice-card-avatar-wrap .avatar{width:56px;height:56px;border-radius:18px}.notice-icon-badge{width:24px;height:24px;border-radius:10px}}
