@import url('https://fonts.googleapis.com/css2?family=Saira+Extra+Condensed:wght@400;600;700;800;900&display=swap');

.hwo-wrap {
    --navy:   #1e3063;
    --gold:   #ffcc00;
    --blue:   #1896cb;
    --dark:   #0d152b;
    --mid:    #5a6a8a;
    --border: #d0d8e8;
    --light:  #f4f6fb;
    --white:  #ffffff;
    --red:    #c0392b;
    --green:  #2e7d32;
    --warn:   #f0a500;
    --r:      4px;
    font-family: 'Saira Extra Condensed', sans-serif;
    max-width: 900px;
    margin: 0 auto;
    color: var(--navy);
}

/* ── Mode Selector ─────────────────────────────────────────────── */
.hwo-mode-selector { text-align:center; padding:20px 0 32px; }
.hwo-mode-intro h2 { font-size:1.8rem;font-weight:900;text-transform:uppercase;color:var(--navy);margin:0 0 6px; }
.hwo-mode-intro p  { color:var(--mid);font-size:1rem;margin:0 0 24px; }
.hwo-mode-cards    { display:flex;gap:20px;justify-content:center;flex-wrap:wrap; }
.hwo-mode-card {
    flex:0 0 260px;border:3px solid var(--border);border-radius:var(--r);background:var(--white);
    padding:28px 20px;cursor:pointer;transition:all 0.18s;text-align:center;
    font-family:'Saira Extra Condensed',sans-serif;
}
.hwo-mode-card:hover { border-color:var(--navy);background:var(--light);transform:translateY(-2px);box-shadow:0 6px 20px rgba(30,48,99,.15); }
.hwo-mode-icon  { font-size:2.8rem;display:block;margin-bottom:10px; }
.hwo-mode-card strong { display:block;font-size:1.4rem;font-weight:900;text-transform:uppercase;color:var(--navy);margin-bottom:8px; }
.hwo-mode-card p { font-size:0.95rem;color:var(--mid);margin:0; }

