*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
    --bg:#edeef0;
    --white:#ffffff;
    --border:#DBDBDB;
    --primary:#0077ff;
    --primary-hover:#006de9;
    --text:#19191a;
    --text-secondary:#383a3d;
    --red:#e64646;
    --green:#4caf50;
    --orange:#ff9800;
    --radius:12px;
    --radius-sm:8px;
    --shadow:0 2px 12px rgba(0,0,0,.08);
    --shadow-md:0 4px 24px rgba(0,0,0,.12);
    --blur:blur(12px);
}
html{font-size:15px;scroll-behavior:smooth}
body{font-family:"Montserrat",sans-serif;background:var(--bg);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:var(--primary);text-decoration:none}
a:hover{color:var(--primary-hover)}
img{max-width:100%;display:block}
input,textarea,select{font-family:inherit;font-size:.9rem;width:100%;border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px;outline:none;background:#fff;color:var(--text);transition:border-color .2s,box-shadow .2s}
input:focus,textarea:focus,select:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(0,119,255,.15)}
textarea{resize:vertical;min-height:80px}
select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg' fill='none' stroke='%235d5f61' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:16px;padding-right:36px}

.btn-primary,.btn-secondary,.btn-danger,.btn-ghost{display:inline-flex;align-items:center;justify-content:center;gap:6px;font-family:inherit;font-size:.875rem;font-weight:600;padding:10px 20px;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:background .2s,transform .1s,box-shadow .2s;text-decoration:none}
.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-hover);color:#fff}
.btn-primary:active,.btn-secondary:active,.btn-danger:active{transform:scale(.98)}
.btn-secondary{background:#f0f2f5;color:var(--text)}.btn-secondary:hover{background:#e3e6ea}
.btn-danger{background:var(--red);color:#fff}.btn-danger:hover{background:#cc3c3c}
.btn-ghost{background:transparent;color:var(--primary);border:1px solid var(--primary)}.btn-ghost:hover{background:rgba(0,119,255,.07)}
.btn-full{width:100%}
.btn-sm{padding:14px 14px;font-size:.9rem}
.btn-icon{background:none;border:none;cursor:pointer;color:var(--text-secondary);display:inline-flex;align-items:center;padding:4px;border-radius:6px;transition:color .2s,background .2s}
.btn-icon:hover{color:var(--primary);background:rgba(0,119,255,.08)}

.card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}
.form-group{margin-bottom:16px}
.form-group label{display:block;font-size:.82rem;font-weight:600;margin-bottom:6px;color:var(--text-secondary)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-error{color:var(--red);font-size:.82rem;margin-top:-8px;margin-bottom:8px;min-height:20px}
.required{color:var(--red)}
.input-eye{position:relative}
.input-eye input{padding-right:44px}
.eye-btn{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--text-secondary);display:flex;padding:0}

.role-badge{display:inline-block;font-size:.72rem;font-weight:700;padding:2px 10px;border-radius:20px;text-transform:uppercase;letter-spacing:.04em}
.role-badge.role-buyer{background:#e3f1ff;color:#0055cc}
.role-badge.role-seller{background:#e8f5e9;color:#2e7d32}
.role-badge.role-admin{background:#fce4ec;color:#c62828}

.tag{display:inline-flex;align-items:center;gap:4px;font-size:.75rem;font-weight:600;padding:3px 10px;border-radius:20px;background:#f0f2f5;color:var(--text-secondary)}
.tag-auto{background:#e3f1ff;color:var(--primary)}
.tag-manual{background:#fff3e0;color:#e65100}
.tag-stock{background:#e8f5e9;color:#2e7d32}
.tag-out{background:#ffebee;color:var(--red)}

.loader-sm{width:28px;height:28px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite;margin:20px auto}
@keyframes spin{to{transform:rotate(360deg)}}

.status-created{background:#f0f2f5;color:#555}
.status-paid{background:#e3f1ff;color:var(--primary)}
.status-progress{background:#fff3e0;color:#e65100}
.status-done{background:#e8f5e9;color:#2e7d32}
.status-arb{background:#fce4ec;color:var(--red)}
.status-cancel{background:#f5f5f5;color:#999}

.section-title{font-size:1.25rem;font-weight:700;margin-bottom:20px}
.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.section-header .section-title{margin-bottom:0}

.catalog-layout{display:grid;grid-template-columns:260px 1fr;gap:20px;max-width:1200px;margin:0 auto;padding:24px 20px}
.catalog-sidebar{position:sticky;top:20px;height:fit-content}
.filter-card h3{font-size:1rem;font-weight:700;margin-bottom:16px}
.catalog-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.catalog-title{font-size:1.4rem;font-weight:700}
.catalog-sort{display:flex;align-items:center;gap:12px}
.catalog-sort select{width:auto}
.catalog-count{font-size:.82rem;color:var(--text-secondary)}

.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}
.product-grid-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:box-shadow .2s,transform .15s;display:flex;flex-direction:column}
.product-grid-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.product-grid-img{aspect-ratio:16/9;overflow:hidden;background:#f0f2f5}
.product-grid-img img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.product-grid-card:hover .product-grid-img img{transform:scale(1.04)}
.product-grid-body{padding:14px;flex:1;display:flex;flex-direction:column;gap:8px}
.product-grid-title{font-weight:600;font-size:.9rem;color:var(--text);line-height:1.3}
.product-grid-tags{display:flex;flex-wrap:wrap;gap:4px}
.product-grid-price{margin-top:auto;display:flex;align-items:baseline;gap:8px}
.product-grid-price .p-main{font-size:1.05rem;font-weight:700;color:var(--text)}
.product-grid-price .p-old{font-size:.8rem;color:#bbb;text-decoration:line-through}
.product-grid-price .p-new{font-size:1.05rem;font-weight:700;color:var(--primary)}
.product-grid-footer{padding:12px 14px;border-top:1px solid var(--border)}

.pagination{display:flex;justify-content:center;gap:8px;margin-top:24px}
.pagination button{min-width:36px;height:36px;border:1px solid var(--border);background:#fff;border-radius:var(--radius-sm);cursor:pointer;font-family:inherit;font-weight:600;font-size:.85rem;transition:all .2s}
.pagination button.active,.pagination button:hover{background:var(--primary);color:#fff;border-color:var(--primary)}

.product-layout{display:grid;grid-template-columns:1fr 300px;gap:24px;max-width:1100px;margin:0 auto;padding:24px 20px}
.product-card{padding:0;overflow:hidden}
.product-img{width:100%;max-height:380px;object-fit:cover}
.product-body{padding:24px}
.product-breadcrumbs{font-size:.8rem;color:var(--text-secondary);margin-bottom:12px}
.product-breadcrumbs a{color:var(--text-secondary)}.product-breadcrumbs a:hover{color:var(--primary)}
.product-breadcrumbs span{margin:0 6px}
.product-title{font-size:1.5rem;font-weight:700;margin-bottom:12px}
.product-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:20px}
.product-desc,.product-howto{margin-bottom:20px}
.product-desc h3,.product-howto h3,.product-reviews h3{font-size:1rem;font-weight:700;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--border)}
.product-desc p,.product-howto p{color:var(--text-secondary);font-size:.9rem;line-height:1.7}
.product-buy-card{position:sticky;top:20px}
.product-price-block{margin-bottom:16px}
.price-main{font-size:1.8rem;font-weight:700}
.price-new{font-size:1.8rem;font-weight:700;color:var(--primary)}
.price-old{font-size:1rem;color:#bbb;text-decoration:line-through;margin-right:8px}
.price-discount{background:var(--red);color:#fff;font-size:.72rem;font-weight:700;padding:2px 8px;border-radius:20px;vertical-align:middle}
.escrow-notice{display:flex;align-items:center;gap:6px;font-size:.78rem;color:var(--text-secondary);margin-top:12px;padding:10px;background:#f0f7ff;border-radius:var(--radius-sm)}
.seller-card{margin-top:12px}
.seller-card h4{font-weight:700;margin-bottom:12px}
.seller-info{display:flex;gap:12px;align-items:flex-start}
.seller-avatar{border-radius:50%;width:48px;height:48px;object-fit:cover}
.seller-name{font-weight:600}
.seller-meta{font-size:.8rem;color:var(--text-secondary);margin-top:2px}

.check-group{display:flex;flex-direction:column;gap:8px}
.check-label{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:.875rem;user-select:none;position:relative;padding-left:26px}
.check-label input[type=checkbox]{position:absolute;opacity:0;width:0;height:0;pointer-events:none}
.check-label::before{content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);width:18px;height:18px;border:2px solid var(--border);border-radius:5px;background:var(--bg-card);transition:background .15s,border-color .15s}
.check-label:has(input:checked)::before{background:var(--primary);border-color:var(--primary);background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 12 10' xmlns='http://www.w3.org/2000/svg'%3E%3Cpolyline points='1 5 4.5 8.5 11 1' stroke='%23fff' stroke-width='2' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C%2Fsvg%3E");background-size:70%;background-repeat:no-repeat;background-position:center}
.search-input-wrap{position:relative}.search-input-wrap input{padding-right:36px}
.search-input-wrap svg{position:absolute;right:12px;top:50%;transform:translateY(-50%);color:var(--text-secondary);pointer-events:none}

.dash-layout{display:grid;grid-template-columns:260px 1fr;min-height:calc(100vh - 60px);max-width:1200px;margin:0 auto;padding:24px 20px;gap:20px}
.dash-sidebar{position:sticky;top:20px;height:fit-content;display:flex;flex-direction:column;gap:12px}
.dash-profile{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:20px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:10px}
.dash-avatar-wrap{position:relative}
.dash-avatar{width:72px;height:72px;border-radius:50%;object-fit:cover;border:3px solid var(--border)}
.dash-user-info{display:flex;flex-direction:column;gap:6px}
.dash-user-info strong{font-size:.95rem}
.dash-balance{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:16px;display:flex;flex-direction:column;gap:8px}
.balance-item{display:flex;justify-content:space-between;align-items:center}
.balance-label{font-size:.82rem;color:var(--text-secondary)}
.balance-val{font-weight:700;font-size:.95rem}
.balance-item.hold .balance-val{color:var(--orange)}
.dash-nav{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.dash-nav-item{display:flex;align-items:center;gap:10px;padding:12px 16px;color:var(--text-secondary);font-size:.875rem;font-weight:500;transition:background .2s,color .2s;border-left:3px solid transparent}
.dash-nav-item:hover{background:#f5f7fa;color:var(--text)}
.dash-nav-item.active{background:#f0f7ff;color:var(--primary);border-left-color:var(--primary);font-weight:600}
.dash-section{display:none}.dash-section.active{display:block}
.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;margin-bottom:24px}
.stat-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:16px;display:flex;align-items:center;gap:14px;position:relative}
.stat-icon{font-size:1.5rem}
.stat-val{font-size:1.1rem;font-weight:700}
.stat-label{font-size:.78rem;color:var(--text-secondary);margin-top:2px}
.stat-card .btn-icon{position:absolute;right:10px;top:10px}

.orders-table{width:100%;border-collapse:collapse}
.orders-table th,.orders-table td{padding:10px 14px;text-align:left;font-size:.85rem;border-bottom:1px solid var(--border)}
.orders-table th{font-weight:700;color:var(--text-secondary);background:#fafbfc}
.orders-table tr:hover td{background:#fafbfc}
.order-status-badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:.75rem;font-weight:700}
.user-mini{display:flex;align-items:center;gap:6px;font-size:.85rem}
.user-mini img{border-radius:50%;object-fit:cover}
.buyer-list{display:flex;flex-direction:column;gap:8px;margin-top:8px}
.buyer-row{display:flex;align-items:center;gap:10px;padding:8px;border-radius:8px;background:#fafbfc}
.buyer-row img{width:32px;height:32px;border-radius:50%;object-fit:cover}

.recent-orders-wrap{margin-top:8px}
.recent-orders-wrap h3{font-size:1rem;font-weight:700;margin-bottom:12px}

.ref-card{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.ref-promo-block{display:flex;flex-direction:column;gap:10px}
.ref-promo-label{font-size:.82rem;color:var(--text-secondary);font-weight:600}
.ref-promo-val{font-size:1.6rem;font-weight:700;font-family:monospace;letter-spacing:.15em;color:var(--primary)}
.ref-promo-link{font-size:.78rem;color:var(--text-secondary);word-break:break-all;background:#f5f7fa;padding:8px;border-radius:8px}
.ref-levels{display:flex;flex-direction:column;gap:8px}
.ref-levels h4{font-weight:700;margin-bottom:4px}
.ref-level-row{display:flex;align-items:center;gap:10px}
.ref-level-num{font-size:.78rem;color:var(--text-secondary);width:70px;flex-shrink:0}
.ref-level-bar{flex:1;height:6px;background:#edeef0;border-radius:3px;overflow:hidden}
.ref-level-bar div{height:100%;background:var(--primary);border-radius:3px;transition:width .5s}
.ref-level-pct{font-size:.78rem;font-weight:700;width:32px;text-align:right}
.ref-note{font-size:.78rem;color:var(--text-secondary);margin-top:8px}

.payout-card{display:flex;flex-direction:column;gap:16px}
.card-save-row{display:flex;gap:10px}
.card-save-row input{flex:1}
.payout-notice{display:flex;align-items:center;gap:8px;font-size:.82rem;color:var(--text-secondary);background:#fff8e1;padding:10px;border-radius:8px}
.deposit-method-group{display:flex;gap:10px;margin-bottom:8px}
.deposit-method-opt{flex:1;display:flex;align-items:center;gap:10px;padding:10px 14px;border:2px solid var(--border);border-radius:10px;cursor:pointer;transition:border-color .15s,background .15s;font-size:.9rem}
.deposit-method-opt input[type="radio"]{width:16px;height:16px;accent-color:var(--primary);flex-shrink:0}
.deposit-method-opt.active{border-color:var(--primary);background:rgba(0,119,255,.06)}
.deposit-method-name{font-weight:600}
.deposit-method-notice{font-size:.82rem;color:var(--text-secondary);padding:6px 10px;background:rgba(0,119,255,.06);border-radius:8px;border-left:3px solid var(--primary)}

.profile-form-card .avatar-upload{display:flex;align-items:center;gap:16px;margin-bottom:20px}
.avatar-preview{width:72px;height:72px;border-radius:50%;object-fit:cover;border:2px solid var(--border)}
.avatar-upload-btn{font-size:.82rem;font-weight:600;color:var(--primary);cursor:pointer;padding:8px 16px;border:1px solid var(--primary);border-radius:8px;transition:background .2s}
.avatar-upload-btn:hover{background:rgba(0,119,255,.07)}

.order-layout{display:grid;grid-template-columns:300px 1fr;gap:20px;max-width:1100px;margin:0 auto;padding:24px 20px;align-items:flex-start}
.order-sidebar{position:sticky;top:20px}
.order-info-card h3{font-size:1.1rem;font-weight:700;margin-bottom:12px}
.order-detail-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border);font-size:.85rem}
.order-detail-row:last-child{border-bottom:none}
.order-detail-row span:first-child{color:var(--text-secondary)}
.order-actions{display:flex;flex-direction:column;gap:8px;margin-top:16px}
.arb-notice{background:#fff8e1;border-left:3px solid var(--orange);padding:10px;border-radius:0 8px 8px 0;font-size:.82rem;margin-top:12px;display:flex;gap:6px}
.delivered-data{margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}
.delivered-label{font-size:.82rem;font-weight:600;color:var(--text-secondary);margin-bottom:8px}
.key-box{background:#f5f7fa;border:1px dashed var(--border);border-radius:8px;padding:12px;font-family:monospace;font-size:.9rem;word-break:break-all;margin-bottom:8px}

.chat-header{display:flex;align-items:center;gap:10px;padding:16px 20px;background:var(--white);border:1px solid var(--border);border-radius:var(--radius) var(--radius) 0 0;font-weight:700;font-size:.95rem}
.chat-messages{background:var(--white);border-left:1px solid var(--border);border-right:1px solid var(--border);min-height:420px;max-height:540px;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}
.chat-message{display:flex;gap:10px;align-items:flex-end}
.chat-message.own{flex-direction:row-reverse}
.chat-bubble{max-width:70%;background:#f0f2f5;border-radius:14px 14px 14px 4px;padding:10px 14px;font-size:.875rem;line-height:1.5}
.chat-message.own .chat-bubble{background:var(--primary);color:#fff;border-radius:14px 14px 4px 14px}
.chat-message.system .chat-bubble{background:#fff8e1;border:1px solid #ffd54f;border-radius:10px;color:#795548;font-size:.8rem;font-style:italic;max-width:90%;margin:0 auto}
.chat-msg-avatar{width:30px;height:30px;border-radius:50%;object-fit:cover;flex-shrink:0}
.chat-msg-meta{font-size:.7rem;color:var(--text-secondary);margin-top:4px}
.chat-message.own .chat-msg-meta{text-align:right}
.chat-input-wrap{background:var(--white);border:1px solid var(--border);border-radius:0 0 var(--radius) var(--radius);border-top:none;padding:12px;display:flex;gap:10px;align-items:flex-end}
.chat-input{flex:1;resize:none;border-radius:10px;min-height:42px;max-height:120px}
.chat-closed{background:var(--white);border:1px solid var(--border);border-top:none;border-radius:0 0 var(--radius) var(--radius);padding:14px;text-align:center;color:var(--text-secondary);font-size:.85rem}

.products-manage-grid{display:grid;gap:12px}
.product-manage-row{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:16px;display:flex;align-items:center;gap:16px}
.product-manage-thumb{width:60px;height:60px;border-radius:8px;object-fit:cover;background:#f0f2f5;flex-shrink:0}
.product-manage-info{flex:1}
.product-manage-title{font-weight:600;font-size:.9rem}
.product-manage-meta{display:flex;gap:10px;margin-top:4px;flex-wrap:wrap;align-items:center}
.product-manage-actions{display:flex;gap:8px;flex-shrink:0}

.modal-actions{display:flex;gap:10px;margin-top:16px;justify-content:flex-end}

@media(max-width:900px){
    .dash-layout{grid-template-columns:1fr}
    .dash-sidebar{position:static}
    .catalog-layout{grid-template-columns:1fr}
    .catalog-sidebar{position:static}
    .product-layout{grid-template-columns:1fr}
    .order-layout{grid-template-columns:1fr}
    .ref-card{grid-template-columns:1fr}
    .form-row{grid-template-columns:1fr}
}
@media(max-width:600px){
    .stats-grid{grid-template-columns:1fr 1fr}
    .products-grid{grid-template-columns:1fr}
    body{font-size:14px}
}

.reviews-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.review-card{background:#fafbfc;border:1px solid var(--border);border-radius:var(--radius);padding:16px;display:flex;flex-direction:column;gap:10px}
.review-header{display:flex;align-items:flex-start;gap:10px}
.review-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;flex-shrink:0}
.review-name{font-weight:600;font-size:.875rem}
.review-stars{font-size:.9rem;line-height:1;margin-top:2px}
.review-date{font-size:.75rem;color:var(--text-secondary);margin-left:auto;white-space:nowrap}
.review-text{font-size:.85rem;color:var(--text-secondary);line-height:1.6;margin:0;word-break:break-word;overflow-wrap:break-word}
#recent-orders-list,#orders-list{overflow-x:auto}

.recently-viewed-scroll{}
.recently-viewed-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}
.recently-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:box-shadow .2s,transform .15s}
.recently-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.recently-thumb{aspect-ratio:16/9;overflow:hidden;background:#f0f2f5}
.recently-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.recently-card:hover .recently-thumb img{transform:scale(1.05)}
.recently-body{padding:10px}
.recently-title{font-size:.78rem;font-weight:600;color:var(--text);margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.recently-price{font-size:.82rem;font-weight:700;color:var(--primary)}

.seller-info-link{display:flex;align-items:center;gap:12px;text-decoration:none;color:inherit;border-radius:var(--radius-sm);padding:8px;margin:-8px;transition:background .2s}
.seller-info-link:hover{background:#f5f7fa}

/* Карточка-обёртка с сердечком */
.product-card-wrap{position:relative}
.fav-btn{position:absolute;top:8px;right:8px;z-index:2;width:32px;height:32px;border-radius:50%;border:none;background:rgba(255,255,255,.9);backdrop-filter:blur(4px);cursor:pointer;display:flex;align-items:center;justify-content:center;color:#e64646;transition:background .2s,transform .15s;box-shadow:0 1px 4px rgba(0,0,0,.12)}
.fav-btn:hover{background:#fff;transform:scale(1.1)}
.fav-btn svg{pointer-events:none}
.fav-btn.fav-active{background:#fff0f0}

/* Кнопка "В избранное" на странице товара */
.btn-fav-product{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:10px 16px;border:1px solid var(--border);border-radius:var(--radius-sm);background:#fff;color:var(--text-secondary);font-family:inherit;font-size:.875rem;font-weight:600;cursor:pointer;transition:border-color .2s,color .2s,background .2s;margin-top:8px}
.btn-fav-product:hover{border-color:#e64646;color:#e64646;background:#fff5f5}
.btn-fav-product.fav-active{border-color:#e64646;color:#e64646;background:#fff0f0}
.btn-fav-product svg{pointer-events:none}

/* Онлайн-статус */
.online-status{display:inline-flex;align-items:center;gap:5px;font-size:.78rem}
.online-dot{width:8px;height:8px;border-radius:50%;background:#ccc;flex-shrink:0;display:inline-block}
.online-status.is-online .online-dot{background:#4caf50;box-shadow:0 0 0 2px rgba(76,175,80,.25)}
.online-status.is-online{color:#2e7d32}

/* Реферальные уровни — ширина метки */
.ref-level-num{width:auto;min-width:140px}

.img-upload-area{border:2px dashed var(--border);border-radius:var(--radius-sm);padding:20px;cursor:pointer;transition:border-color .2s;position:relative;text-align:center}
.img-upload-area:hover{border-color:var(--primary)}
.img-upload-area input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}
.img-upload-placeholder{display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--text-secondary);font-size:.85rem;pointer-events:none}

.dash-nav-logout:hover{background:#fff0f0 !important;color:var(--red) !important}

#reset-filters{margin-top:10px}

.order-page-wrap{max-width:900px;margin:0 auto;padding:24px 20px;display:flex;flex-direction:column;gap:16px}
.order-breadcrumb{display:flex;align-items:center;gap:6px;font-size:.82rem;color:var(--text-secondary)}
.order-breadcrumb a{color:var(--primary)}
.order-header-card{}
.order-header-top{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:12px}
.order-title{font-size:1.2rem;font-weight:700;margin:0}
.order-header-meta{display:flex;align-items:center;gap:16px;flex-wrap:wrap;font-size:.875rem;color:var(--text-secondary)}
.order-users{display:flex;align-items:center;gap:8px}
.order-key-card{}
.key-card-label{display:flex;align-items:center;gap:8px;font-weight:600;font-size:.875rem;margin-bottom:10px;color:var(--primary)}
.key-box{font-family:monospace;font-size:.9rem;padding:12px 14px;background:#f8f9fa;border:1px solid var(--border);border-radius:var(--radius-sm);word-break:break-all;margin-bottom:10px;white-space:pre-wrap}
.order-chat-card{padding:0;overflow:hidden}
.order-chat-header{padding:14px 16px;border-bottom:1px solid var(--border);font-size:.875rem;font-weight:600;display:flex;align-items:center;gap:8px;color:var(--text-secondary)}
.chat-messages{height:480px;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}
.chat-message{display:flex;gap:10px;align-items:flex-start;max-width:75%}
.chat-message.own{align-self:flex-end;flex-direction:row-reverse}
.chat-message.system{max-width:100%;align-self:center}
.chat-bubble{background:#f0f2f5;border-radius:12px 12px 12px 3px;padding:10px 14px;font-size:.875rem;word-break:break-word;line-height:1.5}
.chat-message.own .chat-bubble{background:var(--primary);color:#fff;border-radius:12px 12px 3px 12px}
.chat-message.system .chat-bubble{background:transparent;color:var(--text-secondary);font-size:.78rem;text-align:center;border-radius:20px;padding:5px 14px;border:1px solid var(--border)}
.chat-msg-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover;flex-shrink:0;margin-top:2px}
.chat-msg-meta{font-size:.7rem;color:var(--text-secondary);margin-top:5px;display:flex;align-items:center;gap:4px}
.chat-message.own .chat-msg-meta{justify-content:flex-end}
.chat-admin-badge{background:var(--orange);color:#fff;font-size:.62rem;font-weight:700;padding:1px 6px;border-radius:10px;text-transform:uppercase;letter-spacing:.03em}
.chat-input-wrap{display:flex;gap:10px;padding:12px 16px;border-top:1px solid var(--border);align-items:flex-end}
.chat-input{min-height:44px;max-height:120px;resize:none;font-size:.875rem;margin-bottom:0}
.chat-send-btn-icon{flex-shrink:0;width:44px;height:44px;padding:0;border-radius:var(--radius-sm)}
.chat-closed-notice{padding:14px 16px;text-align:center;color:var(--text-secondary);font-size:.82rem;display:flex;align-items:center;justify-content:center;gap:8px;border-top:1px solid var(--border)}
.order-actions-bar{display:flex;gap:12px;flex-wrap:wrap}
.btn-action{flex:1;min-width:180px;padding:13px 20px;font-size:.9rem}
.arb-notice-card{display:flex;align-items:center;gap:8px;font-size:.875rem;color:var(--orange);border-left:3px solid var(--orange)}
.review-form-title{font-size:1rem;font-weight:700;margin-bottom:12px}
.star-rating{display:flex;gap:4px}
.star-rating .star{font-size:2rem;cursor:pointer;color:#d1d5db;transition:color .15s;line-height:1}
.star-rating .star.active{color:var(--primary)}
.order-review-done{display:flex;align-items:center;gap:8px;color:var(--green);font-size:.875rem}
.product-grid-rating{display:flex;align-items:center;gap:2px;margin-top:6px;font-size:.82rem}
.product-grid-rating-meta{color:var(--text-secondary);font-size:.75rem;margin-left:4px}
.star-display{display:inline-flex;align-items:center;gap:2px;font-size:.9rem}
.star-display-meta{color:var(--text-secondary);font-size:.8rem;margin-left:4px}
.product-buy-rating{margin-top:10px;font-size:.875rem}
.unread-badge{display:inline-flex;align-items:center;justify-content:center;background:var(--red);color:#fff;font-size:.62rem;font-weight:700;min-width:16px;height:16px;border-radius:8px;padding:0 4px;margin-left:5px;vertical-align:middle}

@media(max-width:760px){
    .reviews-grid{grid-template-columns:1fr}
    .order-actions-bar{flex-direction:column}
    .btn-action{min-width:unset}
    .chat-messages{height:340px}
}

.mkt-search-widget{position:relative;width:100%}
.mkt-search-bar{display:flex;align-items:center;background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius);padding:0 14px;gap:10px;transition:border-color .15s}
.mkt-search-bar:focus-within{border-color:var(--primary)}
.mkt-search-icon{color:var(--text-secondary);flex-shrink:0}
.mkt-search-input{flex:1;border:none;background:transparent;outline:none;padding:12px 0;font-size:.9rem;color:var(--text-primary)}
.mkt-search-dropdown{position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius);box-shadow:0 8px 24px rgba(0,0,0,.12);z-index:200;overflow:hidden}
.mkt-search-section{padding:12px 14px;border-bottom:1px solid var(--border)}
.mkt-search-section:last-child{border-bottom:none}
.mkt-search-section-title{font-size:.72rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px}
.mkt-search-results{max-height:230px;overflow-y:auto}
.mkt-search-result-item{display:flex;align-items:center;gap:10px;padding:7px 4px;border-radius:6px;text-decoration:none;color:var(--text-primary);transition:background .12s}
.mkt-search-result-item:hover{background:var(--bg-hover)}
.mkt-sr-thumb{width:36px;height:36px;border-radius:6px;object-fit:cover;flex-shrink:0;background:var(--bg-hover);display:flex;align-items:center;justify-content:center;font-size:1rem}
.mkt-sr-thumb-placeholder{display:flex;align-items:center;justify-content:center}
.mkt-sr-title{flex:1;font-size:.875rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mkt-sr-price{font-size:.82rem;font-weight:600;color:var(--primary);flex-shrink:0}
.mkt-search-empty,.mkt-search-loading{color:var(--text-secondary);font-size:.82rem;padding:4px 0}
.mkt-search-recent-list{display:flex;flex-direction:column;gap:2px}
.mkt-search-recent-item{font-size:.85rem;color:var(--text-primary);text-decoration:none;padding:5px 4px;border-radius:6px;transition:background .12s;display:flex;align-items:center;gap:6px}
.mkt-search-recent-item::before{content:'🕐';font-size:.75rem}
.mkt-search-recent-item:hover{background:var(--bg-hover)}
.mkt-search-cats{display:flex;flex-wrap:wrap;gap:6px}
.mkt-search-cat{display:inline-flex;padding:4px 12px;background:var(--bg-hover);border-radius:20px;font-size:.8rem;color:var(--text-primary);text-decoration:none;transition:background .12s}
.mkt-search-cat:hover{background:var(--primary);color:#fff}
.product-manage-preview-link{color:var(--text-primary);text-decoration:none;font-weight:600}
.product-manage-preview-link:hover{color:var(--primary)}

.balance-log-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:11px 0;border-bottom:1px solid var(--border)}
.balance-log-row:last-child{border-bottom:none}
.balance-log-main{display:flex;flex-direction:column;gap:2px;min-width:0}
.balance-log-label{font-size:.875rem;font-weight:600;color:var(--text-primary)}
.balance-log-msg{font-size:.78rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.balance-log-right{display:flex;flex-direction:column;align-items:flex-end;gap:2px;flex-shrink:0}
.blog-amount{font-size:.9rem;font-weight:700;white-space:nowrap}
.log-green{color:var(--green)}
.log-red{color:var(--red)}
.balance-log-date{font-size:.75rem;color:var(--text-secondary);white-space:nowrap}
