/* AppWT Services Configurator — Tony 2026-06-13. Scoped under .svc. Mobile-first, no h-scroll (Rule 19). */
.svc *{box-sizing:border-box}
.svc{--navy:#0F2744;--green:#1B4332;--gold:#C4A052;--slate:#334155;--pearl:#FAFAFA;--line:#e5e8ee;--ink:#1E2432;
  background:#f5f6f9;color:var(--slate);font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  -webkit-text-size-adjust:100%;overflow-x:hidden;max-width:100%}
.svc img{max-width:100%;height:auto}
.svc .wrap{max-width:1140px;margin:0 auto;padding:0 16px}
.svc [hidden]{display:none !important}
.svc h1,.svc h2,.svc h3{color:var(--navy);margin:0}
.svc-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:0;border-radius:11px;
  padding:14px 24px;font-weight:800;font-size:15.5px;cursor:pointer;text-decoration:none;line-height:1.1;transition:.15s;font-family:inherit}
.svc-btn.gold{background:var(--gold);color:var(--navy)} .svc-btn.gold:hover{background:#b8954a}
.svc-btn.green{background:var(--green);color:#fff} .svc-btn.green:hover{background:#143527}
.svc-btn.ghost{background:#fff;color:var(--navy);border:2px solid var(--line)} .svc-btn.ghost:hover{border-color:#c9cfdb}
.svc-btn.sm{padding:9px 15px;font-size:13.5px;border-radius:9px}
.svc-btn:disabled{opacity:.45;cursor:not-allowed}

/* ===== WELCOME GATE ===== */
.svc-welcome{position:relative;overflow:hidden;padding:64px 0 70px;background:linear-gradient(135deg,#0F2744,#1B4332);color:#fff;text-align:center}
.svc-welcome .wrap{position:relative;z-index:2}
.svc-welcome h1{color:#fff;font-size:34px;line-height:1.14;font-weight:800;margin:0 0 14px}
.svc-welcome .lede{font-size:17px;color:#e6ecf3;max-width:640px;margin:0 auto 30px;line-height:1.55}
.svc-choices{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px;max-width:780px;margin:0 auto}
.svc-choice{background:rgba(255,255,255,.07);border:1.5px solid rgba(255,255,255,.22);border-radius:16px;padding:26px 22px;cursor:pointer;text-align:left;transition:.15s;color:#fff}
.svc-choice:hover{background:rgba(255,255,255,.13);border-color:var(--gold);transform:translateY(-2px)}
.svc-choice .ic{font-size:30px;margin-bottom:10px}
.svc-choice h3{color:#fff;font-size:19px;font-weight:800;margin:0 0 6px}
.svc-choice p{color:#d3dce5;font-size:14px;line-height:1.5;margin:0}
.svc-choice .go{display:inline-block;margin-top:14px;color:var(--gold);font-weight:800;font-size:14px}

/* quiz */
.svc-quiz{max-width:660px;margin:28px auto 0;background:#fff;border-radius:16px;padding:26px 22px;text-align:left;box-shadow:0 18px 50px rgba(0,0,0,.22);color:var(--slate)}
.svc-quiz h2{font-size:21px;margin:0 0 4px}
.svc-quiz .qsub{color:#6b7480;font-size:13.5px;margin:0 0 18px}
.svc-q{margin:0 0 20px}
.svc-q>label{display:block;font-weight:800;color:var(--navy);font-size:15px;margin:0 0 9px}
.svc-opts{display:flex;flex-wrap:wrap;gap:8px}
.svc-opt{display:inline-flex;align-items:center;gap:8px;border:1.5px solid var(--line);border-radius:10px;padding:10px 13px;font-size:14px;cursor:pointer;background:#fff;transition:.12s;line-height:1.25}
.svc-opt:hover{border-color:#c9cfdb}
.svc-opt.on{border-color:var(--green);background:#eef5f0;color:var(--green);font-weight:700}
.svc-opt input{position:absolute;opacity:0;width:0;height:0}
.svc-quiz .row2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.svc-quiz input[type=text],.svc-quiz input[type=email],.svc textarea,.svc select,.svc input[type=tel]{
  width:100%;padding:12px;border:1.5px solid var(--line);border-radius:10px;font:inherit;background:#fff;color:var(--ink)}
.svc-quiz .ck{display:flex;align-items:center;gap:9px;font-size:14px;margin:6px 0 0;cursor:pointer}
.svc-quiz .actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px}
.svc-skip{background:none;border:0;color:#7b8390;font-weight:700;cursor:pointer;font-size:14px;text-decoration:underline;padding:10px}

/* ===== EXPLORER ===== */
.svc-explorer{padding:0 0 120px}
.svc-toolbar{position:sticky;top:0;z-index:40;background:rgba(245,246,249,.96);backdrop-filter:blur(6px);border-bottom:1px solid var(--line);padding:14px 0}
.svc-toolbar .wrap{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.svc-searchbox{position:relative;flex:1;min-width:200px}
.svc-searchbox input{width:100%;padding:14px 14px 14px 42px;border:2px solid var(--line);border-radius:12px;font-size:16px;background:#fff;color:var(--ink)}
.svc-searchbox input:focus{outline:none;border-color:var(--gold)}
.svc-searchbox .si{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:#9aa1ac;font-size:17px}
.svc-selbtn{display:inline-flex;align-items:center;gap:8px;background:var(--navy);color:#fff;border:0;border-radius:12px;padding:13px 18px;font-weight:800;cursor:pointer;font-size:14.5px;white-space:nowrap}
.svc-selbtn .cnt{background:var(--gold);color:var(--navy);border-radius:20px;min-width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;font-size:13px;padding:0 6px}
.svc-chips{display:flex;gap:8px;overflow-x:auto;padding:12px 0 2px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.svc-chips::-webkit-scrollbar{display:none}
.svc-chip{flex:0 0 auto;border:1.5px solid var(--line);background:#fff;border-radius:30px;padding:7px 14px;font-size:13px;font-weight:700;color:var(--slate);cursor:pointer;white-space:nowrap}
.svc-chip.on{background:var(--navy);color:#fff;border-color:var(--navy)}
.svc-note{background:#fff7e6;border:1px solid #f0dca8;color:#7a5b16;border-radius:12px;padding:12px 15px;font-size:14px;margin:16px 0;line-height:1.5}
.svc-note b{color:#5c4410}
.svc-layout{display:grid;grid-template-columns:1fr;gap:22px;margin-top:6px}
.svc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(258px,1fr));gap:14px}
.svc-card{background:#fff;border:2px solid var(--line);border-radius:14px;padding:16px 16px 14px;position:relative;transition:.13s;min-width:0;display:flex;flex-direction:column}
.svc-card:hover{border-color:#c9cfdb;box-shadow:0 6px 18px rgba(15,39,68,.07)}
.svc-card.on{border-color:var(--green);box-shadow:0 6px 22px rgba(27,67,50,.14)}
.svc-card .tick{position:absolute;top:13px;right:13px;width:24px;height:24px;border-radius:50%;border:2px solid #cdd3de;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:14px;transition:.12s}
.svc-card.on .tick{background:var(--green);border-color:var(--green)}
.svc-card.on .tick:after{content:"\2713"}
.svc-card .ic{font-size:22px;margin-bottom:7px}
.svc-card h3{font-size:16.5px;line-height:1.25;margin:0 36px 6px 0;font-weight:800}
.svc-card .price{display:inline-block;font-size:13px;font-weight:800;color:var(--green);background:#eaf3ee;border-radius:20px;padding:3px 11px;margin-bottom:8px;white-space:nowrap}
.svc-card .price.mo{color:#7c3aed;background:#f1ecfd}
.svc-card .blurb{font-size:13.3px;line-height:1.55;color:#3b4351;margin:0 0 12px;flex:1}
.svc-card .cardbtns{display:flex;gap:7px;flex-wrap:wrap;margin-top:auto}
.svc-card .pf{font-size:12.5px;font-weight:700;color:var(--gold);background:none;border:0;cursor:pointer;padding:6px 0;text-decoration:underline}
.svc-empty{text-align:center;color:#7b8390;padding:50px 16px;font-size:15px}

/* selected panel (desktop sidebar) */
.svc-selpanel{display:none}
@media(min-width:1000px){
  .svc-layout{grid-template-columns:1fr 320px}
  .svc-selpanel{display:block;position:sticky;top:84px;align-self:start;background:#fff;border:1px solid var(--line);border-radius:16px;padding:18px;max-height:calc(100vh - 110px);overflow:auto}
  .svc-fab{display:none !important}
}
.svc-selpanel h3,.svc-drawer h3{font-size:16px;margin:0 0 4px}
.svc-selpanel .ph,.svc-drawer .ph{color:#7b8390;font-size:13px;margin:0 0 14px;line-height:1.45}
.svc-sellist{list-style:none;margin:0 0 14px;padding:0;display:flex;flex-direction:column;gap:8px}
.svc-selitem{display:flex;align-items:flex-start;gap:8px;background:#f7f8fb;border:1px solid var(--line);border-radius:10px;padding:9px 11px;font-size:13.5px}
.svc-selitem .nm{font-weight:700;color:var(--navy);flex:1;line-height:1.3}
.svc-selitem .pr{color:var(--green);font-size:12px;font-weight:700;white-space:nowrap}
.svc-selitem .rm{background:none;border:0;color:#b04a4a;font-size:18px;line-height:1;cursor:pointer;padding:0 2px;font-weight:800}
.svc-selempty{color:#9aa1ac;font-size:13.5px;text-align:center;padding:18px 0}

/* mobile floating selected bar + drawer */
.svc-fab{position:fixed;left:0;right:0;bottom:0;z-index:55;background:#fff;border-top:1px solid var(--line);box-shadow:0 -4px 18px rgba(15,39,68,.12);padding:11px 16px;display:flex;align-items:center;gap:12px}
.svc-fab .txt{flex:1;font-size:13.5px;color:var(--slate)} .svc-fab .txt b{color:var(--navy)}
.svc-drawer{position:fixed;top:0;right:0;bottom:0;width:min(370px,88vw);background:#fff;z-index:70;box-shadow:-8px 0 30px rgba(0,0,0,.25);transform:translateX(100%);transition:transform .26s ease;padding:20px 18px;overflow:auto;display:flex;flex-direction:column}
.svc-drawer.open{transform:translateX(0)}
.svc-drawer .dch{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}
.svc-drawer .dclose{background:none;border:0;font-size:26px;line-height:1;color:#7b8390;cursor:pointer;padding:0}
.svc-scrim{position:fixed;inset:0;background:rgba(15,39,68,.45);z-index:65;opacity:0;visibility:hidden;transition:.2s}
.svc-scrim.show{opacity:1;visibility:visible}

/* ===== REFINEMENT ===== */
.svc-refine{padding:30px 0 130px}
.svc-refine .rhead{text-align:center;margin-bottom:8px}
.svc-refine .rhead h2{font-size:26px;font-weight:800}
.svc-refine .rhead p{color:#6b7480;font-size:15px;margin:6px 0 0}
.svc-refbar{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin:18px 0 24px}
.svc-refcard{background:#fff;border:1px solid var(--line);border-radius:16px;padding:20px 20px 16px;margin:0 0 16px;box-shadow:0 2px 10px rgba(15,39,68,.05)}
.svc-refcard .rc-top{display:flex;align-items:flex-start;gap:10px;border-bottom:1px solid var(--line);padding-bottom:12px;margin-bottom:14px;flex-wrap:wrap}
.svc-refcard .rc-ic{font-size:22px}
.svc-refcard .rc-nm{flex:1;min-width:140px}
.svc-refcard .rc-nm h3{font-size:18px;font-weight:800}
.svc-refcard .rc-nm .pr{color:var(--green);font-size:13px;font-weight:800}
.svc-refcard .rc-act{display:flex;gap:7px;flex-wrap:wrap}
.svc-field{margin:0 0 16px}
.svc-field>.q{display:block;font-weight:800;color:var(--navy);font-size:14.5px;margin:0 0 9px}
.svc-field textarea{min-height:74px}
.svc-done-row{text-align:center;margin-top:8px}

/* ===== MODAL (portfolio + quote + thanks) ===== */
.svc-modal{position:fixed;inset:0;z-index:90;display:flex;align-items:center;justify-content:center;padding:18px;background:rgba(15,39,68,.55);opacity:0;visibility:hidden;transition:.2s}
.svc-modal.open{opacity:1;visibility:visible}
.svc-modal-card{background:#fff;border-radius:18px;max-width:920px;width:100%;max-height:88vh;overflow:auto;padding:22px;position:relative}
.svc-modal-card.sm{max-width:520px}
.svc-modal .mclose{position:absolute;top:12px;right:14px;background:#f1f3f7;border:0;width:36px;height:36px;border-radius:50%;font-size:22px;line-height:1;color:#5b6470;cursor:pointer}
.svc-modal h2{font-size:22px;font-weight:800;margin:0 6px 4px 0}
.svc-modal .msub{color:#6b7480;font-size:14px;margin:0 0 16px}
.svc-pfgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}
.svc-pfgrid img{width:100%;height:150px;object-fit:contain;background:#f5f6f9;border:1px solid var(--line);border-radius:10px;padding:6px;cursor:zoom-in}
.svc-modal .mfield{margin:0 0 13px}
.svc-modal .mfield label{display:block;font-weight:700;font-size:13.5px;color:var(--navy);margin:0 0 5px}
.svc-modal .mrow{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.svc-thanks{text-align:center;padding:14px 6px}
.svc-thanks .big{font-size:46px;margin-bottom:8px}
.svc-thanks h2{font-size:24px;margin-bottom:8px}
.svc-thanks p{color:#5b6470;font-size:15px;line-height:1.6;max-width:420px;margin:0 auto 8px}
.svc-lightbox{position:fixed;inset:0;z-index:100;background:rgba(0,0,0,.9);display:flex;align-items:center;justify-content:center;padding:24px;opacity:0;visibility:hidden;transition:.2s;cursor:zoom-out}
.svc-lightbox.open{opacity:1;visibility:visible}
.svc-lightbox img{max-width:96vw;max-height:92vh;object-fit:contain;border-radius:8px}

@media(max-width:600px){
  .svc-welcome h1{font-size:27px} .svc-welcome{padding:40px 0 48px}
  .svc-quiz .row2{grid-template-columns:1fr}
  .svc-modal .mrow{grid-template-columns:1fr}
  .svc-refcard .rc-act{width:100%}
  .svc-modal-card{padding:18px}
}