/* ── Progress ──────────────────────────────────────────────────── */
.hwo-progress { display:flex;align-items:center;margin-bottom:24px; }
.hwo-progress-step { display:flex;flex-direction:column;align-items:center;gap:5px;flex:0 0 auto; }
.hwo-progress-step span { font-size:0.8rem;font-weight:700;text-transform:uppercase;color:var(--mid); }
.hwo-pdot { width:36px;height:36px;border-radius:50%;background:var(--light);border:3px solid var(--border);display:flex;align-items:center;justify-content:center;font-weight:900;color:var(--mid);transition:all .2s; }
.hwo-progress-step.active .hwo-pdot { background:var(--navy);border-color:var(--navy);color:var(--gold); }
.hwo-progress-step.active span { color:var(--navy); }
.hwo-progress-step.done .hwo-pdot { background:var(--blue);border-color:var(--blue);color:#fff; }
.hwo-progress-line { flex:1;height:3px;background:var(--border);margin-bottom:20px; }
.hwo-progress-line.done { background:var(--blue); }

/* ── Step cards ────────────────────────────────────────────────── */
.hwo-step { background:var(--white);border:2px solid var(--border);border-top:5px solid var(--navy);border-radius:var(--r);padding:28px 32px 32px;margin-bottom:16px;box-shadow:0 2px 12px rgba(30,48,99,.08); }
@media(max-width:520px){ .hwo-step{padding:18px 14px 22px;} }
.hwo-step-hdr { display:flex;align-items:flex-start;gap:16px;margin-bottom:22px;padding-bottom:16px;border-bottom:2px solid var(--light); }
.hwo-step-num { font-size:2rem;font-weight:900;color:var(--gold);background:var(--navy);padding:3px 10px;flex-shrink:0;line-height:1.2; }
.hwo-step-hdr h2 { font-size:1.5rem;font-weight:800;text-transform:uppercase;letter-spacing:.04em;margin:0 0 4px;color:var(--navy); }
.hwo-step-hdr p  { margin:0;font-size:.95rem;color:var(--mid);font-weight:500; }

/* ── Fields ────────────────────────────────────────────────────── */
.hwo-field { margin-bottom:16px;flex:1; }
.hwo-field-label,.hwo-field-label-inner { display:block;font-size:.8rem;font-weight:800;text-transform:uppercase;letter-spacing:.07em;color:var(--navy);margin-bottom:5px; }
.hwo-req { color:var(--red); }
.hwo-field input,.hwo-field select,.hwo-field textarea,
.hwo-contact-fields input,.hwo-contact-fields select {
    width:100%;padding:9px 12px;border:2px solid var(--border);border-radius:var(--r);
    font-family:'Saira Extra Condensed',sans-serif;font-size:1rem;font-weight:600;color:var(--navy);background:#fff;
    transition:border-color .2s,box-shadow .2s;box-sizing:border-box;
}
.hwo-field input:focus,.hwo-field select:focus,.hwo-field textarea:focus,
.hwo-contact-fields input:focus,.hwo-contact-fields select:focus {
    outline:none;border-color:var(--navy);box-shadow:0 0 0 3px rgba(30,48,99,.12);
}
.hwo-field textarea { resize:vertical;min-height:80px; }
.hwo-field-row { display:flex;gap:16px; }
@media(max-width:520px){ .hwo-field-row{flex-direction:column;gap:0;} }

/* ── Serial confirm ────────────────────────────────────────────── */
.hwo-serial-entry { margin-bottom:20px; }
.hwo-serial-entry-tabs { display:flex;gap:8px;margin-bottom:14px; }
.hwo-tab { padding:8px 20px;border:2px solid var(--border);border-radius:var(--r);font-family:'Saira Extra Condensed',sans-serif;font-size:1rem;font-weight:800;text-transform:uppercase;background:#fff;cursor:pointer;transition:all .15s; }
.hwo-tab.active { background:var(--navy);color:var(--gold);border-color:var(--navy); }
.hwo-serial-confirm-box { background:var(--light);border:2px solid var(--navy);border-radius:var(--r);padding:18px;margin-bottom:14px; }
.hwo-serial-label { display:block;font-size:.78rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--mid);margin-bottom:6px; }
.hwo-serial-display { display:flex;align-items:center;gap:12px;margin-bottom:12px; }
.hwo-serial-value { font-size:2rem;font-weight:900;letter-spacing:.08em;color:var(--navy);word-break:break-all; }
.hwo-serial-badge { background:var(--gold);color:var(--navy);font-size:.7rem;font-weight:900;text-transform:uppercase;letter-spacing:.08em;padding:3px 10px;border-radius:2px;flex-shrink:0; }
.hwo-serial-edit label { font-size:.82rem;font-weight:700;color:var(--mid);text-transform:uppercase;display:block;margin-bottom:5px; }
.hwo-serial-edit input { width:100%;padding:9px 12px;border:2px solid var(--border);border-radius:var(--r);font-family:'Saira Extra Condensed',sans-serif;font-size:1.2rem;font-weight:700;letter-spacing:.06em;color:var(--navy);box-sizing:border-box; }
.hwo-serial-edit input:focus { outline:none;border-color:var(--navy);box-shadow:0 0 0 3px rgba(30,48,99,.12); }

/* ── Upload zone ───────────────────────────────────────────────── */
.hwo-upload-zone { border:3px dashed var(--blue);border-radius:var(--r);background:#f0f7fd;padding:32px 20px;text-align:center;cursor:pointer;transition:all .2s; }
.hwo-upload-zone:hover,.hwo-upload-zone.drag-over { background:#daeef9;border-color:var(--navy); }
.hwo-upload-icon { font-size:2.5rem;display:block;margin-bottom:8px; }
.hwo-upload-title { font-size:1.3rem;font-weight:800;text-transform:uppercase;color:var(--navy);margin:0 0 4px; }
.hwo-upload-hint  { font-size:.9rem;color:var(--mid);margin:0 0 14px; }
#hwo-scan-preview-wrap { text-align:center;margin-top:12px; }
#hwo-scan-preview { max-width:100%;max-height:240px;border:3px solid var(--navy);border-radius:var(--r);display:block;margin:0 auto 8px; }

/* ── Piece checkboxes ──────────────────────────────────────────── */
.hwo-piece-check-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px;margin:14px 0; }
.hwo-piece-check-tile { border:2px solid var(--border);border-radius:var(--r);padding:12px 10px;text-align:center;cursor:pointer;transition:all .15s;user-select:none;background:#fff; }
.hwo-piece-check-tile:hover { border-color:var(--blue);background:#f0f7fd; }
.hwo-piece-check-tile.selected { border-color:var(--navy);background:var(--navy);color:#fff; }
.hwo-piece-check-tile input { display:none; }
.hwo-pct-icon { font-size:1.8rem;display:block;margin-bottom:5px; }
.hwo-piece-check-tile span:last-child { font-size:.9rem;font-weight:800;text-transform:uppercase;display:block; }

/* ── Repair mini cards ─────────────────────────────────────────── */
.hwo-repair-mini { border:2px solid var(--border);border-radius:var(--r);margin-bottom:12px;overflow:hidden; }
.hwo-repair-mini-hdr { background:var(--navy);color:var(--gold);padding:10px 16px;font-size:1.1rem;font-weight:900;text-transform:uppercase; }
.hwo-repair-mini select,.hwo-repair-mini textarea { width:100%;padding:8px 12px;border:none;border-bottom:1px solid var(--border);font-family:'Saira Extra Condensed',sans-serif;font-size:.95rem;font-weight:600;color:var(--navy);background:#fff;box-sizing:border-box; }
.hwo-repair-mini textarea { resize:vertical;min-height:70px; }
.hwo-damage-upload-mini { padding:10px 12px;background:var(--light); }

/* ── Ensemble cards ────────────────────────────────────────────── */
.hwo-ens-card { display:flex;align-items:center;justify-content:space-between;border:2px solid var(--border);border-left:5px solid var(--blue);border-radius:var(--r);padding:14px 16px;margin-bottom:10px;background:#fff; }
.hwo-ens-card-left { display:flex;flex-wrap:wrap;align-items:center;gap:10px;font-size:.95rem; }
.hwo-ens-pieces small { background:var(--light);border:1px solid var(--border);border-radius:2px;padding:2px 6px;font-size:.78rem;font-weight:700;margin-right:4px; }
.hwo-ens-card-right { display:flex;gap:8px;flex-shrink:0; }
.hwo-serial-pill { background:var(--navy);color:var(--gold);padding:3px 12px;font-weight:900;font-size:1rem;letter-spacing:.06em;border-radius:2px; }

/* ── Add ensemble box ──────────────────────────────────────────── */
.hwo-add-ensemble-box { border:2px dashed var(--blue);border-radius:var(--r);padding:22px;background:var(--light);margin-top:14px; }
.hwo-add-ensemble-box h3 { font-size:1.2rem;font-weight:900;text-transform:uppercase;color:var(--navy);margin:0 0 16px; }
.hwo-add-ensemble-box h4 { font-size:1rem;font-weight:800;text-transform:uppercase;color:var(--navy);margin:16px 0 10px; }

/* ── Quick tag table ───────────────────────────────────────────── */
.hwo-tag-table-wrap { overflow-x:auto;margin:16px 0; }
.hwo-tag-table { width:100%;border-collapse:collapse;font-size:.85rem;table-layout:fixed; }
.hwo-tag-table th { background:var(--navy);color:var(--gold);padding:6px 6px;text-align:center;font-weight:800;text-transform:uppercase;font-size:.75rem;white-space:nowrap;line-height:1.2; }
.hwo-tag-subhead th { background:#1a2a4a;color:#c8a84b;font-size:.7rem;padding:3px 4px;border-top:1px solid #c8a84b44; }
.hwo-tag-table td { padding:3px 4px;border:1px solid var(--border);vertical-align:middle; }
.hwo-tag-table tr:nth-child(even) td { background:#f8f9fc; }
.hwo-tag-num { text-align:center;font-weight:900;color:var(--mid);width:24px; }
.hwo-tag-serial { width:90px; }
.hwo-tag-brand  { width:75px; }
.hwo-tag-mfgdate { width:72px; }
.hwo-tag-check  { text-align:center;width:44px;padding:2px!important; }
.hwo-tag-check label { display:flex;align-items:center;justify-content:center;gap:3px;font-size:.78rem;cursor:pointer;white-space:nowrap; }
.hwo-tag-check label input { margin:0;width:13px;height:13px;flex-shrink:0; }
.hwo-tag-other-pieces { display:flex;flex-direction:column;gap:1px; }
.hwo-tag-other-pieces label { display:flex;align-items:center;gap:3px;font-size:.75rem;cursor:pointer;white-space:nowrap; }
.hwo-tag-other-pieces label input { margin:0;width:12px;height:12px;flex-shrink:0; }
.hwo-tag-repairs { width:100%;min-width:100px; }
.hwo-tag-remove { background:none;border:none;color:#aaa;font-size:1rem;cursor:pointer;padding:2px 4px; }
.hwo-tag-remove:hover { color:var(--red); }
.hwo-tag-table input[type="text"],.hwo-tag-table textarea {
    width:100%;padding:3px 5px;border:1px solid var(--border);border-radius:2px;
    font-family:'Saira Extra Condensed',sans-serif;font-size:.85rem;font-weight:600;color:var(--navy);box-sizing:border-box;
}
.hwo-tag-table textarea { resize:vertical;min-height:36px; }
.hwo-quick-header-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px;margin-bottom:16px; }

/* ── Account option ────────────────────────────────────────────── */
.hwo-account-option { background:#f0f7fd;border:2px solid var(--blue);border-radius:var(--r);padding:14px 16px;margin:16px 0; }
.hwo-account-check { display:flex;align-items:flex-start;gap:12px;cursor:pointer; }
.hwo-account-check input { margin-top:4px;flex-shrink:0;width:18px;height:18px; }
.hwo-account-check strong { display:block;font-size:1rem;font-weight:800;color:var(--navy); }
.hwo-account-check span { font-size:.9rem;color:var(--mid); }

/* ── Buttons ───────────────────────────────────────────────────── */
.hwo-btn { display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:12px 26px;font-family:'Saira Extra Condensed',sans-serif;font-size:1.1rem;font-weight:900;text-transform:uppercase;letter-spacing:.06em;border:3px solid transparent;border-radius:var(--r);cursor:pointer;transition:all .17s;text-decoration:none;line-height:1; }
.hwo-btn--primary { background:var(--navy);color:var(--gold);border-color:var(--navy); }
.hwo-btn--primary:hover { background:var(--dark);transform:translateY(-1px);box-shadow:0 4px 14px rgba(30,48,99,.25); }
.hwo-btn--submit  { background:var(--gold);color:var(--navy);border-color:var(--gold);font-size:1.25rem;padding:14px 34px; }
.hwo-btn--submit:hover { background:#e6b800;transform:translateY(-1px);box-shadow:0 4px 14px rgba(255,204,0,.4); }
.hwo-btn--ghost   { background:transparent;color:var(--mid);border-color:var(--border); }
.hwo-btn--ghost:hover { background:var(--light);color:var(--navy); }
.hwo-btn--sm { padding:6px 14px;font-size:.9rem; }
.hwo-btn:disabled { opacity:.5;cursor:not-allowed;transform:none!important; }
.hwo-step-actions { display:flex;justify-content:flex-end;gap:12px;padding-top:20px;border-top:2px solid var(--light);margin-top:22px; }

/* ── Loader ────────────────────────────────────────────────────── */
.hwo-loader { display:flex;align-items:center;gap:14px;padding:16px 18px;background:var(--light);border-radius:var(--r);border-left:5px solid var(--blue);margin-top:14px; }
.hwo-spinner { width:28px;height:28px;border:3px solid var(--border);border-top-color:var(--navy);border-radius:50%;animation:hwo-spin .75s linear infinite;flex-shrink:0; }
@keyframes hwo-spin { to{transform:rotate(360deg);} }
.hwo-loader strong { display:block;font-size:1.05rem;font-weight:800;color:var(--navy);text-transform:uppercase; }
.hwo-loader p { margin:2px 0 0;font-size:.88rem;color:var(--mid); }

/* ── Alerts ────────────────────────────────────────────────────── */
.hwo-alert { padding:11px 14px;border-radius:var(--r);font-size:.95rem;font-weight:600;margin:10px 0; }
.hwo-alert--warn  { background:#fff8e1;color:#7a5800;border-left:5px solid var(--gold); }
.hwo-alert--error { background:#fde8e8;color:#7a0a0a;border-left:5px solid var(--red); }
.hwo-alert--ok    { background:#e8f5e9;color:#1b5e20;border-left:5px solid #4caf50; }

/* ── Review ────────────────────────────────────────────────────── */
.hwo-review-section { border:1px solid var(--border);border-radius:var(--r);padding:16px;margin-bottom:12px; }
.hwo-review-section h3 { font-size:1rem;font-weight:900;text-transform:uppercase;color:var(--navy);margin:0 0 10px; }
.hwo-dl { display:grid;grid-template-columns:120px 1fr;gap:5px 12px;margin:0; }
.hwo-dl dt { font-weight:700;color:var(--mid);font-size:.85rem; }
.hwo-dl dd { margin:0;color:var(--navy); }

/* ── Success ───────────────────────────────────────────────────── */
.hwo-success-card { text-align:center;background:var(--white);border:3px solid var(--navy);border-top:8px solid var(--gold);border-radius:var(--r);padding:48px 32px;box-shadow:0 4px 20px rgba(30,48,99,.12); }
.hwo-success-icon { font-size:3.5rem;display:block;margin-bottom:14px; }
.hwo-success-card h2 { font-size:2rem;font-weight:900;text-transform:uppercase;color:var(--navy);margin:0 0 10px; }
.hwo-success-card p  { font-size:1.05rem;color:var(--mid);margin:0 0 20px; }
.hwo-success-ref { display:inline-block;background:var(--navy);color:var(--gold);padding:8px 24px;font-size:1.2rem;font-weight:900;letter-spacing:.07em;border-radius:var(--r);margin-bottom:24px; }
