/* ============================================================
   SmartPay Service — Main CSS
   ============================================================ */
:root{
    --bg:#f6f8fc;
    --bg-card:#ffffff;
    --bg-card2:#f2f4fa;
    --bg-input:#ffffff;
    --border:rgba(15,23,42,.10);
    --orange:#da9256;
    --orange-g:rgba(218,146,86,.22);
    --green:#0bb07b;
    --red:#e05252;
    --text:#0f172a;
    --muted:#5b647a;
    --shadow:0 14px 40px rgba(15,23,42,.10);
    --shadow-soft:0 10px 24px rgba(15,23,42,.08);
    --radius:14px;
    --radius-s:8px;
}

:root[data-theme="dark"]{
    --bg:#0f1117;
    --bg-card:#181b27;
    --bg-card2:#1e2132;
    --bg-input:#252838;
    --border:rgba(255,255,255,.07);
    --orange:#da9256;
    --orange-g:rgba(218,146,86,.30);
    --green:#0bb07b;
    --red:#e05252;
    --text:#e8eaf0;
    --muted:#8a90a8;
    --shadow:0 16px 48px rgba(0,0,0,.45);
    --shadow-soft:0 12px 34px rgba(0,0,0,.32);
}

@media (prefers-color-scheme: dark){
  :root:not([data-theme]){
    --bg:#0f1117;
    --bg-card:#181b27;
    --bg-card2:#1e2132;
    --bg-input:#252838;
    --border:rgba(255,255,255,.07);
    --orange:#da9256;
    --orange-g:rgba(218,146,86,.30);
    --green:#0bb07b;
    --red:#e05252;
    --text:#e8eaf0;
    --muted:#8a90a8;
    --shadow:0 16px 48px rgba(0,0,0,.45);
    --shadow-soft:0 12px 34px rgba(0,0,0,.32);
  }
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{background:var(--bg);color:var(--text);transition:background-color .2s,color .2s;font-family:'Manrope','Segoe UI',system-ui,-apple-system,BlinkMacSystemFont,'Helvetica Neue',Arial,sans-serif;min-height:100vh;line-height:1.6}
a{color:var(--orange);text-decoration:none}
a:hover{text-decoration:underline}

/* ── LAYOUT ── */
.sp-layout{display:flex;min-height:100vh}
.sp-sidebar{width:240px;background:var(--bg-card);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;position:sticky;top:0;height:100vh;overflow-y:auto}
.sp-logo{padding:24px 20px 16px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border)}
.sp-logo-icon{width:36px;height:36px;background:linear-gradient(135deg,var(--orange),#b86e2e);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.sp-logo-text{font-size:16px;font-weight:800;letter-spacing:-.3px}
.sp-logo-version{font-size:10px;color:var(--muted);margin-top:1px}
.sp-nav{padding:12px 0;flex:1}
.sp-nav-item{display:flex;align-items:center;gap:10px;padding:11px 20px;color:var(--muted);font-size:13px;font-weight:600;transition:all .18s;border-left:3px solid transparent}
.sp-nav-item:hover{color:var(--text);background:rgba(255,255,255,.03);text-decoration:none}
.sp-nav-item.active{color:var(--orange);border-left-color:var(--orange);background:rgba(218,146,86,.06)}
.sp-nav-item i{font-size:17px;flex-shrink:0}
.sp-nav-section{padding:8px 20px 4px;font-size:10px;text-transform:uppercase;letter-spacing:.8px;color:var(--muted);margin-top:8px}
.sp-main{flex:1;display:flex;flex-direction:column;overflow:auto}
.sp-topbar{background:var(--bg-card);border-bottom:1px solid var(--border);padding:14px 28px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.sp-topbar-title{font-size:18px;font-weight:700}
.sp-content{padding:28px;max-width:none;width:100%}
.sp-merchant-info{display:flex;align-items:center;gap:12px}
.sp-merchant-name{font-size:13px;font-weight:600}
.sp-merchant-id{font-size:11px;color:var(--muted)}
.sp-mobile-menu-btn{display:none;width:36px;height:36px;border-radius:10px;border:1px solid var(--border);background:var(--bg-input);color:var(--text);font-size:21px;align-items:center;justify-content:center;cursor:pointer}
.sp-mobile-menu-close{display:none;margin-left:auto;width:34px;height:34px;border-radius:9px;border:1px solid var(--border);background:var(--bg-input);color:var(--text);font-size:20px;align-items:center;justify-content:center;cursor:pointer}

/* ── CARD ── */
.sp-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:24px;position:relative;overflow:hidden}
.sp-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--orange),transparent);opacity:.6}
.sp-card-head{display:flex;align-items:center;gap:10px;margin-bottom:20px}
.sp-card-head i{font-size:20px;color:var(--orange)}
.sp-card-head .title{font-size:15px;font-weight:700}
.sp-card-head .sub{font-size:12px;color:var(--muted);margin-top:2px}
.sp-stats{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:24px}
.sp-stat{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-s);padding:16px 18px}
.sp-stat-label{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted)}
.sp-stat-value{font-size:24px;font-weight:800;margin-top:4px}

