*{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#f6f3ef;--panel:#ffffff;--panel-soft:#fbf9f6;--line:#e6ddd2;--line-strong:#d9cdbf;
  --text:#1a2633;--text-soft:#647383;--text-muted:#8f9cab;
  --brand:#1f3b5b;--brand-soft:#edf2f8;--brand-mid:#d3deea;
  --accent:#d97828;--accent-soft:#fff1e6;
  --success:#18835b;--success-soft:#eaf7f1;--danger:#d94040;--warn:#a86a08;
  --premium:#8f6512;--premium-soft:#fff7e6;
  --shadow:0 10px 30px rgba(26,38,51,.06);
  --r-xl:22px;--r-lg:16px;--r-md:12px;--r-sm:10px;
}
html,body{height:100%;font-family:'Vazirmatn',sans-serif;background:var(--bg);color:var(--text)}
body{min-height:100vh}
button,input{font-family:'Vazirmatn',sans-serif}
.hide{display:none!important}
.toast-wrap{position:fixed;top:14px;left:50%;transform:translateX(-50%);z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none;width:min(92%,420px)}
.toast{display:flex;align-items:center;gap:8px;padding:12px 15px;border-radius:14px;box-shadow:0 12px 28px rgba(0,0,0,.14);pointer-events:auto;font-size:13px;font-weight:500;animation:slideDown .26s ease both;color:#fff}
.toast.err{background:rgba(217,64,64,.95)} .toast.ok{background:rgba(24,131,91,.95)} .toast.info{background:rgba(31,59,91,.95)} .toast.warn{background:rgba(168,106,8,.95)}
.toast .mi{font-size:18px}.toast.out{animation:fadeUp .22s ease forwards}
@keyframes slideDown{from{opacity:0;transform:translateY(-16px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeUp{to{opacity:0;transform:translateY(-8px)}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.fade-in{animation:fadeIn .24s ease both}
.portal-wrap{min-height:100vh;display:flex;flex-direction:column}
.top-header{position:sticky;top:0;z-index:40;background:rgba(255,255,255,.96);border-bottom:1px solid var(--line);padding:14px 18px;display:flex;align-items:center;justify-content:space-between;gap:16px}
.header-brand{display:flex;align-items:center;gap:12px}
.logo-circle{width:42px;height:42px;border-radius:14px;background:var(--brand);display:grid;place-items:center;color:#fff}
.logo-circle .mi{font-size:22px}
.brand-text h1{font-size:16px;font-weight:800;line-height:1.2;margin:0}
.brand-text p{font-size:12px;color:var(--text-soft);margin:2px 0 0}
.header-side{display:flex;flex-direction:column;align-items:flex-end;gap:8px}
.chips-toggle{display:none;align-items:center;gap:6px;background:#fff;border:1px solid var(--line);color:var(--brand);font-size:11px;font-weight:800;border-radius:999px;padding:7px 10px;cursor:pointer}
.header-chips{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.info-chip{display:flex;align-items:center;gap:9px;padding:8px 12px;border-radius:999px;background:#fff;border:1px solid var(--line);min-width:122px;transition:.18s}
.info-chip .chip-icon{font-size:16px;color:var(--accent)}
.info-chip .chip-label{font-size:10px;color:var(--text-muted);display:block;line-height:1.15}
.info-chip .chip-val{font-size:12px;font-weight:800;color:var(--text);display:block;line-height:1.45}
.info-chip.dim{opacity:.45}
.main-layout{display:grid;grid-template-columns:220px minmax(0,1fr);gap:14px;flex:1;padding:18px;width:min(100%,1220px);margin:0 auto;direction:rtl}
.sidebar,.side-summary,.ui-card{background:var(--panel);border:1px solid var(--line);box-shadow:var(--shadow)}
.sidebar{border-radius:22px;padding:16px 12px;align-self:start;position:sticky;top:82px}
.sidebar-title{font-size:11px;color:var(--text-muted);font-weight:800;margin-bottom:14px;padding-right:10px;letter-spacing:.4px}
.sn-item{display:flex;align-items:center;gap:10px;padding:10px;border-radius:14px;cursor:pointer;transition:.18s;user-select:none}.sn-item:hover{background:#faf7f3}
.sn-circle{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;background:#f1ece5;color:var(--text-muted);font-size:13px;font-weight:800;transition:.2s;border:2px solid transparent;flex-shrink:0}
.sn-lbl{font-size:13px;font-weight:600;color:var(--text-soft)}
.sn-item.active{background:var(--brand-soft)}.sn-item.active .sn-circle{background:var(--brand);color:#fff}.sn-item.active .sn-lbl{color:var(--brand);font-weight:800}
.sn-item.done .sn-circle{background:#dff2ea;color:var(--success);border-color:#c8e8d9}.sn-item.done .sn-lbl{color:var(--text)}
.sn-conn{width:2px;height:18px;background:var(--line);margin:0 17px;border-radius:8px;transition:.2s}.sn-conn.done{background:#a9d7c1}
.content-area{min-width:0;display:flex;justify-content:center;align-items:flex-start}
.shell{width:100%;max-width:980px;display:grid;grid-template-columns:minmax(0,1fr) 292px;gap:14px;align-items:start}
.ui-card{border-radius:24px;padding:28px;position:relative;overflow:hidden}
.ui-card::before{content:'';position:absolute;top:0;right:0;left:0;height:3px;background:var(--brand)}
.side-summary{border-radius:20px;padding:16px;position:sticky;top:82px}
.summary-title{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:800;margin-bottom:12px}.summary-title .mi{font-size:18px;color:var(--brand)}
.summary-empty{font-size:12px;color:var(--text-muted);line-height:2}
.summary-list{display:flex;flex-direction:column;gap:10px}.summary-row{padding:10px 12px;border-radius:14px;background:var(--panel-soft);border:1px solid #efe6dc}.summary-row .lbl{font-size:10px;color:var(--text-muted);display:block;margin-bottom:4px}.summary-row .val{font-size:13px;font-weight:800;color:var(--text);display:block}
.summary-price{margin-top:14px;padding:14px;border-radius:18px;background:var(--brand-soft);border:1px solid var(--brand-mid)}.summary-price .cap{font-size:11px;color:var(--text-soft)}.summary-price .amt{font-size:24px;font-weight:900;color:var(--brand);margin-top:4px}.summary-price .sub{font-size:11px;color:var(--text-muted);margin-top:4px}
.sec-title{font-size:23px;font-weight:900;display:flex;align-items:center;gap:10px;margin-bottom:8px;line-height:1.4}.sec-title .mi{font-size:24px;color:var(--brand)}
.sec-desc{font-size:13px;line-height:2;color:var(--text-soft);margin-bottom:20px;max-width:56ch}
.eyebrow{display:inline-flex;align-items:center;gap:6px;padding:7px 10px;border-radius:999px;background:var(--accent-soft);color:var(--accent);font-size:11px;font-weight:800;margin-bottom:14px;border:1px solid #f4d0b3}.eyebrow .mi{font-size:15px}
.back-bar{display:flex;align-items:center;gap:7px;margin-bottom:18px;padding-bottom:14px;border-bottom:1px dashed var(--line-strong);flex-wrap:wrap}.btn-back{display:inline-flex;align-items:center;gap:5px;background:none;border:none;color:var(--text-soft);font-size:12px;font-weight:700;padding:7px 10px;border-radius:999px;cursor:pointer;transition:.18s}.btn-back:hover{background:#f6f1eb;color:var(--brand)}.btn-back .mi{font-size:15px}.bsep{color:var(--line-strong)}
.phone-box{display:flex;flex-direction:column;gap:10px;margin-bottom:18px}.inp-label{font-size:12px;font-weight:700;color:var(--text-soft)}.inp-wrap{position:relative}
.inp{width:100%;padding:16px 18px 16px 48px;font-size:24px;font-weight:800;letter-spacing:2px;color:var(--text);background:#fff;border:1.5px solid var(--line-strong);border-radius:16px;direction:ltr;text-align:center;outline:none;transition:border-color .2s,box-shadow .2s}.inp:focus{border-color:var(--brand);box-shadow:0 0 0 4px rgba(31,59,91,.08)}.inp.valid{border-color:#b9dfcf}.inp-error{font-size:12px;color:var(--danger);min-height:20px}.inp-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);font-size:20px;color:var(--text-muted)}
.btn-p{height:48px;border:none;border-radius:14px;background:var(--brand);color:#fff;font-size:14px;font-weight:800;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:0 28px;cursor:pointer;transition:background .16s,transform .16s,opacity .16s;width:100%}.btn-p:hover:not(:disabled){background:#17314d;transform:translateY(-1px)}.btn-p:disabled{opacity:.48;cursor:not-allowed}
.btn-o{height:42px;border-radius:14px;background:#fff;color:var(--brand);border:1.5px solid var(--brand-mid);padding:0 18px;font-size:12px;font-weight:800;display:inline-flex;align-items:center;gap:6px;cursor:pointer;transition:.18s}.btn-o:hover{background:var(--brand-soft)}
.spin{animation:spin 1s linear infinite}
.helper-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:18px}.helper-card{padding:14px;border-radius:18px;background:var(--panel-soft);border:1px solid #efe7dc}.helper-card .tt{font-size:12px;font-weight:800;margin-bottom:6px;color:var(--brand)}.helper-card .tx{font-size:12px;line-height:1.9;color:var(--text-soft)}
.section-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:18px}.phone-badge{display:inline-flex;align-items:center;gap:7px;background:#fff;border:1px solid var(--line);border-radius:999px;padding:7px 14px;font-size:13px;font-weight:800;color:var(--text);letter-spacing:1px;direction:ltr}.phone-badge .mi{font-size:15px;color:var(--accent)}.hint{font-size:11px;color:var(--text-muted);margin-top:4px}
.camp-picker,.svc-picker{margin-bottom:12px;border:1px solid #ebdfd4;border-radius:20px;background:#fff;overflow:hidden;transition:box-shadow .2s,border-color .2s}
.camp-picker:hover,.svc-picker:hover{border-color:#d7c8b9}
.camp-picker.compact .camp-grid-wrap,.svc-picker.compact .svc-grid-wrap{max-height:0;opacity:0;overflow:hidden}
.camp-picker.expanded .camp-grid-wrap{max-height:980px;opacity:1}.svc-picker.expanded .svc-grid-wrap{max-height:1200px;opacity:1}
.camp-picker-head,.svc-picker-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 14px;cursor:pointer;background:#fcfbf9}
.camp-picker-head-main,.svc-picker-head-main{display:flex;align-items:flex-start;gap:10px;min-width:0}.camp-picker-head .mi,.svc-picker-head .mi{font-size:18px;color:var(--accent);flex-shrink:0}
.camp-picker-title,.svc-picker-title{font-size:12px;font-weight:800;color:var(--text)}.camp-picker-sub,.svc-picker-sub{font-size:11px;color:var(--text-muted);margin-top:3px}
.camp-picker-toggle,.svc-picker-toggle{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:800;color:var(--brand);white-space:nowrap}.camp-picker-toggle .mi,.svc-picker-toggle .mi{font-size:18px;transition:transform .2s}
.camp-picker.expanded .camp-picker-toggle .mi,.svc-picker.expanded .svc-picker-toggle .mi{transform:rotate(180deg)}
.camp-compact-list,.svc-compact-list,.svc-filter{display:flex;gap:8px;overflow:auto;padding:0 14px 12px;scrollbar-width:none;flex-wrap: wrap;}.camp-compact-list::-webkit-scrollbar,.svc-compact-list::-webkit-scrollbar,.svc-filter::-webkit-scrollbar{display:none}
.camp-mini,.svc-mini,.filter-pill{display:inline-flex;align-items:center;gap:6px;padding:8px 10px;border-radius:999px;background:#fff;border:1px solid #eadfd2;color:var(--text-soft);font-size:11px;font-weight:700;white-space:nowrap;transition:.18s;cursor:pointer}
.camp-mini:hover,.svc-mini:hover,.filter-pill:hover{border-color:#d7c8b9;background:#fcfbfa}
.camp-mini.selected,.svc-mini.selected,.filter-pill.active{background:var(--brand-soft);border-color:var(--brand-mid);color:var(--brand)}
.camp-mini.vip-mini.selected,.svc-mini.vip-mini.selected{background:var(--premium-soft);border-color:#ecd9ac;color:#8b6200}
.camp-mini-check,.svc-mini-check{display:none;font-size:15px!important}.camp-mini.selected .camp-mini-check,.svc-mini.selected .svc-mini-check{display:block}
.camp-grid-wrap,.svc-grid-wrap{padding:0 14px 14px;transition:max-height .28s ease,opacity .22s ease}.camp-grid,.svc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:10px}
.camp-card,.svc-card{border:1.5px solid var(--line);border-radius:18px;padding:13px;cursor:pointer;transition:.18s;background:#fff;position:relative}.camp-card:hover,.svc-card:hover{border-color:#d7c8b9;transform:translateY(-1px)}.camp-card.selected,.svc-card.selected{border-color:var(--brand);background:var(--brand-soft)}
.camp-card.vip,.svc-card.vip-s{border-color:#ecd9ac;background:#fffaf0}.camp-card.vip.selected,.svc-card.vip-s.selected{border-color:var(--premium);background:#fff7ea}
.vip-crown{display:inline-flex;align-items:center;gap:4px;background:var(--premium-soft);color:#8b6200;border:1px solid #edd9a4;font-size:10px;font-weight:800;padding:4px 8px;border-radius:999px;margin-bottom:10px}
.check-dot{position:absolute;top:12px;left:12px;width:22px;height:22px;border-radius:50%;background:var(--brand);display:none;place-items:center;color:#fff}.camp-card.selected .check-dot{display:grid}.camp-card.vip.selected .check-dot{background:var(--premium)}
.camp-icon{width:46px;height:46px;border-radius:14px;display:grid;place-items:center;background:var(--brand);color:#fff;margin-bottom:12px}.camp-card.vip .camp-icon{background:#aa7b1d;color:#fff}.camp-name{font-size:14px;font-weight:800;margin-bottom:5px}.camp-desc{font-size:12px;line-height:1.85;color:var(--text-soft)}.camp-meta{margin-top:10px;font-size:11px;color:var(--text-muted)}
.svc-section{margin-top:18px;padding-top:18px;border-top:1px dashed var(--line-strong);display:none}.svc-label{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:12px}.svc-label h3{font-size:14px;font-weight:800;display:flex;align-items:center;gap:6px;margin:0}.svc-label h3 .mi{font-size:18px;color:var(--accent)}
.rdot{position:absolute;top:12px;left:12px;width:19px;height:19px;border-radius:50%;background:#fff;border:1.5px solid var(--line-strong);display:grid;place-items:center;transition:.2s}.rdot::after{content:'';width:7px;height:7px;border-radius:50%;display:none;background:#fff}.svc-card.selected .rdot{background:var(--brand);border-color:var(--brand)}.svc-card.vip-s.selected .rdot{background:var(--premium);border-color:var(--premium)}.svc-card.selected .rdot::after,.svc-card.vip-s.selected .rdot::after{display:block}
.badge-row{display:flex;gap:5px;flex-wrap:wrap;margin:0 0 8px 22px}.badge{display:inline-flex;align-items:center;padding:3px 8px;border-radius:999px;font-size:10px;font-weight:800}.badge.vip{background:#fff3d2;color:#8b6200}.badge.disc{background:#ffe7e7;color:#bb1f1f}.badge.new-b{background:#e2f8ec;color:#0d744d}.badge.pop{background:#ece8ff;color:#5a2ac5}
.svc-name{font-size:13px;font-weight:800;margin:0 0 6px;padding-left:24px}.svc-orig{font-size:11px;color:var(--text-muted);text-decoration:line-through;display:block}.svc-price{font-size:17px;font-weight:900;color:var(--brand);display:block;margin-top:2px}.svc-card.vip-s .svc-price{color:var(--premium)}.svc-desc{font-size:11px;line-height:1.8;color:var(--text-soft);margin-top:5px}
.duration-section{margin:18px 0 14px;display:none}.duration-card{width:100%;padding:20px 18px;border:1px solid #ebdfd4;border-radius:22px;background:#fff;box-shadow:var(--shadow)}.duration-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:14px}.duration-head h3{font-size:18px;font-weight:900;display:flex;align-items:center;gap:8px;margin:0}.duration-head h3 .mi{font-size:22px;color:var(--accent)}.duration-desc{font-size:13px;line-height:1.9;color:var(--text-soft)}.duration-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px}.duration-item{min-height:72px;border:1.5px solid var(--line);border-radius:18px;background:#d0d2f9;padding:14px 12px;display:flex;align-items:center;justify-content:center;text-align:center;font-size:15px;font-weight:800;color:var(--text);cursor:pointer;transition:.18s}.duration-item:hover{color:#fff;background-color:#a0aee5;border-color:#102767;transform:translateY(-1px)}.duration-item.selected{border-color:var(--brand);background:var(--brand-soft);color:var(--brand)}
.svc-detail-box{display:none;margin-top:16px;padding:18px;border:1px solid #e9dfd3;border-radius:22px;background:linear-gradient(180deg,#fff 0%,#fcfaf7 100%);box-shadow:var(--shadow)}.svc-detail-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:14px}.svc-detail-head h4{margin:0;font-size:15px;font-weight:900;display:flex;align-items:center;gap:7px;color:var(--text)}.svc-detail-head h4 .mi{font-size:19px;color:var(--accent)}.svc-detail-name{display:inline-flex;align-items:center;padding:7px 12px;border-radius:999px;background:var(--brand-soft);border:1px solid var(--brand-mid);font-size:12px;font-weight:800;color:var(--brand)}.svc-detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px}.svc-detail-item{padding:13px 14px;border-radius:18px;background:#fff;border:1px solid #eee4d8}.svc-detail-item .lbl{display:block;font-size:10px;font-weight:700;color:var(--text-muted);margin-bottom:6px}.svc-detail-item .val{display:block;font-size:13px;font-weight:800;color:var(--text);line-height:1.8}.svc-detail-placeholder{padding:18px 16px;border-radius:18px;background:var(--panel-soft);border:1px dashed #e4d8ca;color:var(--text-soft);font-size:12px;line-height:2;text-align:center}.svc-detail-placeholder .mi{font-size:20px;color:var(--accent);display:block;margin-bottom:8px}.svc-detail-loading{display:flex;align-items:center;justify-content:center;gap:8px;padding:16px;border-radius:18px;background:var(--panel-soft);border:1px solid #eee4d8;color:var(--brand);font-size:12px;font-weight:700}
.skeleton{height:92px;border-radius:18px;background:linear-gradient(90deg,#eee6dc 25%,#f8f3ee 50%,#eee6dc 75%);background-size:200% 100%;animation:shimmer 1.4s infinite}@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}.loading-row{display:flex;align-items:center;justify-content:center;padding:20px;gap:8px;color:var(--brand);font-size:12px}
.invoice-box{background:var(--brand-soft);border:1px solid var(--brand-mid);border-radius:20px;padding:18px;margin:14px 0 18px}.inv-row{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;padding:10px 0;font-size:13px;color:var(--text-soft);border-bottom:1px solid rgba(31,59,91,.08)}.inv-row:last-child{border-bottom:none}.inv-row span:last-child{font-weight:800;color:var(--text);text-align:left}.inv-row.save span:last-child{color:#b3261e}.inv-row.total{margin-top:6px;padding:16px 14px;border:none;border-radius:18px;background:#fff;align-items:center}.inv-row.total span:first-child{font-size:13px;color:var(--text-soft);font-weight:700}.inv-row.total span:last-child{font-size:27px;color:var(--brand);font-weight:900}
.sec-note{display:flex;align-items:flex-start;gap:8px;padding:12px 14px;border-radius:16px;background:#faf7f2;border:1px solid #eee4d8;color:var(--text-soft);font-size:12px;line-height:1.9;margin-bottom:18px}.sec-note .mi{font-size:18px;color:var(--warn)}
.result-box{text-align:center;padding:8px 0}.res-icon{width:84px;height:84px;border-radius:50%;margin:0 auto 18px;display:grid;place-items:center}.res-icon .mi{font-size:42px}.res-icon.ok{background:var(--success-soft);color:var(--success)}.res-icon.fail{background:#fdeaea;color:var(--danger)}.res-title{font-size:24px;font-weight:900;margin-bottom:8px}.res-desc{font-size:14px;line-height:2;color:var(--text-soft);margin-bottom:16px}.track-box{display:inline-block;padding:12px 18px;border-radius:16px;background:#fff;border:1px solid var(--line);font-size:12px;color:var(--text-soft);direction:ltr;margin-bottom:18px}.track-box strong{font-size:14px;color:var(--brand)}.result-summary{max-width:460px;margin:0 auto 18px;padding:14px 16px;border-radius:18px;background:var(--panel-soft);border:1px solid #eee4d8;text-align:right}.result-summary .row{display:flex;justify-content:space-between;gap:10px;padding:6px 0;font-size:12px;color:var(--text-soft)}.result-summary .row span:last-child{font-weight:800;color:var(--text)}
.divl{border:none;border-top:1px dashed var(--line-strong);margin:14px 0}

/* ─── فروش مودم فیبرنوری ───────────────────────────────────────────── */
.entry-actions-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin:18px 0}.modem-entry{margin:0;padding:18px;border-radius:22px;background:linear-gradient(135deg,var(--brand) 0%,#244f7d 100%);color:#fff;display:grid;align-items:center;justify-content:space-between;gap:14px;box-shadow:0 14px 30px rgba(31,59,91,.16);cursor:pointer;transition:.18s;border:none;width:100%;text-align:right}
.modem-entry:hover{transform:translateY(-2px);box-shadow:0 18px 38px rgba(31,59,91,.2)}
.modem-entry-main{display:flex;align-items:flex-start;gap:12px}.modem-entry-ico{width:48px;height:48px;border-radius:16px;background:rgba(255,255,255,.14);display:grid;place-items:center;flex-shrink:0}.modem-entry-ico .mi{font-size:27px}.modem-entry-title{font-size:18px;font-weight:900;margin-bottom:5px}.modem-entry-desc{font-size:12px;line-height:1.9;color:rgba(255,255,255,.8)}.modem-entry-cta{display:inline-flex;align-items:center;gap:6px;border-radius:999px;background:#fff;color:var(--brand);font-size:12px;font-weight:900;padding:10px 14px;white-space:nowrap}.modem-entry-cta .mi{font-size:17px}
.modem-store-head{display:block;margin-bottom:18px}.modem-store-head .sec-desc{max-width:none;width:100%;display:block}.modem-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px;margin:14px 0}.modem-card{--modem-hover:#183755;border:1.5px solid var(--line);border-radius:20px;background:#fff;padding:12px;cursor:pointer;position:relative;transition:.18s;min-height:292px;overflow:hidden}.modem-card:hover{border-color:rgba(24,55,85,.9);background:var(--modem-hover);transform:translateY(-2px);box-shadow:0 18px 38px rgba(15,32,52,.22)}.modem-card:hover .modem-card-title,.modem-card:hover .modem-card-sub,.modem-card:hover .modem-card-price{color:#fff}.modem-card:hover .modem-chip{background:rgba(255,255,255,.13);border-color:rgba(255,255,255,.22);color:rgba(255,255,255,.88)}.modem-card.selected{border-color:var(--brand);background:var(--brand-soft)}.modem-card.selected:hover{background:var(--modem-hover)}.modem-card .rdot{top:14px;left:14px}.modem-card.selected .rdot{background:var(--brand);border-color:var(--brand)}.modem-card.selected .rdot::after{display:block}.modem-img-wrap{height:170px;border-radius:17px;background:#fff;border:1px solid #e6edf4;display:flex;align-items:center;justify-content:center;overflow:hidden;margin-bottom:12px;padding:8px}.modem-img{width:100%;height:100%;object-fit:contain!important;object-position:center!important;display:block}.modem-card-title{font-size:14px;font-weight:900;margin:0 0 7px;padding-left:24px;transition:.18s}.modem-card-sub{font-size:11px;line-height:1.8;color:var(--text-soft);min-height:38px;transition:.18s}.modem-card-price{display:block;font-size:18px;font-weight:900;color:var(--brand);margin-top:10px;transition:.18s}.modem-card-meta{display:flex;gap:6px;flex-wrap:wrap;margin-top:10px}.modem-chip{display:inline-flex;align-items:center;padding:4px 8px;border-radius:999px;background:rgba(255,255,255,.78);border:1px solid #eee4d8;color:var(--text-soft);font-size:10px;font-weight:800;transition:.18s}.modem-chip.ok{background:var(--success-soft);border-color:#c8e8d9;color:var(--success)}
.modem-detail-box{display:none;margin-top:16px;padding:18px;border:1px solid #e9dfd3;border-radius:22px;background:linear-gradient(180deg,#fff 0%,#fcfaf7 100%);box-shadow:var(--shadow)}.modem-detail-grid{display:flex;flex-direction:column;gap:8px;margin-top:12px}.modem-detail-item{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 14px;border-radius:15px;background:#fff;border:1px solid #eee4d8}.modem-detail-item .lbl{font-size:11px;font-weight:800;color:var(--text-muted);white-space:nowrap}.modem-detail-item .val{font-size:13px;font-weight:900;color:var(--text);line-height:1.8;text-align:left;direction:rtl}.modem-actions{display:block;margin-top:16px}.modem-actions .btn-p{width:100%;min-width:0}.modem-invoice-section{display:none;margin-top:18px}.modem-retry-mini{height:28px;border-radius:999px;background:#fff;color:var(--brand);border:1px solid var(--brand-mid);padding:0 9px;font-size:10px;font-weight:900;display:inline-flex;align-items:center;gap:4px;cursor:pointer;margin-right:8px;vertical-align:middle}.modem-retry-mini .mi{font-size:14px}.modem-retry-mini:hover{background:var(--brand-soft)}.modem-payment-result{grid-column:1/-1;text-align:center;padding:28px 18px;border-radius:22px;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow)}.modem-payment-result .res-icon{margin-bottom:14px}.modem-payment-result .track-box{margin:10px 0 0}.modem-payment-actions{display:flex;justify-content:center;gap:10px;flex-wrap:wrap;margin-top:16px}.modem-payment-actions .btn-o{height:38px}
@media (max-width:640px){.entry-actions-row{grid-template-columns:1fr}.modem-entry{align-items:stretch}.modem-entry-cta{justify-content:center}.modem-actions .btn-p,.modem-actions .btn-o{width:100%;justify-content:center}}


body.modem-mode .sidebar,body.modem-mode #summaryCard{display:none!important}
body.modem-mode .main-layout{grid-template-columns:1fr;width:min(100%,1220px)}
body.modem-mode .content-area{width:100%}
body.modem-mode .shell{grid-template-columns:1fr;max-width:1180px;width:100%}
body.modem-mode #vModems{width:100%}
@media (max-width:1180px){.main-layout{grid-template-columns:1fr;padding:16px;gap:14px}.sidebar{position:static;padding:12px 10px;border-radius:18px;overflow:auto;white-space:nowrap}.sidebar>.sn-item,.sidebar>.sn-conn{display:inline-flex;vertical-align:middle}.sn-item{min-width:152px}.sn-conn{width:22px;height:2px;margin:0 6px 0 2px;display:inline-block}.shell{grid-template-columns:1fr}.side-summary{position:static;order:-1}}
@media (max-width:860px){.top-header{padding:12px 14px;align-items:flex-start;flex-direction:column}.header-side{width:100%;align-items:stretch}.chips-toggle{display:inline-flex;align-self:flex-start}.header-chips{display:none;width:100%}.header-chips.open{display:flex}.helper-grid{grid-template-columns:1fr}.camp-grid,.svc-grid,.duration-grid{grid-template-columns:1fr}.phone-badge{width:100%;justify-content:center}.ui-card{padding:22px 16px;border-radius:22px}.sec-title{font-size:19px}.inp{font-size:22px;padding:15px 16px 15px 42px}.camp-picker-head,.svc-picker-head{padding:11px 12px}.camp-compact-list,.svc-compact-list,.svc-filter{padding:0 12px 10px}.camp-mini,.svc-mini,.filter-pill{font-size:10px;padding:7px 9px}.camp-grid-wrap,.svc-grid-wrap{padding:0 12px 12px}.duration-card{padding:18px 14px}.duration-head h3{font-size:16px}.svc-detail-box{padding:15px 13px}.svc-detail-grid{grid-template-columns:1fr}}
@media (max-width:640px){.header-chips{flex-direction:column}.info-chip{width:100%;min-width:unset}.btn-p{height:47px}.inv-row,.result-summary .row{font-size:11px}.inv-row.total span:last-child{font-size:22px}}

/* Utilities extracted from inline HTML attributes during separation */
.u-mb-0{margin-bottom:0!important}
.u-icon-14{font-size:14px!important}.u-icon-15{font-size:15px!important}.u-icon-16{font-size:16px!important}.u-icon-18{font-size:18px!important}
.u-text-danger{color:var(--danger)!important}.u-text-success{color:var(--success)!important}.u-dir-ltr{direction:ltr!important}
.two-column-form{
  background:#fff;
  border:1px solid #e9dfd3;
  border-radius:20px;
  padding:18px;
  box-shadow:var(--shadow);
}

.two-column-form-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
  align-items:start;
}

.two-column-form-col{
  display:flex;
  flex-direction:column;
  gap:12px;
}

.two-column-form-title{
  display:flex;
  align-items:center;
  gap:7px;
  padding-bottom:10px;
  border-bottom:1px dashed var(--line-strong);
  color:var(--brand);
  font-size:13px;
  font-weight:900;
}

.two-column-form-title .mi{
  font-size:19px;
  color:var(--accent);
}

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

.form-field label{
  font-size:11px;
  font-weight:800;
  color:var(--text-soft);
}

.form-field input,
.form-field textarea{
  width:100%;
  border:1.5px solid var(--line-strong);
  border-radius:12px;
  background:#fff;
  color:var(--text);
  font-family:'Vazirmatn',sans-serif;
  font-size:13px;
  font-weight:700;
  outline:none;
  box-sizing:border-box;
  transition:border-color .18s,box-shadow .18s;
}

.form-field input{
  height:42px;
  padding:0 12px;
}

.form-field textarea{
  min-height:86px;
  padding:10px 12px;
  resize:vertical;
  line-height:1.9;
}

.form-field input:focus,
.form-field textarea:focus{
  border-color:var(--brand);
  box-shadow:0 0 0 4px rgba(31,59,91,.08);
}

.form-field input.invalid,
.form-field textarea.invalid{
  border-color:var(--danger);
  box-shadow:0 0 0 4px rgba(217,64,64,.08);
}

.form-field input.valid,
.form-field textarea.valid{
  border-color:#b9dfcf;
}

.two-column-form-actions{
  display:flex;
  justify-content:flex-end;
  margin-top:16px;
  padding-top:14px;
  border-top:1px dashed var(--line-strong);
}

.two-column-form-actions .btn-p{
  width:auto;
  min-width:180px;
}

@media (max-width:760px){
  .two-column-form-grid{
    grid-template-columns:1fr;
  }

  .two-column-form-actions .btn-p{
    width:100%;
  }
}
/* ─── پیام‌های داخل صفحه ───────────────────────────────────────── */

.page-message{
  display:flex;
  align-items:flex-start;
  gap:10px;
  width:100%;
  padding:13px 14px;
  border-radius:14px;
  border:1px solid var(--line);
  background:#fff;
  color:var(--text-soft);
  margin:12px 0;
}

.page-message-icon{
  width:28px;
  height:28px;
  border-radius:10px;
  display:grid;
  place-items:center;
  flex-shrink:0;
  font-size:20px;
  margin-top:1px;
}

.page-message-content{
  min-width:0;
  flex:1;
}

.page-message-title{
  color:var(--text);
  font-size:13px;
  font-weight:900;
  line-height:1.6;
  margin-bottom:2px;
}

.page-message-text{
  color:var(--text-soft);
  font-size:12px;
  font-weight:600;
  line-height:1.9;
}

.page-message-info{
  background:var(--brand-soft);
  border-color:var(--brand-mid);
}

.page-message-info .page-message-icon{
  color:var(--brand);
  background:#fff;
}

.page-message-success{
  background:var(--success-soft);
  border-color:#c8e8d9;
}

.page-message-success .page-message-icon{
  color:var(--success);
  background:#fff;
}

.page-message-warning{
  background:#fff7e6;
  border-color:#edd9a4;
}

.page-message-warning .page-message-icon{
  color:var(--warn);
  background:#fff;
}

.page-message-danger{
  background:#fdeaea;
  border-color:#f3c1c1;
}

.page-message-danger .page-message-icon{
  color:var(--danger);
  background:#fff;
}

.page-message-empty{
  background:var(--panel-soft);
  border-style:dashed;
}

.page-message-empty .page-message-icon{
  color:var(--text-muted);
  background:#fff;
}

.page-message-compact{
  padding:10px 12px;
  border-radius:12px;
}

.page-message-compact .page-message-title{
  font-size:12px;
  margin-bottom:0;
}

.page-message-compact .page-message-text{
  font-size:11px;
}