@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@400;600;700&family=Inter:wght@400;500;600&display=swap');
:root{--v-gold:#C9A84C;--v-gold-light:#E8D08A;--v-gold-dark:#9A7A2E;--v-navy:#1A2744;--v-navy-mid:#243360;--v-navy-light:#3A5080;--v-cream:#F8F5EE;--v-cream-dark:#EDE9DE;--v-text:#1A1A2E;--v-text-muted:#6B7280;--v-border:#D4C99A;--v-success:#2D6A4F;--v-danger:#8B1A1A;--v-radius:8px;--v-shadow:0 4px 20px rgba(26,39,68,.12);--v-shadow-sm:0 2px 8px rgba(26,39,68,.08)}
.vestina-wrap{font-family:'Inter',sans-serif;color:var(--v-text);max-width:960px;margin:0 auto;padding:0 16px 60px}
.vestina-join-hero,.vestina-page-hero{text-align:center;padding:48px 24px 36px}
.vestina-crest{font-size:56px;margin-bottom:12px;filter:drop-shadow(0 2px 8px rgba(201,168,76,.3))}
.vestina-join-hero h1,.vestina-page-hero h1{font-family:'Cormorant Garamond',serif;font-size:2.4rem;font-weight:700;color:var(--v-navy);margin:0 0 10px;letter-spacing:.02em}
.vestina-join-hero p,.vestina-page-hero p{color:var(--v-text-muted);font-size:1rem;max-width:520px;margin:0 auto;line-height:1.6}
.vestina-form-card{background:#fff;border:1px solid var(--v-border);border-radius:var(--v-radius);padding:32px;max-width:560px;margin:0 auto;box-shadow:var(--v-shadow)}
.vestina-field{margin-bottom:20px}
.vestina-field label{display:block;font-size:.85rem;font-weight:600;color:var(--v-navy);margin-bottom:6px;letter-spacing:.03em;text-transform:uppercase}
.vestina-field .req{color:var(--v-gold-dark)}
.vestina-field input,.vestina-field textarea,.vestina-field select{width:100%;padding:10px 14px;border:1.5px solid var(--v-border);border-radius:var(--v-radius);font-family:'Inter',sans-serif;font-size:.95rem;color:var(--v-text);background:var(--v-cream);box-sizing:border-box;transition:border-color .2s,box-shadow .2s}
.vestina-field input:focus,.vestina-field textarea:focus{outline:none;border-color:var(--v-gold);box-shadow:0 0 0 3px rgba(201,168,76,.15);background:#fff}
.vestina-field small{display:block;margin-top:4px;color:var(--v-text-muted);font-size:.8rem}
.vestina-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.vestina-checkbox label{display:flex;gap:8px;font-size:.9rem;text-transform:none;letter-spacing:0;font-weight:400;color:var(--v-text-muted);cursor:pointer;line-height:1.5}
.vestina-checkbox input[type=checkbox]{width:16px;height:16px;flex-shrink:0;margin-top:2px;accent-color:var(--v-gold-dark)}
.vestina-field-readonly .vestina-readonly-value{background:var(--v-cream-dark);border:1.5px solid var(--v-border);border-radius:var(--v-radius);padding:10px 14px;font-size:.95rem;color:var(--v-text-muted)}
.vestina-btn{padding:11px 24px;border:none;border-radius:var(--v-radius);font-family:'Inter',sans-serif;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s;text-decoration:none;display:inline-block}
.vestina-btn-primary{background:linear-gradient(135deg,var(--v-navy) 0%,var(--v-navy-mid) 100%);color:var(--v-gold-light);width:100%;padding:13px;font-size:1rem;letter-spacing:.05em;text-transform:uppercase}
.vestina-btn-primary:hover{background:linear-gradient(135deg,var(--v-navy-mid) 0%,var(--v-navy-light) 100%);transform:translateY(-1px);box-shadow:var(--v-shadow);color:var(--v-gold-light)}
.vestina-btn-ghost{background:transparent;color:var(--v-text-muted);border:1.5px solid var(--v-border);padding:8px 16px;font-size:.85rem}
.vestina-btn-ghost:hover{border-color:var(--v-gold);color:var(--v-navy)}
.vestina-login-link{text-align:center;margin-top:20px;color:var(--v-text-muted);font-size:.9rem}
.vestina-login-link a{color:var(--v-gold-dark);font-weight:600}
.vestina-alert{padding:12px 16px;border-radius:var(--v-radius);margin-bottom:16px;font-size:.9rem}
.vestina-alert.success{background:#D1FAE5;color:var(--v-success);border-left:4px solid var(--v-success)}
.vestina-alert.error{background:#FEE2E2;color:var(--v-danger);border-left:4px solid var(--v-danger)}
.vestina-notice{background:var(--v-cream);border:1px solid var(--v-border);border-radius:var(--v-radius);padding:16px;text-align:center;color:var(--v-text-muted)}
.vestina-notice a{color:var(--v-gold-dark)}
.vestina-cabinet{background:#fff;border:1px solid var(--v-border);border-radius:var(--v-radius);overflow:hidden;box-shadow:var(--v-shadow)}
.vestina-cabinet-header{background:linear-gradient(135deg,var(--v-navy) 0%,var(--v-navy-mid) 100%);padding:28px 32px;display:flex;align-items:center;gap:20px}
.vestina-avatar-wrap{position:relative;cursor:pointer}
.vestina-avatar{width:72px;height:72px;background:var(--v-gold);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Cormorant Garamond',serif;font-weight:700;font-size:1.6rem;color:var(--v-navy);flex-shrink:0;border:3px solid rgba(255,255,255,.2)}
.vestina-avatar-img{border-radius:50%;object-fit:cover;border:2px solid rgba(255,255,255,.15);display:block;flex-shrink:0}
.vestina-avatar-edit{position:absolute;bottom:0;right:0;background:var(--v-gold);color:var(--v-navy);width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;cursor:pointer;border:2px solid var(--v-navy-mid);transition:transform .2s}
.vestina-avatar-edit:hover{transform:scale(1.15)}
.vestina-cabinet-info{flex:1}
.vestina-cabinet-info h2{font-family:'Cormorant Garamond',serif;color:#fff;font-size:1.6rem;margin:0 0 4px}
.vestina-login-label{color:rgba(255,255,255,.5);font-size:.85rem;margin-bottom:6px;font-family:monospace}
.vestina-citizen-id{color:var(--v-gold-light);font-size:.85rem;margin-top:6px;font-family:monospace;letter-spacing:.04em}
.vestina-role-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:.8rem;font-weight:600;letter-spacing:.04em}
.vestina-role-sm{font-size:.72rem;padding:2px 8px}
.vestina-role-applicant{background:rgba(245,158,11,.2);color:#B45309}
.vestina-role-citizen{background:rgba(201,168,76,.2);color:var(--v-gold-dark)}
.vestina-role-senator{background:rgba(59,130,246,.2);color:#1E40AF}
.vestina-role-minister{background:rgba(139,92,246,.2);color:#6D28D9}
.vestina-role-president{background:rgba(201,168,76,.35);color:#7A5010;border:1px solid var(--v-gold)}
.vestina-tabs{display:flex;border-bottom:1px solid var(--v-cream-dark);background:var(--v-cream);flex-wrap:wrap}
.vestina-tab{padding:14px 20px;background:none;border:none;cursor:pointer;font-family:'Inter',sans-serif;font-size:.9rem;color:var(--v-text-muted);font-weight:500;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .2s}
.vestina-tab.active{color:var(--v-navy);border-bottom-color:var(--v-gold);font-weight:600}
.vestina-tab:hover{color:var(--v-navy)}
.vestina-badge{background:var(--v-danger);color:#fff;border-radius:10px;padding:1px 6px;font-size:.7rem;margin-left:4px}
.vestina-tab-content{display:none;padding:28px 32px}
.vestina-tab-content.active{display:block}
.vestina-idcard-section{display:flex;flex-direction:column;gap:24px;align-items:center}
.vestina-idcard-wrap{width:100%;max-width:600px;border-radius:12px;overflow:hidden;box-shadow:0 8px 32px rgba(26,39,68,.18);border:2px solid var(--v-gold)}
.vestina-idcard-img{width:100%;display:block}
.vestina-idcard-placeholder{width:100%;max-width:600px;background:var(--v-cream);border:2px dashed var(--v-border);border-radius:12px;padding:48px 32px;text-align:center;color:var(--v-text-muted)}
.vestina-idcard-placeholder-icon{font-size:48px;margin-bottom:12px}
.vestina-vst-card{width:100%;max-width:600px;background:linear-gradient(135deg,var(--v-navy) 0%,var(--v-navy-mid) 100%);border-radius:12px;padding:24px 28px;border:1px solid var(--v-gold-dark)}
.vestina-vst-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;color:var(--v-gold-light);opacity:.7;margin-bottom:8px}
.vestina-vst-number{font-family:'Courier New',monospace;font-size:2rem;font-weight:700;color:var(--v-gold-light);letter-spacing:.12em;margin-bottom:16px}
.vestina-vst-meta{display:flex;gap:20px;flex-wrap:wrap}
.vestina-vst-meta span{font-size:.82rem;color:rgba(255,255,255,.6)}
.vestina-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px}
.vestina-stat-card{background:var(--v-cream);border:1px solid var(--v-border);border-radius:var(--v-radius);padding:20px;text-align:center}
.vestina-stat-num{font-family:'Cormorant Garamond',serif;font-size:2.2rem;font-weight:700;color:var(--v-navy)}
.vestina-stat-label{font-size:.8rem;color:var(--v-text-muted);text-transform:uppercase;letter-spacing:.06em;margin-top:4px}
.vestina-bio-preview{background:var(--v-cream);border-radius:var(--v-radius);padding:16px;margin-bottom:20px;border-left:3px solid var(--v-gold)}
.vestina-bio-preview h4{font-size:.8rem;text-transform:uppercase;letter-spacing:.06em;color:var(--v-text-muted);margin:0 0 8px}
.vestina-quick-links{display:flex;gap:12px;flex-wrap:wrap}
.vestina-quick-link{background:var(--v-cream);border:1px solid var(--v-border);border-radius:var(--v-radius);padding:10px 18px;font-size:.9rem;color:var(--v-navy);text-decoration:none;font-weight:500;transition:all .2s}
.vestina-quick-link:hover{background:var(--v-navy);color:var(--v-gold-light);border-color:var(--v-navy)}
.vestina-pending-card{padding:48px 32px;text-align:center}
.vestina-pending-icon{font-size:48px;margin-bottom:16px}
.vestina-pending-card h3{font-family:'Cormorant Garamond',serif;font-size:1.6rem;color:var(--v-navy);margin:0 0 10px}
.vestina-pending-card p{color:var(--v-text-muted);line-height:1.6}
.vestina-messages-wrap{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.vestina-messages-inbox h4,.vestina-compose h4{font-family:'Cormorant Garamond',serif;font-size:1.2rem;color:var(--v-navy);margin:0 0 12px}
.vestina-messages-list{border:1px solid var(--v-border);border-radius:var(--v-radius);overflow:hidden;min-height:120px}
.vestina-message-item{padding:12px 16px;border-bottom:1px solid var(--v-cream-dark)}
.vestina-message-item.unread{background:rgba(255,255,255,.03)}
.vestina-message-sender{font-weight:600;font-size:.9rem;color:var(--v-navy)}
.vestina-message-subject{font-size:.85rem;color:var(--v-text-muted)}
.vestina-message-date{font-size:.75rem;color:var(--v-text-muted);float:right}
.vestina-loading{padding:24px;text-align:center;color:var(--v-text-muted)}
.vestina-members-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px}
.vestina-member-card{background:#fff;border:1px solid var(--v-border);border-radius:var(--v-radius);padding:20px 16px;text-align:center;transition:box-shadow .2s}
.vestina-member-card:hover{box-shadow:var(--v-shadow)}
.vestina-member-name{font-weight:600;color:var(--v-navy);margin-bottom:6px}
.vestina-member-id{font-size:.75rem;color:var(--v-text-muted);font-family:monospace;margin-top:6px}
.vestina-forum-categories{display:flex;flex-direction:column;gap:12px}
.vestina-forum-cat{background:#fff;border:1px solid var(--v-border);border-radius:var(--v-radius);padding:20px 24px;display:flex;align-items:center;gap:20px;text-decoration:none;transition:all .2s}
.vestina-forum-cat:hover{border-color:var(--v-gold);box-shadow:var(--v-shadow-sm);transform:translateX(4px)}
.vestina-cat-icon{font-size:2rem;flex-shrink:0}
.vestina-cat-info{flex:1}
.vestina-cat-name{font-weight:600;font-size:1.05rem;color:var(--v-navy);margin-bottom:4px}
.vestina-cat-desc{font-size:.85rem;color:var(--v-text-muted)}
.vestina-cat-stats{text-align:right;flex-shrink:0}
.vestina-cat-count{font-size:0.72rem;color:var(--v-text-muted);background:rgba(255,255,255,.1);border-radius:8px;padding:1px 6px;margin-left:4px}
.vestina-cat-label{font-size:.75rem;color:var(--v-text-muted);text-transform:uppercase;letter-spacing:.06em}
.vestina-cat-last{font-size:.75rem;color:var(--v-text-muted);margin-top:4px;max-width:160px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.vestina-breadcrumb{font-size:.85rem;color:var(--v-text-muted);margin-bottom:20px;padding:12px 0;border-bottom:1px solid var(--v-cream-dark)}
.vestina-breadcrumb a{color:var(--v-gold-dark);text-decoration:none}
.vestina-new-topic-wrap{display:flex;justify-content:flex-end;margin-bottom:16px}
.vestina-new-topic-form{background:rgba(255,255,255,.04);border:1px solid var(--v-border);border-radius:var(--v-radius);padding:20px;margin-bottom:20px}
.vestina-topics-list{display:flex;flex-direction:column;gap:8px}
.vestina-topic-row{background:rgba(255,255,255,.03);border:1px solid var(--v-border);border-radius:var(--v-radius);padding:12px 16px;display:flex;align-items:center;gap:12px;text-decoration:none;transition:all .2s}
.vestina-topic-row:hover{border-color:var(--v-gold);background:rgba(212,175,55,.06)}
.vestina-topic-icon{font-size:1.2rem;flex-shrink:0}
.vestina-topic-info{flex:1}
.vestina-topic-title{font-weight:600;color:var(--v-text);margin-bottom:3px;font-size:0.95rem;line-height:1.35}
.vestina-topic-meta{font-size:.8rem;color:var(--v-text-muted)}
.vestina-topic-stats{text-align:right;font-size:.8rem;color:var(--v-text-muted);flex-shrink:0}
.vestina-topic-full{display:flex;flex-direction:column}
.vestina-topic-heading{font-size:1.3rem;font-weight:600;color:var(--v-text);margin:0 0 8px}
.vestina-post{display:grid;grid-template-columns:120px 1fr;border:1px solid var(--v-border);margin-bottom:-1px;overflow:hidden}
.vestina-post:first-child{border-radius:var(--v-radius) var(--v-radius) 0 0}
.vestina-post:last-of-type{border-radius:0 0 var(--v-radius) var(--v-radius);margin-bottom:24px}
.vestina-post-main .vestina-post-author{background:linear-gradient(180deg,var(--v-navy) 0%,var(--v-navy-mid) 100%)}
.vestina-post-reply .vestina-post-author{background:rgba(255,255,255,.03)}
.vestina-post-author{padding:20px 14px;display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center;border-right:1px solid var(--v-border)}
.vestina-post-main .vestina-post-author-name{color:var(--v-gold-light)}
.vestina-post-reply .vestina-post-author-name{color:var(--v-navy)}
.vestina-post-author-name{font-weight:600;font-size:.85rem}
.vestina-post-body{padding:20px 24px;background:#fff}
.vestina-post-date{font-size:.78rem;color:var(--v-text-muted);margin-bottom:12px}
.vestina-post-content{line-height:1.7}
.vestina-reply-form{background:var(--v-cream);border:1px solid var(--v-border);border-radius:var(--v-radius);padding:24px;margin-top:24px}
.vestina-reply-form h3{font-family:'Cormorant Garamond',serif;font-size:1.3rem;color:var(--v-navy);margin:0 0 16px}
.vestina-locked-notice{padding:14px 20px;background:var(--v-cream);border:1px solid var(--v-border);border-radius:var(--v-radius);margin-top:24px;color:var(--v-text-muted);text-align:center}
.vestina-empty{padding:32px;text-align:center;color:var(--v-text-muted);grid-column:1/-1}
.vestina-form-actions{display:flex;gap:12px}
@media(max-width:640px){.vestina-form-grid{grid-template-columns:1fr}.vestina-stats-grid{grid-template-columns:repeat(3,1fr)}.vestina-messages-wrap{grid-template-columns:1fr}.vestina-cabinet-header{flex-wrap:wrap}.vestina-post{grid-template-columns:70px 1fr}.vestina-tab{padding:10px 12px;font-size:.8rem}.vestina-vst-number{font-size:1.4rem}}

/* ── ВЫБОРЫ ──────────────────────────────────────────────────────────────────── */
.vestina-elections-list{display:flex;flex-direction:column;gap:16px}
.vestina-election-card{background:#fff;border:1px solid var(--v-border);border-radius:var(--v-radius);padding:24px;box-shadow:var(--v-shadow-sm)}
.vestina-election-card-header{display:flex;align-items:center;gap:12px;margin-bottom:10px;flex-wrap:wrap}
.vestina-election-title{font-family:'Cormorant Garamond',serif;font-size:1.3rem;font-weight:700;color:var(--v-navy)}
.vestina-election-desc{color:var(--v-text-muted);font-size:.9rem;line-height:1.6;margin-bottom:12px}
.vestina-election-meta{display:flex;gap:20px;font-size:.85rem;color:var(--v-text-muted);margin-bottom:16px;flex-wrap:wrap}
.vestina-election-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.v-badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:.78rem;font-weight:600}
.v-badge-active{background:#D1FAE5;color:#065F46}
.v-badge-pending{background:#FEF3C7;color:#92400E}
.v-badge-ended{background:#F3F4F6;color:#6B7280}
.v-voted-label{color:var(--v-success);font-weight:600;font-size:.9rem}

/* Голосование */
.vestina-vote-wrap{max-width:800px;margin:0 auto}
.vestina-vote-header{text-align:center;margin-bottom:32px}
.vestina-vote-header h2{font-family:'Cormorant Garamond',serif;font-size:1.8rem;color:var(--v-navy);margin:0 0 8px}
.vestina-vote-deadline{display:inline-block;background:var(--v-cream);border:1px solid var(--v-border);border-radius:20px;padding:4px 16px;font-size:.85rem;color:var(--v-text-muted);margin-top:8px}
.vestina-candidates-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:24px}
.vestina-candidate-card{background:#fff;border:2px solid var(--v-border);border-radius:var(--v-radius);padding:20px;text-align:center;cursor:pointer;transition:all .2s;position:relative}
.vestina-candidate-card:hover{border-color:var(--v-gold);box-shadow:var(--v-shadow)}
.vestina-candidate-card.selected{border-color:var(--v-navy);background:rgba(255,255,255,.03)}
.vestina-candidate-check{position:absolute;top:10px;right:10px;width:22px;height:22px;border:2px solid var(--v-border);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.7rem;color:transparent;transition:all .2s}
.vestina-candidate-card.selected .vestina-candidate-check{background:var(--v-navy);border-color:var(--v-navy);color:#fff}
.vestina-candidate-avatar{width:64px;height:64px;border-radius:50%;object-fit:cover;margin:0 auto 12px;display:block}
.vestina-candidate-name{font-weight:700;color:var(--v-navy);font-size:1rem;margin-bottom:4px}
.vestina-candidate-id{font-size:.75rem;color:var(--v-text-muted);font-family:monospace;margin-bottom:8px}
.vestina-candidate-platform{font-size:.82rem;color:var(--v-text-muted);line-height:1.5;text-align:left}

/* Результаты выборов */
.vestina-results-wrap{max-width:700px;margin:0 auto}
.vestina-results-wrap h2{font-family:'Cormorant Garamond',serif;font-size:1.8rem;color:var(--v-navy);margin:0 0 8px}
.vestina-results-meta{color:var(--v-text-muted);font-size:.9rem;margin-bottom:24px}
.vestina-results-list{display:flex;flex-direction:column;gap:12px}
.vestina-result-row{display:grid;grid-template-columns:40px 1fr auto auto auto;align-items:center;gap:12px;background:#fff;border:1px solid var(--v-border);border-radius:var(--v-radius);padding:14px 18px}
.vestina-result-winner{border-color:var(--v-gold);background:linear-gradient(135deg,#FFFDF0 0%,#FFF8E0 100%)}
.vestina-result-place{font-size:1.3rem;text-align:center}
.vestina-result-name{font-weight:600;color:var(--v-navy)}
.vestina-result-bar-wrap{width:120px;background:var(--v-cream-dark);border-radius:10px;height:8px;overflow:hidden}
.vestina-result-bar{height:8px;background:var(--v-navy);border-radius:10px;transition:width .8s}
.vestina-result-pct{font-weight:700;color:var(--v-navy);min-width:45px;text-align:right}
.vestina-result-votes{font-size:.82rem;color:var(--v-text-muted);min-width:60px;text-align:right}

/* ── ГРАЖДАНСКОЕ УЧАСТИЕ ────────────────────────────────────────────────────── */
.vestina-civic-list{display:flex;flex-direction:column;gap:16px}
.vestina-civic-card{background:#fff;border:1px solid var(--v-border);border-radius:var(--v-radius);padding:24px;box-shadow:var(--v-shadow-sm)}
.vestina-civic-card-top{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.vestina-civic-type{font-size:.8rem;font-weight:600;color:var(--v-gold-dark);text-transform:uppercase;letter-spacing:.05em}
.vestina-civic-title{font-family:'Cormorant Garamond',serif;font-size:1.3rem;color:var(--v-navy);margin:0 0 10px}
.vestina-civic-title a{color:inherit;text-decoration:none}
.vestina-civic-title a:hover{color:var(--v-gold-dark)}
.vestina-civic-excerpt{color:var(--v-text-muted);font-size:.9rem;line-height:1.6;margin-bottom:14px}
.vestina-civic-bar-wrap{margin-bottom:10px}
.vestina-civic-bar{height:10px;background:var(--v-cream-dark);border-radius:10px;overflow:hidden;display:flex;margin-bottom:6px}
.vestina-civic-bar-for{background:#22C55E;transition:width .6s}
.vestina-civic-bar-against{background:#EF4444;transition:width .6s}
.vestina-civic-votes-info{display:flex;gap:16px;font-size:.85rem;flex-wrap:wrap}
.v-for{color:#16A34A;font-weight:600}
.v-against{color:#DC2626;font-weight:600}
.vestina-civic-footer{display:flex;align-items:center;justify-content:space-between;margin-top:14px;padding-top:14px;border-top:1px solid var(--v-cream-dark)}
.vestina-civic-date{font-size:.8rem;color:var(--v-text-muted)}

/* Детальная страница инициативы */
.vestina-civic-detail{max-width:800px;margin:0 auto}
.vestina-civic-detail-header{margin-bottom:24px}
.vestina-civic-detail-header h2{font-family:'Cormorant Garamond',serif;font-size:2rem;color:var(--v-navy);margin:8px 0}
.vestina-civic-dates{font-size:.85rem;color:var(--v-text-muted)}
.vestina-civic-body{background:var(--v-cream);border-radius:var(--v-radius);padding:24px;margin-bottom:20px;line-height:1.8;border-left:4px solid var(--v-gold)}
.vestina-civic-doc{margin-bottom:20px}
.vestina-civic-vote-block{background:#fff;border:1px solid var(--v-border);border-radius:var(--v-radius);padding:24px;margin-bottom:24px;text-align:center}
.vestina-civic-vote-title{font-family:'Cormorant Garamond',serif;font-size:1.2rem;color:var(--v-navy);margin-bottom:14px;font-weight:700}
.vestina-voted-notice{background:#D1FAE5;color:#065F46;padding:12px 20px;border-radius:var(--v-radius);font-weight:600}
.vestina-btn-for{background:#16A34A;color:#fff;border:none;padding:12px 28px;border-radius:var(--v-radius);font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}
.vestina-btn-for:hover{background:#15803D;transform:translateY(-1px)}
.vestina-btn-against{background:#DC2626;color:#fff;border:none;padding:12px 28px;border-radius:var(--v-radius);font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}
.vestina-btn-against:hover{background:#B91C1C;transform:translateY(-1px)}

/* Комментарии */
.vestina-civic-comments h3{font-family:'Cormorant Garamond',serif;font-size:1.3rem;color:var(--v-navy);margin:0 0 16px}
.vestina-comments-list{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}
.vestina-comment{background:#fff;border:1px solid var(--v-border);border-radius:var(--v-radius);padding:16px}
.vestina-comment-author{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.vestina-comment-name{font-weight:600;color:var(--v-navy);font-size:.9rem}
.vestina-comment-date{font-size:.75rem;color:var(--v-text-muted)}
.vestina-comment-text{line-height:1.6;color:var(--v-text)}
.vestina-comment-form{background:var(--v-cream);border-radius:var(--v-radius);padding:20px}

/* ── ИСТОРИЯ ─────────────────────────────────────────────────────────────────── */
.vestina-history-wrap{display:flex;flex-direction:column;gap:8px}
.vestina-history-item{display:flex;align-items:flex-start;gap:14px;background:var(--v-cream);border:1px solid var(--v-border);border-radius:var(--v-radius);padding:14px 16px}
.vestina-history-icon{font-size:1.4rem;flex-shrink:0;margin-top:2px}
.vestina-history-title{font-weight:600;color:var(--v-navy);font-size:.9rem;margin-bottom:3px}
.vestina-history-date{font-size:.75rem;color:var(--v-text-muted)}
.vestina-history-empty{padding:32px;text-align:center;color:var(--v-text-muted)}

/* ── ИС DELICT — БРЕНДИНГ ────────────────────────────────────────────────────── */
.vestina-system-label {
    display: inline-block;
    background: var(--v-navy);
    color: var(--v-gold-light);
    font-family: 'Inter', sans-serif;
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    padding: 4px 14px;
    border-radius: 20px;
    border: 1px solid var(--v-gold-dark);
    margin-bottom: 12px;
}

/* ── АРХИВ ВЫБОРОВ ───────────────────────────────────────────────────────────── */
.vestina-archive-header { margin-bottom: 24px; }
.vestina-archive-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: 2rem;
    color: var(--v-navy);
    margin: 0 0 8px;
}
.vestina-archive-subtitle {
    color: var(--v-text-muted);
    font-size: 0.95rem;
    margin: 0 0 24px;
}
.vestina-archive-list { display: flex; flex-direction: column; gap: 12px; }
.vestina-archive-card {
    background: #fff;
    border: 1px solid var(--v-border);
    border-radius: var(--v-radius);
    padding: 20px 24px;
    display: grid;
    grid-template-columns: 90px 1fr auto;
    align-items: center;
    gap: 20px;
    transition: box-shadow 0.2s;
}
.vestina-archive-card:hover { box-shadow: var(--v-shadow-sm); }
.vestina-archive-card-left { text-align: center; }
.vestina-archive-year {
    font-family: 'Cormorant Garamond', serif;
    font-size: 2rem;
    font-weight: 700;
    color: var(--v-navy);
    line-height: 1;
}
.vestina-archive-dates {
    font-size: 0.72rem;
    color: var(--v-text-muted);
    margin-top: 4px;
}
.vestina-archive-election-title {
    font-weight: 700;
    color: var(--v-navy);
    font-size: 1.05rem;
    margin-bottom: 6px;
}
.vestina-archive-winner {
    font-size: 0.9rem;
    color: var(--v-text);
    margin-bottom: 4px;
}
.vestina-archive-winner strong { color: var(--v-gold-dark); }
.vestina-archive-turnout {
    font-size: 0.82rem;
    color: var(--v-text-muted);
}

@media (max-width: 640px) {
    .vestina-archive-card { grid-template-columns: 1fr; gap: 12px; }
    .vestina-archive-card-left { text-align: left; display: flex; align-items: center; gap: 12px; }
}

/* ── ЧАТ ─────────────────────────────────────────────────────────────────────── */
.vestina-chat-layout{display:grid;grid-template-columns:260px 1fr;gap:0;border:1px solid var(--v-border);border-radius:var(--v-radius);overflow:hidden;height:520px;min-height:400px}
.vestina-chat-sidebar{border-right:1px solid var(--v-border);display:flex;flex-direction:column;background:rgba(255,255,255,.03)}
.vestina-chat-sidebar-header{padding:12px 14px;border-bottom:1px solid var(--v-border);display:flex;align-items:center;justify-content:space-between;background:transparent}
.vestina-chat-sidebar-header h4{font-size:1rem;color:var(--v-text);margin:0}
.vestina-chat-threads{flex:1;overflow-y:auto}
.vestina-chat-thread{padding:10px 12px;cursor:pointer;border-bottom:1px solid var(--v-border);display:flex;align-items:center;gap:10px;transition:background .15s}
.vestina-chat-thread:hover{background:rgba(212,175,55,.07)}
.vestina-chat-thread.active{background:rgba(212,175,55,.1);border-left:3px solid var(--v-gold)}
.vestina-chat-thread.unread .vestina-chat-thread-name{font-weight:700}
.vestina-chat-thread-info{flex:1;min-width:0;overflow:hidden}
.vestina-chat-thread-name{font-size:0.88rem;font-weight:600;color:var(--v-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.vestina-chat-thread-last{font-size:0.78rem;color:var(--v-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.vestina-chat-empty{padding:20px;text-align:center;color:var(--v-text-muted);font-size:0.85rem}
.vestina-chat-window{display:flex;flex-direction:column;background:transparent;height:100%;overflow:hidden}
.vestina-chat-placeholder{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--v-text-muted);font-size:0.9rem}
.vestina-chat-header{padding:12px 16px;border-bottom:1px solid var(--v-border);background:transparent}
.vestina-chat-header-name{font-weight:700;color:var(--v-navy);font-size:0.95rem}
.vestina-chat-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:8px;background:rgba(0,0,0,.08);min-height:0}
.vestina-chat-msg{display:flex;flex-direction:column;max-width:75%}
.vestina-chat-msg.mine{align-self:flex-end;align-items:flex-end}
.vestina-chat-msg.theirs{align-self:flex-start;align-items:flex-start}
.vestina-chat-bubble{padding:9px 13px;border-radius:16px;font-size:0.9rem;line-height:1.5;word-break:break-word}
.vestina-chat-msg.mine .vestina-chat-bubble{background:var(--v-gold);color:var(--v-navy);border-bottom-right-radius:4px}
.vestina-chat-msg.theirs .vestina-chat-bubble{background:rgba(255,255,255,.09);border:1px solid var(--v-border);color:var(--v-text);border-bottom-left-radius:4px}
.vestina-chat-msg-time{font-size:0.7rem;color:var(--v-text-muted);margin-top:2px;padding:0 4px}
.vestina-chat-input-wrap{padding:12px;border-top:1px solid var(--v-border);display:flex;gap:8px;align-items:flex-end;background:rgba(255,255,255,.03)}
.vestina-chat-input-wrap textarea{flex:1;padding:8px 12px;border:1.5px solid var(--v-border);border-radius:var(--v-radius);font-family:'Inter',sans-serif;font-size:0.9rem;resize:none;background:#fff}
.vestina-chat-input-wrap textarea:focus{outline:none;border-color:var(--v-gold)}
.vestina-new-chat-form{background:var(--v-cream);border:1px solid var(--v-border);border-radius:var(--v-radius);padding:20px;margin-top:12px}

/* ── СЧЁТЧИК ГРАЖДАН ─────────────────────────────────────────────────────────── */
.vestina-members-counter{text-align:center;padding:40px 20px}
.vestina-counter-main{display:inline-block}
.vestina-counter-num{font-family:'Cormorant Garamond',serif;font-size:5rem;font-weight:700;color:var(--v-navy);line-height:1}
.vestina-counter-label{font-size:1rem;color:var(--v-text-muted);margin-top:6px;letter-spacing:0.04em}
.vestina-members-roles{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:32px}
.vestina-role-stat{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--v-border);border-radius:var(--v-radius);padding:10px 16px}
.vestina-role-stat-num{font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:700;color:var(--v-navy)}
.vestina-newest-citizens{max-width:500px;margin:0 auto}
.vestina-newest-citizens h3{font-family:'Cormorant Garamond',serif;font-size:1.3rem;color:var(--v-navy);margin:0 0 12px;text-align:center}
.vestina-newest-item{display:flex;align-items:center;gap:12px;padding:10px 14px;background:#fff;border:1px solid var(--v-border);border-radius:var(--v-radius);margin-bottom:6px}
.vestina-newest-id{font-family:monospace;font-size:0.78rem;color:var(--v-text-muted);min-width:100px}
.vestina-newest-name{flex:1;font-weight:600;color:var(--v-navy);font-size:0.9rem}
.vestina-newest-date{font-size:0.78rem;color:var(--v-text-muted)}

/* ── ФОРУМ (обновлённый) ─────────────────────────────────────────────────────── */
.vestina-forum-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--v-cream-dark)}
.vestina-forum-stats{font-size:0.9rem;color:var(--v-text-muted)}
.vestina-forum-stats strong{color:var(--v-navy)}

@media(max-width:640px){
    .vestina-chat-layout{grid-template-columns:1fr;height:auto}
    .vestina-chat-sidebar{height:200px}
    .vestina-chat-messages{height:250px}
}

/* ── МОДАЛЬНОЕ ОКНО ──────────────────────────────────────────────────────────── */
.vestina-modal-overlay {
    position: fixed;
    inset: 0;
    background: rgba(26,39,68,0.6);
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
}
.vestina-modal {
    background: #fff;
    border-radius: 12px;
    width: 100%;
    max-width: 520px;
    box-shadow: 0 20px 60px rgba(26,39,68,0.3);
    overflow: hidden;
}
.vestina-modal-header {
    background: linear-gradient(135deg, var(--v-navy) 0%, var(--v-navy-mid) 100%);
    padding: 18px 24px;
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.vestina-modal-header h3 {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.3rem;
    color: #fff;
    margin: 0;
}
.vestina-modal-close {
    background: none;
    border: none;
    color: rgba(255,255,255,0.6);
    font-size: 1.1rem;
    cursor: pointer;
    padding: 4px 8px;
    transition: color 0.2s;
}
.vestina-modal-close:hover { color: #fff; }
.vestina-modal-body { padding: 24px; }
.vestina-modal-footer {
    padding: 16px 24px;
    border-top: 1px solid var(--v-cream-dark);
    display: flex;
    gap: 12px;
    background: var(--v-cream);
}

/* Бейдж — выдвижение кандидатов */
.v-badge-nomination { background: #EDE9FE; color: #5B21B6; }

/* ── БАННЕР ПРЕДПРОСМОТРА ПРОФИЛЯ ────────────────────────────────────────────── */
.vestina-preview-banner {
    background: linear-gradient(135deg, #7c3aed 0%, #5b21b6 100%);
    color: #fff;
    padding: 12px 20px;
    border-radius: var(--v-radius);
    margin-bottom: 16px;
    font-size: 0.9rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
}
.vestina-preview-banner a {
    color: rgba(255,255,255,0.8);
    text-decoration: none;
    font-size: 0.85rem;
    white-space: nowrap;
}
.vestina-preview-banner a:hover { color: #fff; text-decoration: underline; }

/* ── КАРТОЧКА КАНДИДАТА v2 ───────────────────────────────────────────────────── */
.vestina-candidate-card {
    cursor: default; /* карточка не кликабельна целиком */
}
.vestina-candidate-select-wrap {
    margin-bottom: 10px;
}
.vestina-candidate-select-label {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    cursor: pointer;
    padding: 6px 12px;
    border: 1.5px solid var(--v-border);
    border-radius: 20px;
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--v-text-muted);
    transition: all 0.2s;
    user-select: none;
}
.vestina-candidate-select-label:hover {
    border-color: var(--v-gold);
    color: var(--v-navy);
}
.vestina-candidate-card.selected .vestina-candidate-select-label {
    background: var(--v-navy);
    border-color: var(--v-navy);
    color: var(--v-gold-light);
}
.vestina-candidate-card.selected .vestina-candidate-check {
    background: var(--v-gold);
    border-color: var(--v-gold);
    color: var(--v-navy);
}
.vestina-candidate-info-btn {
    display: block;
    width: 100%;
    margin-top: 10px;
    padding: 7px;
    background: var(--v-cream);
    border: 1px solid var(--v-border);
    border-radius: var(--v-radius);
    font-family: 'Inter', sans-serif;
    font-size: 0.82rem;
    color: var(--v-navy);
    cursor: pointer;
    transition: all 0.2s;
}
.vestina-candidate-info-btn:hover {
    background: var(--v-navy);
    color: var(--v-gold-light);
    border-color: var(--v-navy);
}

/* ── МОДАЛЬНОЕ ОКНО БИОГРАФИИ ────────────────────────────────────────────────── */
.vestina-bio-modal-profile {
    display: flex;
    align-items: center;
    gap: 16px;
    margin-bottom: 20px;
    padding-bottom: 16px;
    border-bottom: 1px solid var(--v-cream-dark);
}
.vestina-bio-modal-photo {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    object-fit: cover;
    border: 3px solid var(--v-gold);
    flex-shrink: 0;
}
.vestina-bio-modal-name {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.3rem;
    font-weight: 700;
    color: var(--v-navy);
    margin-bottom: 4px;
}
.vestina-bio-modal-vst {
    font-size: 0.8rem;
    color: var(--v-gold-dark);
    font-family: monospace;
}
.vestina-bio-modal-section-title {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--v-text-muted);
    font-weight: 600;
    margin-bottom: 8px;
    margin-top: 16px;
}
.vestina-bio-modal-text {
    font-size: 0.9rem;
    line-height: 1.7;
    color: var(--v-text);
    white-space: pre-wrap;
}

/* ── РЕДАКТОР ЗАКОНОПРОЕКТА (в гражданском участии) ─────────────────────────── */
.vestina-civic-body { line-height: 1.8; }
.vestina-civic-body p { margin-bottom: 12px; }
.vestina-civic-body strong, .vestina-civic-body b { font-weight: 700; }
.vestina-civic-body em, .vestina-civic-body i { font-style: italic; }
.vestina-civic-body u { text-decoration: underline; }
.vestina-civic-body ul, .vestina-civic-body ol { padding-left: 24px; margin-bottom: 12px; }
.vestina-civic-body li { margin-bottom: 4px; }
.vestina-civic-body h1,.vestina-civic-body h2,.vestina-civic-body h3 {
    font-family: 'Cormorant Garamond', serif;
    color: var(--v-navy);
    margin: 16px 0 8px;
}

/* ── ЗАБЛОКИРОВАННЫЙ ПРОФИЛЬ ─────────────────────────────────────────────────── */
.vestina-blocked-notice {
    text-align: center;
    padding: 64px 32px;
    max-width: 500px;
    margin: 40px auto;
    background: #fff;
    border: 1px solid #FCA5A5;
    border-radius: 12px;
    border-top: 4px solid #DC2626;
}
.vestina-blocked-icon { font-size: 3rem; margin-bottom: 16px; }
.vestina-blocked-notice h2 {
    font-family: 'Cormorant Garamond', serif;
    color: var(--v-navy);
    font-size: 1.6rem;
    margin-bottom: 10px;
}
.vestina-blocked-notice p { color: var(--v-text-muted); margin-bottom: 16px; }
.vestina-blocked-reason {
    background: #FEF2F2;
    border: 1px solid #FECACA;
    border-radius: var(--v-radius);
    padding: 10px 16px;
    font-size: 0.9rem;
    color: #991B1B;
    margin-bottom: 10px;
    text-align: left;
}
.vestina-blocked-until {
    font-size: 0.9rem;
    color: var(--v-text-muted);
    background: var(--v-cream);
    display: inline-block;
    padding: 6px 14px;
    border-radius: 20px;
    margin-top: 4px;
}

/* ── ОБЛОЖКА В СПИСКЕ ИНИЦИАТИВ ──────────────────────────────────────────────── */
.vestina-civic-card-link {
    display: flex;
    align-items: stretch;
    text-decoration: none;
    color: inherit;
    transition: all 0.2s;
}
.vestina-civic-card-link:hover {
    border-left-color: var(--v-gold);
    box-shadow: var(--v-shadow);
    transform: translateX(2px);
    color: inherit;
}
.vestina-civic-card-link .vestina-civic-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.3rem;
    color: var(--v-navy);
    margin: 0 0 10px;
    line-height: 1.3;
}
.vestina-civic-card-link:hover .vestina-civic-title { color: var(--v-gold-dark); }
.vestina-civic-card-body {
    flex: 1;
    min-width: 0;
}
.vestina-civic-card-cover {
    flex-shrink: 0;
    width: 160px;
    margin-left: 20px;
    border-radius: var(--v-radius);
    overflow: hidden;
    align-self: stretch;
}
.vestina-civic-card-cover img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    min-height: 120px;
}

/* ── ОБЛОЖКА НА СТРАНИЦЕ ИНИЦИАТИВЫ ─────────────────────────────────────────── */
.vestina-civic-cover {
    width: 100%;
    border-radius: 10px;
    overflow: hidden;
    margin-bottom: 24px;
    box-shadow: 0 4px 20px rgba(26,39,68,0.12);
    max-height: 420px;
}
.vestina-civic-cover img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

@media (max-width: 640px) {
    .vestina-civic-card-cover { display: none; }
}

/* ═══════════════════════════════════════════════════════════════
   v3.4 — ОНЛАЙН, ДРУЗЬЯ, КНОПКА КАБИНЕТА, ГОСУСЛУГИ, ПРОФИЛИ
   ═══════════════════════════════════════════════════════════════ */

/* Постоянная кнопка «Вернуться в личный кабинет» */
.vestina-back-bar {
    margin-bottom: 18px;
    padding: 10px 0 0;
}
.vestina-back-bar-btn {
    font-size: 0.85rem !important;
    padding: 8px 18px !important;
    width: auto !important;
    border-radius: 20px !important;
}

/* Ссылка-автор в форуме */
.vestina-author-link {
    color: var(--v-gold);
    text-decoration: none;
    font-weight: 500;
}
.vestina-author-link:hover { text-decoration: underline; }

/* VST-ID в строке темы */
.vestina-topic-vst {
    font-size: 0.72rem;
    color: var(--v-text-muted);
    background: rgba(212,175,55,.1);
    border: 1px solid rgba(212,175,55,.2);
    border-radius: 8px;
    padding: 1px 7px;
    margin-left: 4px;
    vertical-align: middle;
}

/* ── Граждане онлайн ── */
.vestina-online-wrap { max-width: 860px; }
.vestina-online-header { display: flex; align-items: center; gap: 12px; margin-bottom: 20px; }
.vestina-online-header h2 { margin: 0; }
.vestina-online-count {
    display: inline-flex; align-items: center; justify-content: center;
    min-width: 28px; height: 28px; border-radius: 14px;
    background: #2e7d32; color: #fff; font-size: 0.85rem; font-weight: 700; padding: 0 8px;
}
.vestina-online-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 12px;
}
.vestina-online-card {
    display: flex; align-items: center; gap: 12px;
    padding: 12px 14px;
    background: rgba(255,255,255,.04);
    border: 1px solid var(--v-border);
    border-radius: 10px;
    text-decoration: none;
    color: var(--v-text);
    transition: all .2s;
}
.vestina-online-card:hover { border-color: var(--v-gold); background: rgba(212,175,55,.06); }
.vestina-recently-card { opacity: .7; }
.vestina-online-dot {
    position: absolute; bottom: 2px; right: 2px;
    width: 11px; height: 11px; border-radius: 50%;
    background: #4caf50;
    border: 2px solid var(--v-bg, #0d1529);
}
.vestina-online-name { font-weight: 600; font-size: 0.9rem; }
.vestina-online-vst { font-size: 0.75rem; color: var(--v-text-muted); margin: 2px 0; }
.vestina-online-ago { font-size: 0.75rem; color: var(--v-text-muted); }
.vestina-online-indicator {
    display: inline-block; width: 10px; height: 10px;
    border-radius: 50%; background: #4caf50;
    border: 2px solid var(--v-bg, #0d1529);
}

/* ── Публичный профиль ── */
.vestina-public-profile { max-width: 680px; margin: 0 auto; }
.vestina-public-info-grid {
    display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin: 20px 0;
}
.vestina-public-info-item {
    display: flex; flex-direction: column; gap: 4px;
    padding: 12px 16px;
    background: rgba(255,255,255,.04);
    border: 1px solid var(--v-border);
    border-radius: 8px;
}
.vestina-public-info-full { grid-column: 1 / -1; }
.vestina-public-info-label { font-size: 0.78rem; color: var(--v-text-muted); }
.vestina-public-topics { margin-top: 24px; }
.vestina-public-topic-row {
    display: flex; justify-content: space-between; align-items: center;
    padding: 10px 14px; border: 1px solid var(--v-border); border-radius: 8px;
    text-decoration: none; color: var(--v-text); margin-bottom: 6px;
    transition: all .2s;
}
.vestina-public-topic-row:hover { border-color: var(--v-gold); }
.vestina-public-topic-meta { font-size: 0.78rem; color: var(--v-text-muted); white-space: nowrap; }
.vestina-profile-actions { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 14px; }
.vestina-last-seen { font-size: 0.8rem; color: var(--v-text-muted); margin-top: 4px; }
.vestina-last-seen.online { color: #4caf50; }
.vestina-back-cabinet {
    display: inline-flex; align-items: center; gap: 6px;
    color: var(--v-text-muted); text-decoration: none; font-size: 0.85rem;
    margin-bottom: 18px; transition: color .2s;
}
.vestina-back-cabinet:hover { color: var(--v-gold); }

/* ── Друзья ── */
.vestina-friends-wrap { padding: 8px 0; }
.vestina-friends-section { margin-bottom: 24px; }
.vestina-friends-section h3 { font-size: 0.95rem; color: var(--v-text-muted); margin: 0 0 12px; }
.vestina-friends-grid {
    display: grid; grid-template-columns: repeat(auto-fill, minmax(190px, 1fr)); gap: 10px;
}
.vestina-friend-card {
    display: flex; flex-direction: column; align-items: center; gap: 8px;
    padding: 16px 12px; text-align: center;
    background: rgba(255,255,255,.04);
    border: 1px solid var(--v-border); border-radius: 10px;
    text-decoration: none; color: var(--v-text); transition: all .2s;
}
.vestina-friend-card:hover { border-color: var(--v-gold); }
.vestina-friend-name { font-weight: 600; font-size: 0.88rem; }
.vestina-friend-vst { font-size: 0.73rem; color: var(--v-text-muted); }
.vestina-friend-actions { display: flex; gap: 6px; margin-top: 4px; }
.vestina-friend-action-btn {
    font-size: 0.78rem; padding: 4px 10px; border-radius: 6px; cursor: pointer;
    border: 1px solid var(--v-border); background: transparent; color: var(--v-text-muted);
    transition: all .2s;
}
.vestina-friend-action-btn:hover { border-color: var(--v-gold); color: var(--v-gold); }
.vestina-friend-action-btn.accept { border-color: #4caf50; color: #4caf50; }
.vestina-friend-action-btn.decline { border-color: #e05252; color: #e05252; }

/* ── Tab-link (ссылка вместо кнопки) ── */
.vestina-tab-link {
    text-decoration: none !important;
    display: inline-block;
}

/* ── Госуслуги ── */
.vestina-gosulugi-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 16px; margin-top: 10px;
}
.vestina-gosulugi-card {
    display: flex; flex-direction: column; align-items: center; text-align: center;
    padding: 28px 20px 20px;
    background: rgba(255,255,255,.04);
    border: 1px solid var(--v-border); border-radius: 12px;
    text-decoration: none; color: var(--v-text); transition: all .2s; position: relative;
}
.vestina-gosulugi-card:hover { border-color: var(--v-gold); background: rgba(212,175,55,.06); }
.vestina-gosulugi-card-soon { opacity: .55; pointer-events: none; }
.vestina-gosulugi-icon { font-size: 2.2rem; margin-bottom: 10px; }
.vestina-gosulugi-title { font-weight: 600; font-size: 1rem; margin-bottom: 6px; }
.vestina-gosulugi-desc { font-size: 0.82rem; color: var(--v-text-muted); }
.vestina-gosulugi-badge {
    position: absolute; top: 10px; right: 10px;
    font-size: 0.7rem; background: rgba(212,175,55,.15);
    color: var(--v-gold); border: 1px solid var(--v-gold);
    border-radius: 10px; padding: 2px 8px;
}

/* ── Свидетельство о браке ── */
.vestina-certificate-wrap { margin: 20px 0 28px; }
.vestina-certificate {
    border: 2px solid var(--v-gold);
    border-radius: 12px;
    padding: 32px;
    background: linear-gradient(135deg, rgba(212,175,55,.06) 0%, rgba(212,175,55,.02) 100%);
    max-width: 560px;
    margin: 0 auto;
    text-align: center;
    position: relative;
}
.vestina-certificate::before {
    content: '';
    position: absolute; inset: 6px;
    border: 1px solid rgba(212,175,55,.25);
    border-radius: 8px; pointer-events: none;
}
.vestina-certificate-header { margin-bottom: 24px; }
.vestina-certificate-crest { font-size: 2.4rem; margin-bottom: 8px; }
.vestina-certificate-title { font-size: 1.1rem; font-weight: 700; letter-spacing: .12em; color: var(--v-gold); }
.vestina-certificate-subtitle { font-size: 0.82rem; color: var(--v-text-muted); margin-top: 4px; }
.vestina-certificate-names { font-size: 1.2rem; font-weight: 600; margin: 16px 0; }
.vestina-certificate-and { margin: 0 12px; color: var(--v-gold); }
.vestina-certificate-date { font-size: 0.88rem; color: var(--v-text-muted); margin-top: 8px; }
.vestina-certificate-footer {
    margin-top: 24px; padding-top: 16px;
    border-top: 1px solid rgba(212,175,55,.2);
    font-size: 0.82rem; color: var(--v-text-muted);
    display: flex; align-items: center; justify-content: center; gap: 8px;
}
.vestina-certificate-seal { font-size: 1.4rem; }
.vestina-marriage-wrap { max-width: 680px; margin: 0 auto; }
.vestina-marriage-form-wrap {
    margin-top: 24px; padding: 20px 24px;
    background: rgba(255,255,255,.04);
    border: 1px solid var(--v-border); border-radius: 10px;
}
.vestina-marriage-request-card {
    padding: 18px 22px; margin-bottom: 16px;
    background: rgba(212,175,55,.08);
    border: 1px solid var(--v-gold); border-radius: 10px;
}

/* Свидетельство о расторжении — слегка отличается от свидетельства о браке */
.vestina-certificate-divorce {
    border-color: rgba(224, 82, 82, .5);
    background: linear-gradient(135deg, rgba(224,82,82,.05) 0%, rgba(224,82,82,.02) 100%);
}
.vestina-certificate-divorce .vestina-certificate-title {
    color: #e05252;
    font-size: 0.95rem;
}
.vestina-certificate-divorce::before {
    border-color: rgba(224,82,82,.2);
}

/* ── Госуслуги: карточка с входящим заявлением ── */
.vestina-gosulugi-card-alert {
    border-color: var(--v-gold) !important;
    background: rgba(212,175,55,.08) !important;
}
.vestina-badge-alert {
    background: var(--v-gold) !important;
    color: var(--v-navy, #0d1529) !important;
    border: none !important;
    font-weight: 700;
}

/* ── Поиск друга по VST-ID ── */
.vestina-friends-search {
    padding: 16px;
    background: rgba(255,255,255,.04);
    border: 1px solid var(--v-border);
    border-radius: 10px;
    margin-bottom: 20px;
}
.vestina-friends-search input {
    padding: 10px 14px;
    background: rgba(255,255,255,.06);
    border: 1px solid var(--v-border);
    border-radius: 8px;
    color: var(--v-text);
    font-size: 0.9rem;
}
.vestina-vst-found-card {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 16px;
    background: rgba(212,175,55,.07);
    border: 1px solid rgba(212,175,55,.3);
    border-radius: 10px;
    margin-bottom: 10px;
    flex-wrap: wrap;
}
.vestina-vst-found-info { flex: 1; min-width: 0; }

/* ── Шапка публичного профиля — фикс переноса имени и размера кнопок ── */
.vestina-public-profile .vestina-cabinet-header {
    flex-wrap: nowrap;
    align-items: flex-start;
    gap: 16px;
}
.vestina-public-profile .vestina-cabinet-info {
    flex: 1;
    min-width: 0;
}
.vestina-public-profile .vestina-cabinet-info h2 {
    font-size: 1.3rem;
    word-break: break-word;
    white-space: normal;
    line-height: 1.3;
}
.vestina-profile-actions {
    flex-shrink: 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
    align-items: flex-end;
}
.vestina-profile-actions .vestina-btn {
    font-size: 0.82rem !important;
    padding: 7px 14px !important;
    width: auto !important;
    white-space: nowrap;
}

/* ── Чат: шапка треда с аватаркой ── */

/* ═══════════════════════════════════════════════════════════════
   ФОРУМ — КАТЕГОРИИ, ПАГИНАЦИЯ, ОБЩИЙ ПОРЯДОК (v3.4 fix)
   ═══════════════════════════════════════════════════════════════ */

/* Тулбар форума */
.vestina-forum-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 16px;
    padding-bottom: 16px;
    border-bottom: 1px solid var(--v-border);
}
.vestina-forum-stats {
    font-size: 0.85rem;
    color: var(--v-text-muted);
}

/* Категории-табы */
.vestina-forum-cats {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin: 0 0 18px;
    padding-bottom: 16px;
    border-bottom: 1px solid var(--v-border);
}
.vestina-cat-tab {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 5px 12px;
    border-radius: 16px;
    border: 1px solid var(--v-border);
    color: var(--v-text-muted);
    font-size: 0.82rem;
    text-decoration: none;
    transition: all .18s;
    background: transparent;
    cursor: pointer;
    white-space: nowrap;
}
.vestina-cat-tab:hover { border-color: var(--v-gold); color: var(--v-gold); }
.vestina-cat-tab.active {
    background: var(--v-gold);
    color: var(--v-navy, #0d1529);
    border-color: var(--v-gold);
    font-weight: 600;
}
.vestina-cat-tab .vestina-cat-count {
    font-size: 0.7rem;
    background: rgba(0,0,0,.15);
    border-radius: 8px;
    padding: 0px 5px;
    color: inherit;
    margin-left: 0;
}
.vestina-cat-tab.active .vestina-cat-count { background: rgba(0,0,0,.2); }

/* Строка темы */
.vestina-topics-list { display: flex; flex-direction: column; gap: 6px; }
.vestina-topic-icon { font-size: 1.1rem; flex-shrink: 0; width: 28px; text-align: center; }
.vestina-topic-info { flex: 1; min-width: 0; }
.vestina-topic-meta {
    font-size: 0.78rem;
    color: var(--v-text-muted);
    margin-top: 3px;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 4px;
}
.vestina-topic-stats {
    text-align: right;
    font-size: 0.78rem;
    color: var(--v-text-muted);
    flex-shrink: 0;
    min-width: 60px;
}

/* Пагинация */
.vestina-pagination {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
    justify-content: center;
    margin: 20px 0;
}
.vestina-page-btn {
    min-width: 34px;
    height: 34px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 7px;
    border: 1px solid var(--v-border);
    color: var(--v-text-muted);
    text-decoration: none;
    font-size: 0.85rem;
    transition: all .18s;
    background: transparent;
}
.vestina-page-btn:hover { border-color: var(--v-gold); color: var(--v-gold); }
.vestina-page-btn.active {
    background: var(--v-gold);
    color: var(--v-navy, #0d1529);
    border-color: var(--v-gold);
    font-weight: 700;
}

/* ── Строка темы — финальная структура ── */
.vestina-topic-row {
    display: flex;
    align-items: center;
    gap: 12px;
    background: rgba(255,255,255,.03);
    border: 1px solid var(--v-border);
    border-radius: 8px;
    padding: 12px 14px;
    text-decoration: none;
    color: var(--v-text);
    transition: border-color .18s, background .18s;
    margin-bottom: 0;
}
.vestina-topic-row:hover {
    border-color: var(--v-gold);
    background: rgba(212,175,55,.05);
}
.vestina-topic-avatar-link {
    flex-shrink: 0;
    display: block;
    line-height: 0;
}
.vestina-topic-avatar-link:hover { opacity: .85; }

/* Аватарки — xs размер */
.vestina-avatar-xs {
    width: 36px !important;
    height: 36px !important;
    font-size: 0.8rem !important;
}

.vestina-topic-info { flex: 1; min-width: 0; }
.vestina-topic-title {
    font-weight: 600;
    color: var(--v-text);
    font-size: 0.93rem;
    line-height: 1.35;
    margin-bottom: 4px;
}
.vestina-topic-meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 4px;
    font-size: 0.78rem;
    color: var(--v-text-muted);
    margin-top: 0;
}
.vestina-topic-cat-tag {
    font-size: 0.69rem;
    background: rgba(212,175,55,.12);
    color: var(--v-gold);
    border: 1px solid rgba(212,175,55,.25);
    border-radius: 8px;
    padding: 1px 6px;
    margin-left: 4px;
    vertical-align: middle;
}
.vestina-topic-stats {
    text-align: right;
    font-size: 0.78rem;
    color: var(--v-text-muted);
    flex-shrink: 0;
    min-width: 56px;
}

/* Основная ссылка темы внутри div-обёртки */
.vestina-topic-main-link {
    flex: 1;
    min-width: 0;
    text-decoration: none;
    color: var(--v-text);
}
.vestina-topic-main-link:hover .vestina-topic-title {
    color: var(--v-gold);
}
/* div-обёртка строки темы */
div.vestina-topic-row {
    cursor: default;
}
div.vestina-topic-row:hover {
    border-color: var(--v-gold);
    background: rgba(212,175,55,.05);
}

/* ── Форум: заголовок темы как ссылка ── */
.vestina-topic-title-link {
    display: block;
    font-weight: 600;
    font-size: 0.95rem;
    color: var(--v-text);
    text-decoration: none;
    line-height: 1.4;
    margin-bottom: 4px;
    transition: color .15s;
}
.vestina-topic-title-link:hover { color: var(--v-gold); }
.vestina-pin { font-style: normal; }
.vestina-lock { font-size: 0.8em; }

/* ── Профиль: читаемые роль и ID в тёмной шапке ── */
.vestina-cabinet-header .vestina-role-badge {
    margin-top: 4px;
}
.vestina-cabinet-header .vestina-citizen-id {
    font-size: 0.88rem;
    color: rgba(255,255,255,.85);
    margin-top: 4px;
    letter-spacing: .02em;
}
.vestina-cabinet-header .vestina-last-seen {
    font-size: 0.8rem;
    color: rgba(255,255,255,.6);
    margin-top: 3px;
}
.vestina-cabinet-header .vestina-last-seen.online {
    color: #81c784;
}

/* ── Чат: input wrap не сжимается ── */
.vestina-chat-input-wrap {
    flex-shrink: 0;
    padding: 10px 12px;
    border-top: 1px solid var(--v-border);
    background: rgba(255,255,255,.03);
    display: flex;
    gap: 8px;
    align-items: flex-end;
}
.vestina-chat-input-wrap textarea {
    flex: 1;
    resize: none;
    border-radius: 8px;
    padding: 8px 12px;
    background: rgba(255,255,255,.07);
    border: 1px solid var(--v-border);
    color: var(--v-text);
    font-size: 0.88rem;
    min-height: 38px;
    max-height: 80px;
}

/* ── Друзья: поиск по VST — карточка вставляется над алертом ── */
.vestina-vst-found-card {
    margin-bottom: 10px;
}

/* ════════════════════════════════════════════════════════════════
   ФИНАЛЬНЫЙ ФИХ v3.4.1 — аватарки, онлайн, чат
   ════════════════════════════════════════════════════════════════ */

/* Базовый div-аватар (инициалы) */
.vestina-avatar {
    border-radius: 50%;
    background: var(--v-gold, #d4af37);
    color: var(--v-navy, #0d1529);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-family: 'Cormorant Garamond', serif;
    flex-shrink: 0;
    line-height: 1;
    /* дефолтный размер */
    width: 56px; height: 56px; font-size: 1rem;
}

/* Размеры — применяются и к div и к img */
.vestina-avatar.vestina-avatar-lg,
img.vestina-avatar-img.vestina-avatar-lg { width: 72px !important; height: 72px !important; font-size: 1.2rem !important; }

.vestina-avatar.vestina-avatar-sm,
img.vestina-avatar-img.vestina-avatar-sm { width: 40px !important; height: 40px !important; font-size: 0.82rem !important; }

.vestina-avatar.vestina-avatar-xs,
img.vestina-avatar-img.vestina-avatar-xs { width: 32px !important; height: 32px !important; font-size: 0.72rem !important; }

/* Онлайн-точка */
.vestina-online-dot {
    position: absolute !important;
    bottom: 1px; right: 1px;
    width: 10px; height: 10px;
    border-radius: 50%;
    background: #4caf50;
    border: 2px solid var(--v-bg, #0d1529);
    display: block !important;
    z-index: 2;
}

/* Чат — фикс прокрутки */
.vestina-chat-layout {
    height: 520px !important;
}
.vestina-chat-window {
    display: flex !important;
    flex-direction: column !important;
    overflow: hidden !important;
    height: 100% !important;
}
.vestina-chat-messages {
    flex: 1 1 auto !important;
    overflow-y: auto !important;
    min-height: 0 !important;
}
.vestina-chat-input-wrap {
    flex-shrink: 0 !important;
}

/* Чат — тёмная тема для пузырей */
.vestina-chat-msg.mine .vestina-chat-bubble {
    background: var(--v-gold, #d4af37) !important;
    color: var(--v-navy, #0d1529) !important;
}
.vestina-chat-msg.theirs .vestina-chat-bubble {
    background: rgba(255,255,255,.09) !important;
    border: 1px solid var(--v-border) !important;
    color: var(--v-text) !important;
}

/* Sidebar чата */
.vestina-chat-sidebar { background: rgba(255,255,255,.02) !important; }
.vestina-chat-sidebar-header { background: transparent !important; }
.vestina-chat-window { background: transparent !important; }

/* ════════════════════════════════════════════════════════════════
   МОИ ДОКУМЕНТЫ — вкладка в кабинете
   ════════════════════════════════════════════════════════════════ */
.vestina-documents-wrap { display: flex; flex-direction: column; gap: 28px; }
.vestina-doc-section {}
.vestina-doc-title {
    font-size: 1rem;
    font-weight: 600;
    color: var(--v-text);
    margin: 0 0 14px;
    padding-bottom: 8px;
    border-bottom: 1px solid var(--v-border);
    display: flex;
    align-items: center;
    gap: 7px;
}
.vestina-doc-empty {
    font-size: 0.88rem;
    color: var(--v-text-muted);
    padding: 14px 16px;
    background: rgba(255,255,255,.03);
    border: 1px dashed var(--v-border);
    border-radius: 8px;
}

/* Поздравление от Президента */
.vestina-congrats-card {
    margin-top: 16px;
    border: 1px solid rgba(212,175,55,.35);
    border-radius: 12px;
    background: linear-gradient(135deg, rgba(212,175,55,.08) 0%, rgba(212,175,55,.03) 100%);
    overflow: hidden;
}
.vestina-congrats-header {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 18px 10px;
    border-bottom: 1px solid rgba(212,175,55,.2);
}
.vestina-congrats-icon { font-size: 1.6rem; }
.vestina-congrats-from {
    font-size: 0.72rem;
    color: var(--v-gold);
    text-transform: uppercase;
    letter-spacing: .08em;
    font-weight: 600;
}
.vestina-congrats-title {
    font-size: 0.92rem;
    font-weight: 600;
    color: var(--v-text);
}
.vestina-congrats-body {
    padding: 16px 18px;
    font-size: 0.9rem;
    line-height: 1.65;
    color: var(--v-text);
    font-style: italic;
}
.vestina-congrats-footer {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 18px;
    border-top: 1px solid rgba(212,175,55,.15);
    background: rgba(0,0,0,.06);
}

/* ═══════════════════════════════════════════════════════════════
   VESTINA v3.5.0 — НОВЫЙ ВИЗУАЛ КАБИНЕТА
   Переопределяет старые стили кабинета, не трогает форум/выборы
   ═══════════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Raleway:wght@300;400;500;600;700&display=swap');

/* ── СКРЫТЬ САЙДБАР и расширить контент на страницах плагина ── */

/* Универсальные селекторы — работают с большинством тем включая Tenku */
.page-id-vestina-cabinet .widget-area,
.page-id-vestina-cabinet #secondary,
.page-id-vestina-cabinet aside,
.vestina-wrap ~ .widget-area,
.vestina-wrap ~ #secondary,
.vestina-wrap ~ aside {
  display: none !important;
}

/* Tenku специфичные классы */
body:has(.vestina-wrap) #secondary { display: none !important; }
body:has(.vestina-wrap) .widget-area { display: none !important; }
body:has(.vestina-wrap) aside.sidebar { display: none !important; }
body:has(.vestina-wrap) #main { width: 100% !important; max-width: 100% !important; }
body:has(.vestina-wrap) #primary { width: 100% !important; max-width: 100% !important; float: none !important; }
body:has(.vestina-wrap) .content-area { width: 100% !important; max-width: 100% !important; float: none !important; }
body:has(.vestina-wrap) .site-content { width: 100% !important; }
body:has(.vestina-wrap) .site-main { width: 100% !important; }

/* Tenku конкретные grid/flex контейнеры */
body:has(.vestina-wrap) .content-sidebar-wrap { display: block !important; }
body:has(.vestina-wrap) .site-inner { max-width: 100% !important; }
body:has(.vestina-wrap) #content { width: 100% !important; float: none !important; margin: 0 !important; }
body:has(.vestina-wrap) .entry-content { max-width: 100% !important; }

/* Если тема использует grid */
body:has(.vestina-wrap) .site-content,
body:has(.vestina-wrap) #page {
  display: block !important;
}


/* ── НОВЫЕ CSS-переменные кабинета (светлая тема, Вестина #1A2E5A) ── */
.vestina-wrap {
  --vb-primary:   #1A2E5A;
  --vb-primary-2: #243a72;
  --vb-primary-3: #2e488a;
  --vb-accent:    #2563c8;
  --vb-accent-2:  #5a8ae0;
  --vb-accent-3:  #b8cff4;
  --vb-light:     #eef3fc;
  --vb-lighter:   #f6f9ff;
  --vb-white:     #ffffff;
  --vb-bg:        #f4f7fb;
  --vb-text:      #1A2E5A;
  --vb-muted:     #5a6e99;
  --vb-border:    #c8d6ee;
  --vb-border-2:  #dce7f8;
  --vb-success:   #1a7a56;
  --vb-radius:    10px;
  --vb-shadow:    0 2px 16px rgba(26,46,90,0.09);
  --vb-shadow-sm: 0 1px 5px rgba(26,46,90,0.06);
  font-family: 'Raleway', sans-serif;
  font-size: 14px;
  background: var(--vb-bg);
  color: var(--vb-text);
}

/* ── КАБИНЕТ: ОБЁРТКА ── */
.vestina-wrap .vestina-cabinet {
  background: transparent;
  border: none;
  box-shadow: none;
  border-radius: 0;
  max-width: 1080px;
  margin: 0 auto;
}

/* ── БАННЕР с геометрическим паттерном ── */
.vestina-cabinet-banner {
  height: 160px;
  background: var(--vb-primary);
  position: relative;
  overflow: hidden;
  border-radius: var(--vb-radius) var(--vb-radius) 0 0;
}

/* Геометрические фигуры SVG-паттерн */
.vestina-cabinet-banner::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    /* Large diamond top-right */
    linear-gradient(45deg, transparent 35%, rgba(255,255,255,0.04) 35%, rgba(255,255,255,0.04) 50%, transparent 50%),
    linear-gradient(-45deg, transparent 35%, rgba(255,255,255,0.04) 35%, rgba(255,255,255,0.04) 50%, transparent 50%),
    /* Grid lines */
    linear-gradient(rgba(255,255,255,0.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.035) 1px, transparent 1px);
  background-size: 80px 80px, 80px 80px, 40px 40px, 40px 40px;
}

/* Large accent circle top-right */
.vestina-cabinet-banner::after {
  content: '';
  position: absolute;
  top: -100px; right: -80px;
  width: 360px; height: 360px;
  border-radius: 50%;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.07);
}

/* Extra geometric shapes via box-shadow trick on label */
.vestina-cabinet-banner-label {
  position: absolute;
  top: 18px; right: 24px;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.3);
  z-index: 1;
}

/* Diamond shapes overlay */
.vestina-cabinet-banner-label::before {
  content: '';
  position: absolute;
  bottom: -90px; left: -320px;
  width: 120px; height: 120px;
  border: 1px solid rgba(255,255,255,0.07);
  transform: rotate(45deg);
}

.vestina-cabinet-banner-label::after {
  content: '';
  position: absolute;
  bottom: -50px; left: -180px;
  width: 70px; height: 70px;
  border: 1px solid rgba(255,255,255,0.06);
  transform: rotate(45deg);
  background: rgba(255,255,255,0.02);
}

/* ── ШАПКА КАБИНЕТА ── */
.vestina-wrap .vestina-cabinet-header {
  background: var(--vb-white) !important;
  padding: 0 36px 0 !important;
  border-bottom: 1px solid var(--vb-border-2);
  box-shadow: 0 2px 10px rgba(26,46,90,0.07);
  display: block !important;
}

.vestina-head-top {
  display: flex;
  align-items: flex-end;
  gap: 16px;
  padding-bottom: 18px;
  position: relative;
  top: -40px;
  margin-bottom: -40px;
  min-width: 0;
}

/* ── АВАТАР ── */
.vestina-wrap .vestina-avatar-wrap {
  position: relative;
  flex-shrink: 0;
}

.vestina-wrap .vestina-avatar,
.vestina-wrap img.vestina-avatar-img {
  width: 100px !important;
  height: 100px !important;
  border-radius: 50% !important;
  border: 4px solid var(--vb-white) !important;
  box-shadow: 0 4px 18px rgba(26,46,90,0.18) !important;
  font-size: 2rem !important;
  background: var(--vb-primary-3) !important;
  color: var(--vb-white) !important;
}

.vestina-wrap .vestina-avatar-edit {
  background: var(--vb-accent) !important;
  color: var(--vb-white) !important;
  border: 2px solid var(--vb-white) !important;
  width: 28px !important;
  height: 28px !important;
}
.vestina-wrap .vestina-avatar-edit:hover {
  transform: none !important;
  background: var(--vb-primary-2) !important;
}

/* ── ИМЯ И МЕТА ── */
.vestina-head-info { flex: 1; min-width: 0; padding-bottom: 6px; overflow: hidden; }

.vestina-wrap .vestina-cabinet-info h2 {
  font-family: 'Raleway', sans-serif !important;
  font-size: 22px !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  font-weight: 700 !important;
  color: var(--vb-primary) !important;
  margin: 0 0 6px !important;
}

.vestina-wrap .vestina-login-label {
  font-size: 13px;
  color: var(--vb-muted);
  font-weight: 400;
}

.vestina-wrap .vestina-role-badge {
  font-size: 12px !important;
  font-weight: 600 !important;
  padding: 3px 12px !important;
  border-radius: 20px !important;
  background: var(--vb-light) !important;
  color: var(--vb-accent) !important;
  border: 1px solid var(--vb-accent-3) !important;
}

.vestina-wrap .vestina-citizen-id {
  font-size: 12px;
  color: var(--vb-muted);
  background: var(--vb-lighter);
  border: 1px solid var(--vb-border-2);
  padding: 2px 10px;
  border-radius: 6px;
}

/* ── КНОПКИ ── */
.vestina-wrap .vestina-btn {
  font-family: 'Raleway', sans-serif !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  border-radius: 8px !important;
  padding: 9px 20px !important;
  transition: all 0.15s !important;
}
.vestina-wrap .vestina-btn-primary {
  background: var(--vb-primary) !important;
  color: var(--vb-white) !important;
  border: none !important;
}
.vestina-wrap .vestina-btn-primary:hover { background: var(--vb-primary-2) !important; }
.vestina-wrap .vestina-btn-ghost {
  background: var(--vb-primary) !important;
  color: #ffffff !important;
  border: 2px solid var(--vb-primary) !important;
}
.vestina-wrap .vestina-btn-ghost:hover {
  background: var(--vb-primary-2) !important;
  border-color: var(--vb-primary-2) !important;
  color: #ffffff !important;
}

/* ── ВКЛАДКИ ── */
.vestina-wrap .vestina-tabs {
  display: flex !important;
  border-bottom: 1px solid var(--vb-border-2) !important;
  background: var(--vb-white) !important;
  flex-wrap: nowrap !important;
  overflow-x: auto;
  scrollbar-width: none;
  margin-top: 18px;
}
.vestina-wrap .vestina-tabs::-webkit-scrollbar { display: none; }

.vestina-wrap .vestina-tab,
.vestina-wrap .vestina-tab-link {
  font-family: 'Raleway', sans-serif !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  color: var(--vb-muted) !important;
  padding: 13px 18px !important;
  border: none !important;
  border-bottom: 2px solid transparent !important;
  background: none !important;
  white-space: nowrap;
  margin-bottom: -1px;
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 6px;
  transition: color 0.15s !important;
}
.vestina-wrap .vestina-tab:hover,
.vestina-wrap .vestina-tab-link:hover { color: var(--vb-primary) !important; }
.vestina-wrap .vestina-tab.active {
  color: var(--vb-primary) !important;
  border-bottom-color: var(--vb-accent) !important;
  font-weight: 700 !important;
}

.vestina-wrap .vestina-badge {
  background: var(--vb-accent) !important;
  color: #fff !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  border-radius: 10px !important;
  padding: 1px 6px !important;
}

/* ── КОНТЕНТ ВКЛАДОК ── */
.vestina-wrap .vestina-tab-content {
  padding: 28px 32px !important;
  background: var(--vb-bg);
}

/* ── КАРТОЧКИ / ПОЛЯ ── */
.vestina-wrap .vestina-stat-card,
.vestina-wrap .vestina-idcard-section,
.vestina-wrap .vestina-vst-card,
.vestina-wrap .vestina-quick-links,
.vestina-wrap .vestina-doc-section {
  background: var(--vb-white);
  border: 1px solid var(--vb-border-2);
  border-radius: var(--vb-radius);
  box-shadow: var(--vb-shadow-sm);
}

.vestina-wrap .vestina-stat-num { color: var(--vb-primary) !important; font-family: 'Raleway', sans-serif !important; font-weight: 700 !important; }
.vestina-wrap .vestina-stat-label { color: var(--vb-muted) !important; font-size: 12px !important; }

/* ── ПОЛЯ ФОРМЫ ── */
.vestina-wrap input[type="text"],
.vestina-wrap input[type="email"],
.vestina-wrap input[type="tel"],
.vestina-wrap input[type="password"],
.vestina-wrap input[type="url"],
.vestina-wrap textarea,
.vestina-wrap select {
  font-family: 'Raleway', sans-serif !important;
  font-size: 14px !important;
  color: var(--vb-primary) !important;
  border: 1px solid var(--vb-border) !important;
  border-radius: 8px !important;
  background: var(--vb-white) !important;
}
.vestina-wrap input:focus,
.vestina-wrap textarea:focus,
.vestina-wrap select:focus {
  border-color: var(--vb-accent) !important;
  outline: none !important;
  box-shadow: 0 0 0 3px rgba(37,99,200,0.1) !important;
}

/* ── LABEL ── */
.vestina-wrap label {
  font-family: 'Raleway', sans-serif;
  font-size: 12px;
  font-weight: 700;
  color: var(--vb-muted);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

/* ── АЛЕРТЫ ── */
.vestina-wrap .vestina-alert { border-radius: 8px !important; font-family: 'Raleway', sans-serif !important; }
.vestina-wrap .vestina-alert.success { background: #e6f4ea !important; color: var(--vb-success) !important; border-color: #b7dfbf !important; }
.vestina-wrap .vestina-alert.error   { background: #fce8e8 !important; color: #a32d2d !important; border-color: #f5b8b8 !important; }

/* ── VST КАРТОЧКА ── */
.vestina-wrap .vestina-vst-label { color: var(--vb-accent) !important; font-size: 11px !important; letter-spacing: 0.16em !important; text-transform: uppercase !important; font-weight: 700 !important; }
.vestina-wrap .vestina-vst-number { color: var(--vb-primary) !important; font-family: 'Raleway', sans-serif !important; font-weight: 700 !important; font-size: 26px !important; }

/* ── ИСТОРИЯ ── */
.vestina-wrap .vestina-history-item { border-bottom: 1px solid var(--vb-border-2) !important; font-size: 13px !important; }
.vestina-wrap .vestina-history-date { color: var(--vb-muted) !important; }

/* ── PENDING (заявка на рассмотрении) ── */
.vestina-wrap .vestina-pending-card {
  background: var(--vb-white) !important;
  border: 1px solid var(--vb-border-2) !important;
  border-radius: var(--vb-radius) !important;
  color: var(--vb-text) !important;
}

/* ── БЛОКИРОВКА ── */
.vestina-wrap .vestina-blocked-notice {
  background: var(--vb-white) !important;
  border-radius: var(--vb-radius) !important;
}

/* ── СООБЩЕНИЯ ── */
.vestina-wrap .vestina-chat-sidebar { border-right: 1px solid var(--vb-border-2) !important; }
.vestina-wrap .vestina-chat-sidebar-header { background: var(--vb-lighter) !important; border-bottom: 1px solid var(--vb-border-2) !important; }
.vestina-wrap .vestina-thread-item:hover,
.vestina-wrap .vestina-thread-item.active { background: var(--vb-lighter) !important; }
.vestina-wrap .vestina-thread-item.active { border-left: 3px solid var(--vb-accent) !important; }

/* ── ДРУЗЬЯ ── */
.vestina-wrap .vestina-friend-card { border: 1px solid var(--vb-border-2) !important; border-radius: var(--vb-radius) !important; }
.vestina-wrap .vestina-friend-card:hover { border-color: var(--vb-accent-2) !important; }

/* ── ОНЛАЙН ── */
.vestina-wrap .vestina-online-dot { background: #22c55e !important; }

/* ── ГОСУСЛУГИ: ПОДВКЛАДКИ ── */
.vestina-gs-tabs {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-bottom: 20px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--vb-border-2);
}
.vestina-gs-tab {
  font-family: 'Raleway', sans-serif;
  font-size: 13px;
  font-weight: 700;
  padding: 8px 18px;
  border-radius: 20px;
  border: 2px solid var(--vb-primary);
  background: var(--vb-primary);
  color: #ffffff;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
  white-space: nowrap;
}
.vestina-gs-tab:hover { background: var(--vb-primary-2); border-color: var(--vb-primary-2); color: #ffffff; }
.vestina-gs-tab.active { background: var(--vb-accent); border-color: var(--vb-accent); color: #ffffff; }

.vestina-gs-pane { display: none; }
.vestina-gs-pane.active { display: block; }

.vestina-gs-pane .vp-wrap { --vp-primary: #1A2E5A; --vp-accent: #2563c8; --vp-light: #f6f9ff; --vp-border: #dce7f8; }
.vestina-gs-pane--dark { border-radius: var(--vb-radius); overflow: hidden; }

/* ── PREVIEW BANNER (admin) ── */
.vestina-wrap .vestina-preview-banner {
  background: var(--vb-light) !important;
  border-bottom: 1px solid var(--vb-accent-3) !important;
  color: var(--vb-primary) !important;
  font-family: 'Raleway', sans-serif !important;
}

/* ── PUBLIC PROFILE ── */
.vestina-public-profile .vestina-cabinet-header {
  background: var(--vb-white) !important;
}
.vestina-public-profile .vestina-cabinet-info h2 { color: var(--vb-primary) !important; }

/* ── RESPONSIVE ── */
@media (max-width: 700px) {
  .vestina-wrap .vestina-tab-content { padding: 20px 16px !important; }
  .vestina-wrap .vestina-cabinet-header { padding: 0 16px 0 !important; }
  .vestina-head-top { padding: 0 16px 16px; }
  .vestina-cabinet-banner { height: 120px; }
}

/* ── По body class .vestina-page ── */
body.vestina-page #secondary,
body.vestina-page .widget-area,
body.vestina-page aside#secondary,
body.vestina-page .sidebar,
body.vestina-page [class*="sidebar"],
body.vestina-page [id*="sidebar"] {
  display: none !important;
}

body.vestina-page #primary,
body.vestina-page #content,
body.vestina-page .content-area,
body.vestina-page main#main,
body.vestina-page .hfeed {
  width: 100% !important;
  max-width: 100% !important;
  float: none !important;
  margin-right: 0 !important;
}

body.vestina-page .site-content,
body.vestina-page #page .site-content {
  display: block !important;
}

/* ── ПРОКРУТКА ВКЛАДОК НА МОБИЛЬНОМ ── */
.vestina-wrap .vestina-tabs {
  overflow-x: auto !important;
  -webkit-overflow-scrolling: touch;
  flex-wrap: nowrap !important;
  scrollbar-width: none;
}
.vestina-wrap .vestina-tabs::-webkit-scrollbar { display: none; }

/* ── CHAT LAYOUT ── */
.vestina-wrap .vestina-chat-layout {
  overflow: hidden !important;
  background: var(--vb-white) !important;
}

.vestina-wrap .vestina-chat-sidebar {
  display: flex !important;
  flex-direction: column !important;
  border-right: 1px solid var(--vb-border-2) !important;
  background: var(--vb-white) !important;
  width: 260px !important;
  min-width: 260px !important;
  overflow: hidden !important;
}

.vestina-wrap .vestina-chat-threads {
  flex: 1 !important;
  overflow-y: auto !important;
  display: block !important;
}

@media (max-width: 600px) {
  .vestina-wrap .vestina-chat-layout {
    grid-template-columns: 1fr !important;
    height: auto !important;
  }
  .vestina-wrap .vestina-chat-sidebar {
    width: 100% !important;
    min-width: unset !important;
    height: 220px !important;
  }
}

/* ── LAST SEEN ── */
.vestina-wrap .vestina-last-seen,
.vestina-chat-thread .vestina-last-seen {
  color: #5a6e99 !important;
  font-size: 12px !important;
}
.vestina-wrap .vestina-last-seen.online {
  color: #22c55e !important;
}

/* ── CROPPER.JS ── */
#crop-modal .cropper-container {
  max-height: 320px !important;
}
#crop-modal img#crop-image {
  display: block;
  max-width: 100%;
}
