/* =====================================================
   Δημιουργία / Επεξεργασία αγγελίας — φόρμα + live preview
   Συνεργάζεται με marketplace.css (design tokens).
   ===================================================== */
body{padding-top:56px}

/* ===== Left panel (form) ===== */
.panel{position:fixed;left:0;top:56px;bottom:0;width:420px;background:var(--surface);border-right:1px solid var(--line);display:flex;flex-direction:column;z-index:50}
.panel-scroll{flex:1;overflow-y:auto;padding:14px 16px 10px}
.p-kicker{font-size:13px;color:var(--text-2)}
.p-titlerow{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin:2px 0 4px}
.p-title{font-size:24px;font-weight:700;line-height:1.15;letter-spacing:-.01em}
.p-subtitle{font-size:12.5px;color:var(--text-2);margin-bottom:14px}
.user-row{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.user-row .av{width:40px;height:40px;border-radius:var(--r);background:linear-gradient(135deg,#2F63E0,#7B5CFF);display:grid;place-items:center;font-weight:700;color:#fff;flex-shrink:0;text-transform:uppercase}
.user-row .av svg{width:20px;height:20px}
.user-row b{font-size:15px;display:block}
.user-row span{font-size:12.5px;color:var(--text-2)}

/* sections */
.sec{border:1px solid var(--line-2);border-radius:var(--r);padding:16px 14px 8px;margin-top:14px;background:var(--surface)}
.sec-head{display:flex;align-items:center;gap:9px;margin-bottom:2px}
.sec-head svg{width:17px;height:17px;color:var(--blue-txt);flex-shrink:0}
.sec-head h2{font-size:15.5px;font-weight:700}
.sec-head .right{margin-left:auto}
.sec-sub{font-size:12px;color:var(--text-2);margin:2px 0 12px;padding-left:26px}

/* fields */
.fld{position:relative;border:1px solid var(--line-2);border-radius:var(--r);background:transparent;margin-bottom:12px;transition:border-color .12s,opacity .12s,box-shadow .15s}
.fld:focus-within{border-color:var(--blue)}
.fld.off{opacity:.55;pointer-events:none}
/* Transient highlight when a tap on the publish button points the seller at a
   still-empty required field. JS adds .need for ~1.7s, then removes it. */
.fld.need{border-color:var(--red);box-shadow:0 0 0 3px rgba(228,30,63,.16)}
.pick.need .pick-lbl{color:var(--red)}
.pick.need .cat{border-color:rgba(228,30,63,.55)}
.fld label{position:absolute;left:16px;top:13px;font-size:11.5px;color:var(--text-2);pointer-events:none}
.fld label b{color:var(--red);font-weight:700}
.fld input,.fld select{width:100%;height:54px;border:none;background:transparent;padding:24px 16px 7px;font-size:14.5px;color:var(--text)}
.fld input:focus,.fld select:focus,.fld textarea:focus{outline:none}
.fld select{appearance:none;-webkit-appearance:none;cursor:pointer}
.fld select option{background:var(--surface);color:var(--text)}
.fld.has-caret::after{content:'';position:absolute;right:15px;top:32px;width:8px;height:8px;border-right:2px solid var(--text-2);border-bottom:2px solid var(--text-2);transform:rotate(45deg);pointer-events:none}
.fld textarea{width:100%;min-height:110px;border:none;background:transparent;padding:14px 16px 10px;font-size:14.5px;resize:vertical;color:var(--text)}
.fld.ta{padding-top:0}
.fld-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.fld-row .fld{margin-bottom:12px}
.check-row{display:flex;align-items:center;gap:9px;padding:2px 2px 12px;cursor:pointer;font-size:14px;user-select:none}
.check-row input{display:none}
.check-row .box{width:18px;height:18px;border:2px solid var(--text-2);border-radius:var(--r);display:grid;place-items:center;transition:all .12s;flex-shrink:0}
.check-row .box svg{width:11px;height:11px;color:#fff;opacity:0;transform:scale(.4);transition:all .12s}
.check-row input:checked + .box{background:var(--blue);border-color:var(--blue)}
.check-row input:checked + .box svg{opacity:1;transform:scale(1)}
.check-row small{display:block;font-size:11.5px;color:var(--text-2)}
.hint{font-size:11.5px;color:var(--text-2);margin:-6px 0 12px;padding-left:2px}
.phone-safe{display:flex;align-items:flex-start;gap:9px;background:var(--surface-2);border:1px solid var(--line-2);border-radius:var(--r);padding:10px 12px;margin-bottom:6px;font-size:12px;line-height:1.45;color:var(--text-2)}
.phone-safe svg{width:18px;height:18px;color:var(--green);flex-shrink:0;margin-top:1px}
.phone-safe b{color:var(--text);font-weight:700}
/* Alt-mobile verification widget */
.pf-status{font-size:12px;line-height:1.4;margin:-4px 0 10px;padding-left:2px}
.pf-status.ok{color:var(--green);font-weight:600}
.pf-status.warn{color:#9a6b00}
.pf-status.muted{color:var(--text-2)}
.pf-send-btn{display:inline-flex;align-items:center;gap:7px;height:38px;padding:0 13px;margin-bottom:10px;border:1px solid var(--blue);border-radius:var(--r);background:var(--blue-dim);color:var(--blue-txt);font-size:13px;font-weight:600;cursor:pointer}
.pf-send-btn svg{width:15px;height:15px}
.pf-send-btn:disabled{opacity:.6;cursor:default}
.pf-otp{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:10px}
.pf-otp input{flex:1;min-width:120px;height:42px;border:1px solid var(--line-2);border-radius:var(--r);background:var(--surface);padding:0 12px;font-size:15px;letter-spacing:2px;color:var(--text)}
.pf-otp input:focus{outline:none;border-color:var(--blue)}
.pf-btn{height:42px;padding:0 16px;border:none;border-radius:var(--r);background:var(--blue);color:#fff;font-size:13px;font-weight:600;cursor:pointer}
.pf-btn:disabled{opacity:.6;cursor:default}
.pf-resend{height:42px;padding:0 6px;border:none;background:none;color:var(--blue-txt);font-size:12.5px;font-weight:600;cursor:pointer;text-decoration:underline}

/* ===== Click-card pickers (same look as the homepage filters) =====
   One CLICK per choice instead of a dropdown — single-select via radios. */
.pick{margin-bottom:14px}
.pick-lbl{display:block;font-size:11.5px;color:var(--text-2);margin-bottom:7px}
.pick-lbl b{color:var(--red);font-weight:700}
.cat-grid{display:grid;grid-template-columns:1fr 1fr;gap:7px}
.cat{position:relative;display:flex;align-items:center;gap:8px;padding:9px 10px;border:1px solid var(--line-2);border-radius:var(--r);font-size:13px;font-weight:500;color:var(--text);background:var(--surface);cursor:pointer;min-width:0;transition:border-color .12s,background .12s,color .12s}
.cat:hover{border-color:var(--text-3)}
.cat input{position:absolute;opacity:0;width:0;height:0;pointer-events:none}
.cat .ic{width:18px;height:18px;display:grid;place-items:center;flex-shrink:0;color:var(--text-2)}
.cat .ic svg,.cat .ic img{width:18px;height:18px;object-fit:contain}
.cat .cat-nm{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cat:has(input:checked){border-color:var(--blue);background:var(--blue-dim);color:var(--blue-txt);font-weight:600}
.cat:has(input:checked) .ic{color:var(--blue)}
.cat:focus-within{outline:none;border-color:var(--blue)}

/* photo upload */
.dropzone{border:1px dashed var(--line-2);border-radius:var(--r);background:var(--surface-2);min-height:120px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:7px;cursor:pointer;transition:background .12s,border-color .12s;text-align:center;padding:16px;margin-bottom:12px}
.dropzone:hover{background:var(--hover)}
.dropzone.drag{border-color:var(--blue);background:var(--blue-dim)}
/* Pulse when the seller tries to submit with no photo (matches .fld.need). */
.dropzone.need{border-color:var(--red);border-style:solid;box-shadow:0 0 0 3px rgba(228,30,63,.16)}
.dz-ic{width:36px;height:36px;border-radius:var(--r);background:var(--hover);display:grid;place-items:center}
.dz-ic svg{width:17px;height:17px}
.dropzone b{font-size:14.5px}
.dropzone span{font-size:12px;color:var(--text-2)}
/* Drag copy is meaningless on touch → swap to "take/choose" via @media hover:none. */
.dropzone .dz-touch{display:none}
.thumbs{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:12px}
.thumb{position:relative;aspect-ratio:1;border-radius:var(--r);overflow:hidden;background:var(--surface-2)}
.thumb img{width:100%;height:100%;object-fit:cover;display:block}
.thumb .rm{position:absolute;top:4px;right:4px;width:22px;height:22px;border-radius:var(--r);background:rgba(0,0,0,.7);color:#fff;display:grid;place-items:center;font-size:13px;line-height:1;border:none;cursor:pointer}
.thumb .main-tag{position:absolute;left:4px;bottom:4px;background:rgba(0,0,0,.72);color:#fff;font-size:9.5px;font-weight:700;padding:2px 6px;border-radius:var(--r)}
.thumb .ord{position:absolute;left:4px;bottom:4px;background:rgba(0,0,0,.55);color:#fff;font-size:9.5px;font-weight:700;min-width:16px;height:16px;display:grid;place-items:center;padding:0 4px;border-radius:var(--r)}
.thumbs .thumb{cursor:grab}
.thumbs .thumb:active{cursor:grabbing}
.thumb.thumb-ghost{opacity:.35}
.thumbs-hint{display:flex;align-items:center;gap:6px;font-size:11.5px;color:var(--text-2);margin:-4px 0 10px;padding-left:2px}
.thumbs-hint svg{width:14px;height:14px;color:var(--text-3);flex-shrink:0}
.thumbs-hint b{color:var(--text)}

/* mobile-upload (QR) */
.phone-up-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;height:42px;border:1px solid var(--line-2);border-radius:var(--r);background:var(--surface-2);color:var(--text);font-size:13px;font-weight:600;cursor:pointer;margin-bottom:12px;transition:background .12s,border-color .12s}
.phone-up-btn:hover{background:var(--hover);border-color:var(--text-3)}
.phone-up-btn svg{width:16px;height:16px;color:var(--blue-txt)}
.qr-panel{border:1px solid var(--line-2);border-radius:var(--r);background:var(--surface-2);padding:14px;margin-bottom:12px;text-align:center}
.qr-panel[hidden]{display:none}
.qr-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}
.qr-head b{font-size:14px}
.qr-x{width:28px;height:28px;border-radius:var(--r);background:var(--hover);border:none;color:var(--text-2);display:grid;place-items:center;cursor:pointer}
.qr-x svg{width:15px;height:15px}
.qr-sub{font-size:11.5px;color:var(--text-2);line-height:1.45;margin-bottom:12px}
.qr-box{width:188px;height:188px;margin:0 auto 10px;background:#fff;border-radius:var(--r);padding:10px;display:grid;place-items:center}
.qr-box svg,.qr-box img,.qr-box canvas{width:100%!important;height:100%!important;display:block}
.qr-status{font-size:12px;font-weight:600;color:var(--text-2)}
.qr-status.ok{color:var(--green)}
.qr-link{display:inline-block;margin-top:6px;font-size:11.5px;color:var(--blue-txt);word-break:break-all}

/* περιγραφή */
.suggest-btn{height:32px;padding:0 12px;border-radius:var(--r);background:var(--hover);font-size:12.5px;font-weight:600;display:inline-flex;align-items:center;gap:6px;transition:background .12s;border:none;cursor:pointer;color:var(--text)}
.suggest-btn:hover{background:var(--hover-2)}
.suggest-btn svg{width:13px;height:13px;color:var(--gold)}

/* εξοπλισμός */
.feat-total{font-size:12px;color:var(--text-2);margin:0 0 10px;padding-left:26px}
.feat{border-top:1px solid var(--line)}
.feat-head{width:100%;height:44px;display:flex;align-items:center;gap:9px;font-size:14.5px;font-weight:600;transition:background .12s;border-radius:var(--r);background:none;border:none;cursor:pointer;color:var(--text)}
.feat-head:hover{background:var(--hover)}
.feat-head .cnt{font-size:11px;font-weight:700;background:var(--blue-dim);color:var(--blue-txt);min-width:20px;height:20px;border-radius:var(--r);display:grid;place-items:center;padding:0 6px}
.feat-head .cnt.zero{background:var(--hover);color:var(--text-2)}
.feat-head svg{width:13px;height:13px;color:var(--text-2);margin-left:auto;transition:transform .15s;flex-shrink:0}
.feat.open .feat-head svg{transform:rotate(180deg)}
.feat-body{display:none;padding:4px 2px 14px;flex-wrap:wrap;gap:8px}
.feat.open .feat-body{display:flex}
.fchk{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--line-2);border-radius:var(--r);padding:6px 12px;font-size:12.5px;cursor:pointer;transition:all .12s;user-select:none}
.fchk:hover{border-color:var(--text-3)}
.fchk input{display:none}
.fchk:has(input:checked){background:var(--blue-dim);border-color:transparent;color:var(--blue-txt);font-weight:600}

/* footer */
.panel-foot{border-top:1px solid var(--line);padding:12px 16px 14px;background:var(--surface)}
.prog{height:8px;border-radius:var(--r);background:var(--hover);overflow:hidden;margin-bottom:6px}
.prog i{display:block;height:100%;width:0;background:var(--blue);border-radius:var(--r);transition:width .25s ease}
.prog-lbl{font-size:11.5px;color:var(--text-2);margin-bottom:10px}
/* Always clickable: a tap on the (grey) not-ready state guides the seller to
   the first missing field rather than being a dead button. .ready = blue. */
.next-btn{width:100%;height:42px;border-radius:var(--r);background:var(--hover);color:var(--text-3);font-weight:700;font-size:15px;transition:background .15s,color .15s;border:none;cursor:pointer}
.next-btn.ready{background:var(--blue);color:#fff}
.next-btn:hover{background:var(--hover-2)}
.next-btn.ready:hover{background:var(--blue-hover)}

/* ===== Preview ===== */
.preview-wrap{margin-left:420px;padding:24px;min-height:calc(100vh - 56px);display:flex;justify-content:center;align-items:flex-start}
.preview-card{width:100%;max-width:1060px;background:var(--surface);border-radius:var(--r);box-shadow:var(--shadow-card)}
.pv-head{padding:14px 18px;font-size:16px;font-weight:700;border-bottom:1px solid var(--line)}
.pv-body{display:grid;grid-template-columns:1.55fr 1fr;min-height:560px}
.pv-stage{background:#101011;border-bottom-left-radius:var(--r);position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;min-height:360px}
.pv-stage img{max-width:100%;max-height:100%;object-fit:contain}
.pv-placeholder{max-width:380px;text-align:center;padding:30px;color:#E4E6EB}
.pv-placeholder b{display:block;font-size:21px;margin-bottom:10px}
.pv-placeholder p{font-size:14.5px;color:#B0B3B8}
.pv-info{padding:20px 22px;display:flex;flex-direction:column;border-left:1px solid var(--line)}
.pv-title{font-size:24px;font-weight:700;line-height:1.2;word-break:break-word}
.pv-price{font-size:15px;font-weight:600;margin-top:4px}
.pv-price .neg{font-size:12px;font-weight:600;color:var(--green);margin-left:7px}
.pv-meta{font-size:12.5px;color:var(--text-2);margin-top:8px}
.pv-h{font-size:16px;font-weight:700;margin:18px 0 6px}
.pv-desc{font-size:14px;color:var(--text-2);white-space:pre-wrap;word-break:break-word}
.pv-specs{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}
.pv-chip{font-size:12px;font-weight:600;color:var(--text-2);background:var(--hover);border-radius:var(--r);padding:4px 9px}
.pv-chip.extras{color:var(--blue-txt);background:var(--blue-dim)}

/* ===== Edit (single column, no preview) ===== */
.edit-page{max-width:640px;margin:0 auto;padding:24px 16px 50px}
.edit-page .p-title{font-size:24px;font-weight:700;letter-spacing:-.01em}
.edit-page .p-subtitle{margin-bottom:6px}
.edit-foot{position:sticky;bottom:0;background:var(--surface);border:1px solid var(--line-2);border-radius:var(--r);padding:12px 14px;margin-top:14px;display:flex;gap:10px;box-shadow:var(--shadow-card)}
.edit-foot .save{flex:1;height:44px;border-radius:var(--r);background:var(--blue);color:#fff;font-weight:700;font-size:15px;border:none;cursor:pointer}
.edit-foot .save:hover{background:var(--blue-hover)}
.edit-foot .cancel{height:44px;padding:0 18px;border-radius:var(--r);background:var(--hover);color:var(--text);font-weight:600;display:inline-flex;align-items:center}
.fld input:disabled,.fld select:disabled{color:var(--text-2);cursor:not-allowed}
.existing-photos{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:12px}
.existing-photos .ph{aspect-ratio:1;border-radius:var(--r);overflow:hidden;background:var(--surface-2);position:relative}
.existing-photos .ph img{width:100%;height:100%;object-fit:cover}
.existing-photos .ph .main-tag{position:absolute;left:4px;bottom:4px;background:rgba(0,0,0,.7);color:#fff;font-size:9.5px;font-weight:700;padding:2px 6px;border-radius:var(--r)}
/* Existing photos are now reorderable (drag) + deletable (✕) on the edit page. */
.existing-photos .ph{cursor:grab;touch-action:none}
.existing-photos .ph:active{cursor:grabbing}
.existing-photos .ph.thumb-ghost{opacity:.35}
.existing-photos .ph .rm{position:absolute;top:4px;right:4px;width:22px;height:22px;border-radius:var(--r);background:rgba(0,0,0,.7);color:#fff;display:grid;place-items:center;font-size:13px;line-height:1;border:none;cursor:pointer;z-index:2}
.existing-photos .ph .ord{position:absolute;left:4px;bottom:4px;background:rgba(0,0,0,.55);color:#fff;font-size:9.5px;font-weight:700;min-width:16px;height:16px;display:grid;place-items:center;padding:0 4px;border-radius:var(--r)}

@media(max-width:1100px){.pv-body{grid-template-columns:1fr}.pv-info{border-left:none;border-top:1px solid var(--line)}}

/* ===== Mobile / tablet (≤900px): single focused column, no desktop preview =====
   The side-by-side live preview is a desktop luxury — below 900px it's just a
   huge, non-interactive block the seller has to scroll past, so we hide it and
   centre the form into one clean column. The progress + «Δημοσίευση» bar pins
   to the bottom so the primary action is always one tap away. */
@media(max-width:900px){
  body{padding-top:56px}
  .panel{position:static;width:auto;max-width:680px;margin:0 auto;border-right:none;height:auto}
  .panel-scroll{overflow:visible;padding:14px 16px 26px}
  .preview-wrap{display:none}
  .panel-foot{position:sticky;bottom:0;z-index:40;border-top:1px solid var(--line);box-shadow:0 -8px 22px rgba(0,0,0,.10);padding-bottom:calc(14px + env(safe-area-inset-bottom,0px))}
  .next-btn{height:48px}
  .sec{padding:16px 14px 10px}
  .edit-page{padding:18px 14px 30px}
  .edit-foot{padding-bottom:calc(12px + env(safe-area-inset-bottom,0px));box-shadow:0 -8px 22px rgba(0,0,0,.10)}
  .edit-foot .save{height:48px}
}

/* ===== Touch devices (phone/tablet): the QR "upload from your phone" flow is
   redundant — the device already has a camera + gallery — so hide it and switch
   the drag-copy to take/choose. Bigger tap targets for comfort. ===== */
@media (hover:none){
  .phone-up-btn,.qr-panel{display:none!important}
  .dropzone .dz-desktop{display:none}
  .dropzone .dz-touch{display:block}
  .cat{padding:11px 11px;font-size:13.5px}
  .fchk{padding:8px 13px}
  .check-row{padding:6px 2px 14px}
}

/* ── Validation error summary (create/edit forms) ── */
.form-errors{background:rgba(228,30,63,.08);border:1px solid rgba(228,30,63,.45);border-radius:var(--r);padding:12px 14px;margin-bottom:14px;font-size:13.5px;color:var(--text)}
.form-errors b{color:var(--red);display:block;margin-bottom:5px}
.form-errors ul{margin:0;padding-left:20px}
.form-errors li{margin-bottom:3px;line-height:1.5}

/* ── Guest hint row + inline auth gate (guest fills the form, gate at submit) ── */
.guest-row .guest-av{background:var(--hover);color:var(--text-2)}
.guest-row .guest-av svg{width:20px;height:20px}

.auth-gate{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:16px}
.auth-gate[hidden]{display:none}
.ag-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.6)}
.ag-card{position:relative;width:100%;max-width:400px;max-height:calc(100dvh - 32px);overflow:auto;background:var(--surface);border:1px solid var(--line-2);border-radius:var(--r);box-shadow:var(--shadow-pop);padding:22px 20px 20px}
.ag-x{position:absolute;top:10px;right:10px;width:32px;height:32px;border-radius:var(--r);background:var(--hover);border:none;color:var(--text-2);display:grid;place-items:center;cursor:pointer}
.ag-x svg{width:18px;height:18px}
.ag-h{font-size:20px;font-weight:800;letter-spacing:-.01em}
.ag-sub{font-size:13.5px;color:var(--text-2);margin:6px 0 16px;line-height:1.5}
.ag-tabs{display:flex;gap:6px;background:var(--surface-2);border-radius:var(--r);padding:4px;margin-bottom:14px}
.ag-tab{flex:1;height:34px;border:none;border-radius:var(--r);background:none;font-weight:600;font-size:13px;color:var(--text-2);cursor:pointer;transition:background .12s,color .12s}
.ag-tab.on{background:var(--surface);color:var(--text);box-shadow:var(--shadow-card)}
.ag-err{background:rgba(228,30,63,.08);border:1px solid rgba(228,30,63,.45);color:var(--text);border-radius:var(--r);padding:9px 12px;font-size:13px;margin-bottom:12px}
.ag-err[hidden]{display:none}
.ag-pane{display:flex;flex-direction:column;gap:10px}
.ag-pane[hidden]{display:none}
.ag-in{height:44px;padding:0 13px;border:1px solid var(--line-2);border-radius:var(--r);background:transparent;color:var(--text);font-size:14.5px;width:100%}
.ag-in:focus{outline:none;border-color:var(--blue)}
.ag-check{display:flex;gap:8px;align-items:flex-start;font-size:12.5px;color:var(--text-2);line-height:1.45;cursor:pointer}
.ag-check input{margin-top:2px;flex-shrink:0}
.ag-check a{color:var(--blue-txt)}
.ag-submit{height:46px;border-radius:var(--r);background:var(--blue);color:#fff;font-weight:700;font-size:15px;border:none;cursor:pointer;margin-top:2px;transition:background .15s,opacity .15s}
.ag-submit:hover{background:var(--blue-hover)}
.ag-submit:disabled{opacity:.7;cursor:wait}

/* ── Smart start: πινακίδα/VIN → αυτόματη συμπλήρωση (λιγότερα clicks) ── */
.smart-start{margin:2px 0 14px;padding:13px 14px;border-radius:var(--r);background:linear-gradient(150deg,rgba(47,99,224,.10),rgba(123,92,255,.05));border:1px solid rgba(47,99,224,.30)}
.ss-head{display:flex;gap:10px;align-items:flex-start}
.ss-ic{width:30px;height:30px;flex-shrink:0;border-radius:9px;display:grid;place-items:center;background:linear-gradient(135deg,#2F63E0,#7B5CFF);color:#fff}
.ss-ic svg{width:17px;height:17px}
.ss-txt b{display:block;font-size:14px;font-weight:700}
.ss-txt span{display:block;font-size:12px;color:var(--text-2);line-height:1.45;margin-top:1px}
.ss-row{display:flex;gap:8px;margin-top:10px}
.ss-row input{flex:1;min-width:0;height:40px;padding:0 12px;border:1px solid var(--line-2);border-radius:var(--r);background:var(--input);color:var(--text);font-size:15px;text-transform:uppercase;letter-spacing:.04em;font-family:inherit}
.ss-row input:focus{outline:none;border-color:var(--blue)}
.ss-btn{flex-shrink:0;height:40px;padding:0 16px;border:none;border-radius:var(--r);background:var(--blue);color:#fff;font-weight:600;font-size:14px;display:inline-flex;align-items:center;gap:7px;cursor:pointer;transition:filter .12s}
.ss-btn svg{width:16px;height:16px}
.ss-btn:hover{filter:brightness(1.06)}
.ss-btn:disabled{opacity:.6;cursor:default}
.ss-result{margin-top:9px;font-size:12.5px;line-height:1.4;color:var(--text-2)}
.ss-result[hidden]{display:none}
.ss-result.ok,.ss-result.ok b{color:#16a34a}
.ss-result.warn{color:#b45309}
:root[data-theme="dark"] .ss-result.warn{color:#fbbf24}
@media (prefers-color-scheme:dark){:root:not([data-theme]) .ss-result.warn{color:#fbbf24}}
.ss-result b{font-weight:700}
.ss-note{display:block;margin-top:3px;font-weight:400;color:var(--text-2)}
@media(max-width:480px){.ss-row{flex-wrap:wrap}.ss-btn{flex:1;justify-content:center}}