/* ── FORM ── */
.sp-field{margin-bottom:16px}
.sp-field label{display:block;font-size:12px;color:var(--muted);margin-bottom:7px;font-weight:600;letter-spacing:.3px;text-transform:uppercase}
.sp-input{width:100%;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-s);color:var(--text);font-size:14px;padding:12px 14px;outline:none;transition:border-color .2s,box-shadow .2s,background-color .2s,color .2s;font-family:inherit}
.sp-input:hover{border-color:rgba(15,23,42,.18)}
.sp-input:focus{border-color:var(--orange);box-shadow:0 0 0 3px var(--orange-g)}
.sp-input:focus-visible{outline:none}
.sp-input:disabled{background:var(--bg-card2);color:var(--muted);cursor:not-allowed;opacity:.85}
.sp-input[readonly]{background:var(--bg-card2);color:var(--text)}
.sp-input::placeholder{color:var(--muted)}
.sp-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%238a90a8' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14L2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:calc(100% - 14px) center;padding-right:40px}
.sp-select:disabled{background:var(--bg-card2);color:var(--muted);cursor:not-allowed}
.sp-hint{font-size:11px;color:var(--muted);margin-top:5px}

/* ── CHECKBOX & RADIO ── */
input[type="checkbox"],input[type="radio"]{accent-color:var(--orange)}
input[type="checkbox"]:focus-visible,input[type="radio"]:focus-visible{outline:none;box-shadow:0 0 0 3px var(--orange-g)}
input[type="checkbox"]:disabled,input[type="radio"]:disabled{filter:grayscale(.3);opacity:.7;cursor:not-allowed}
label>input[type="checkbox"],label>input[type="radio"]{margin-right:6px}

/* ── BUTTON ── */
.sp-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:linear-gradient(135deg,var(--orange),#b86e2e);color:#fff;border:none;border-radius:var(--radius-s);padding:12px 22px;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s;box-shadow:0 4px 14px var(--orange-g);font-family:inherit}
.sp-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px var(--orange-g)}
.sp-btn:active{transform:translateY(0)}
.sp-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}
.sp-btn-sm{padding:8px 14px;font-size:12px}
.sp-btn-ghost{background:var(--bg-input);color:var(--text);box-shadow:none;border:1px solid var(--border)}
.sp-btn-ghost:hover{border-color:var(--orange);color:var(--orange);box-shadow:none;transform:none}
.sp-btn-danger{background:linear-gradient(135deg,var(--red),#a03030)}
.sp-btn-success{background:linear-gradient(135deg,var(--green),#08845c)}
.sp-btn-w100{width:100%}

/* ── TABLE ── */
.sp-table{width:100%;border-collapse:collapse}
.sp-table th{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);font-weight:600;padding:10px 14px;border-bottom:1px solid var(--border);text-align:left}
.sp-table td{padding:12px 14px;border-bottom:1px solid var(--border);font-size:13px;vertical-align:middle}
.sp-table tr:last-child td{border-bottom:none}
.sp-table tr:hover td{background:rgba(218,146,86,.06)}

/* ── BADGE ── */
.sp-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700;letter-spacing:.4px;text-transform:uppercase}
.sp-badge-pending{background:rgba(218,146,86,.12);color:var(--orange);border:1px solid rgba(218,146,86,.3)}
.sp-badge-paid{background:rgba(11,176,123,.12);color:var(--green);border:1px solid rgba(11,176,123,.3)}
.sp-badge-rejected{background:rgba(224,82,82,.12);color:var(--red);border:1px solid rgba(224,82,82,.3)}
.sp-badge-expired{background:rgba(138,144,168,.12);color:var(--muted);border:1px solid rgba(138,144,168,.28)}
.sp-badge-checking,.sp-badge-awaiting{background:rgba(100,150,255,.12);color:#7ba4ff;border:1px solid rgba(100,150,255,.3)}

/* ── AUTH PAGES ── */
.sp-auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:var(--bg);background-image:radial-gradient(ellipse 80% 50% at 50% -10%,rgba(218,146,86,.12) 0%,transparent 70%)}
.sp-auth-card{width:100%;max-width:420px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:36px;box-shadow:0 16px 48px rgba(0,0,0,.5)}
.sp-auth-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--orange),transparent)}
.sp-auth-logo{text-align:center;margin-bottom:28px}
.sp-auth-logo .icon{width:56px;height:56px;background:linear-gradient(135deg,var(--orange),#b86e2e);border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:26px;margin:0 auto 12px;box-shadow:0 6px 20px var(--orange-g)}
.sp-auth-logo h1{font-size:22px;font-weight:800}
.sp-auth-logo p{font-size:13px;color:var(--muted);margin-top:4px}
.sp-divider{display:flex;align-items:center;gap:12px;margin:16px 0}
.sp-divider span{font-size:12px;color:var(--muted);white-space:nowrap}
.sp-divider::before,.sp-divider::after{content:'';flex:1;height:1px;background:var(--border)}

/* ── ALERTS ── */
.sp-alert{padding:12px 16px;border-radius:var(--radius-s);font-size:13px;margin-bottom:16px;display:flex;align-items:flex-start;gap:10px}
.sp-alert i{font-size:16px;flex-shrink:0;margin-top:1px}
.sp-alert-success{background:rgba(11,176,123,.1);border:1px solid rgba(11,176,123,.3);color:var(--green)}
.sp-alert-error{background:rgba(224,82,82,.1);border:1px solid rgba(224,82,82,.3);color:var(--red)}
.sp-alert-warning{background:rgba(218,146,86,.1);border:1px solid rgba(218,146,86,.3);color:var(--orange)}
.sp-alert-info{background:rgba(218,146,86,.08);border:1px solid rgba(218,146,86,.25);color:var(--orange)}

/* ── CODE BLOCK ── */
.sp-code{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-s);padding:14px 16px;font-family:'JetBrains Mono','SFMono-Regular',Consolas,'Liberation Mono',Menlo,monospace;font-size:12px;word-break:break-all;position:relative}
.sp-copy-btn,.sp-copy-inline{display:inline-flex;align-items:center;justify-content:center;gap:6px;background:rgba(218,146,86,.07);border:1px solid rgba(218,146,86,.22);color:var(--orange);border-radius:10px;padding:7px 12px;font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .18s;white-space:nowrap}
.sp-copy-btn{position:absolute;top:8px;right:8px;z-index:2}
.sp-copy-btn:hover,.sp-copy-inline:hover{background:rgba(218,146,86,.12);border-color:rgba(218,146,86,.35);color:#f0a96e}
.sp-copy-btn:active,.sp-copy-inline:active{transform:translateY(1px)}
.sp-copy-inline{margin-left:8px}

.sp-file-input{padding:8px 10px}
.sp-form-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-top:8px}
.sp-icon-uploader{background:linear-gradient(180deg,rgba(255,255,255,.02),rgba(255,255,255,.01));border:1px dashed rgba(218,146,86,.28);border-radius:12px;padding:12px}
.sp-icon-uploader-line{display:flex;align-items:center;justify-content:space-between;gap:12px}
.sp-file-name{font-size:14px;color:var(--muted)}
.sp-file-hidden{position:absolute;opacity:0;pointer-events:none;width:1px;height:1px}
.sp-upload-trigger{margin-left:0;margin-top:10px}
.sp-icon-current-box{width:54px;height:54px;border-radius:12px;background:rgba(218,146,86,.08);border:1px solid rgba(218,146,86,.25);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.sp-icon-preview{width:42px;height:42px;object-fit:cover;border-radius:10px;border:1px solid var(--border);background:var(--bg-card2);padding:4px}
.sp-icon-empty{font-size:20px;color:var(--muted);line-height:1}

/* ── IZI TOAST ACCENT COLORS ── */
.iziToast.sp-toast-success{background:#10241e!important;color:#35d6a2!important;border:1px solid #1f8c69!important}
.iziToast.sp-toast-success .iziToast-message,.iziToast.sp-toast-success .iziToast-title,.iziToast.sp-toast-success .iziToast-icon{color:var(--green)!important}

.iziToast.sp-toast-error{background:#2a1618!important;color:#ff7b7b!important;border:1px solid #8f3a40!important}
.iziToast.sp-toast-error .iziToast-message,.iziToast.sp-toast-error .iziToast-title,.iziToast.sp-toast-error .iziToast-icon{color:#ffb4b4!important}

.iziToast.sp-toast-warning{background:#2a2118!important;color:#ffbd86!important;border:1px solid #9e6a3f!important}
.iziToast.sp-toast-warning .iziToast-message,.iziToast.sp-toast-warning .iziToast-title,.iziToast.sp-toast-warning .iziToast-icon{color:var(--orange)!important}

.iziToast.sp-toast-info{background:#162131!important;color:#8fc1ff!important;border:1px solid #3d6f9d!important}
.iziToast.sp-toast-info .iziToast-message,.iziToast.sp-toast-info .iziToast-title,.iziToast.sp-toast-info .iziToast-icon{color:#93c5fd!important}

/* ── GRID ── */
.sp-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.sp-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}

/* ── TABS ── */
.sp-tabs{display:flex;gap:4px;background:var(--bg-input);border-radius:10px;padding:4px;margin-bottom:20px;width:fit-content}
.sp-tab{padding:8px 18px;border-radius:8px;font-size:13px;font-weight:600;color:var(--muted);cursor:pointer;transition:all .18s}
.sp-tab.active{background:var(--orange);color:#fff}

/* ── RESPONSIVE ── */
@media(max-width:768px){
    .sp-mobile-menu-btn{display:inline-flex}
    .sp-mobile-menu-close{display:inline-flex}
    .sp-sidebar{display:flex;position:fixed;left:-260px;top:0;z-index:60;transition:left .22s ease;box-shadow:0 20px 40px rgba(0,0,0,.45)}
    .sp-layout.sp-sidebar-open .sp-sidebar{left:0}
    .sp-content{padding:16px}
    .sp-grid-2,.sp-grid-3{grid-template-columns:1fr}
    .sp-topbar{padding:12px 14px}
    .sp-merchant-info{max-width:calc(100vw - 90px)}
    .sp-form-actions .sp-btn{width:100%;justify-content:center}

    /* Ensure page has comfortable padding on small screens */
    body{padding:12px}
    .sp-auth-wrap{padding:16px}

    /* Make nx-visual inner grid display single column on mobile (one block per row) */
    .nx-visual .nx-grid{grid-template-columns:1fr}

    /* Hide the "Защищенный режим" badge inside nx-visual on small screens */
    .nx-visual .nx-chip{display:none}
}


/* ── THEME TOGGLE ── */
.sp-theme-btn{width:40px;height:40px;border-radius:12px;border:1px solid var(--border);background:var(--bg-input);color:var(--text);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .18s,border-color .18s,background-color .18s,color .18s}
.sp-theme-btn:hover{transform:translateY(-1px);border-color:rgba(218,146,86,.35)}
.sp-theme-btn:active{transform:translateY(0)}
.sp-theme-btn i{font-size:18px}


/* ── PUBLIC THEME TOGGLE (FAB) ── */
.sp-theme-fab{position:fixed;top:calc(16px + env(safe-area-inset-top));right:calc(16px + env(safe-area-inset-right));z-index:9999;width:42px;height:42px;border-radius:14px;border:1px solid var(--border);background:var(--bg-card);box-shadow:var(--shadow-soft);color:var(--text);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .18s,border-color .18s,background-color .18s,color .18s}
.sp-theme-fab:hover{transform:translateY(-1px);border-color:rgba(218,146,86,.35)}
.sp-theme-fab:active{transform:translateY(0)}
.sp-theme-fab i{font-size:18px}
@media(max-width:768px){.sp-theme-fab{top:calc(12px + env(safe-area-inset-top));right:calc(12px + env(safe-area-inset-right))}}
