/* ==========================================================================
   NORTH GEORGIA AWARDS — TROPHY BUILDER  |  builder.css
   Brand: navy #233354 / gold #d6c390
   ========================================================================== */

:root{
  --navy:#233354;
  --navy-deep:#1a2740;
  --navy-soft:#2e4068;
  --gold:#d6c390;
  --gold-bright:#e8d9a8;
  --gold-deep:#b89f5e;
  --ink:#1d2433;
  --paper:#f4f5f7;
  --paper-warm:#eef0f3;
  --white:#ffffff;
  --line:#dde1e8;
  --muted:#7b8499;
  --ok:#3a7d52;
  --shadow-sm:0 2px 8px rgba(28,38,64,.08);
  --shadow-md:0 6px 22px rgba(28,38,64,.13);
  --shadow-lg:0 18px 50px rgba(20,30,55,.30);
  --radius:14px;
  --radius-sm:9px;
  --display:'Fraunces',Georgia,serif;
  --body:'Outfit',-apple-system,BlinkMacSystemFont,sans-serif;
  --ease:.28s cubic-bezier(.4,.1,.2,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:var(--body);
  background:var(--paper);
  color:var(--ink);
  font-size:15px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  display:flex;flex-direction:column;
  min-height:100vh;
}

/* ============================ HEADER ============================ */
.tb-header{
  background:var(--navy);
  border-bottom:3px solid var(--gold);
  flex-shrink:0;
}
.tb-header-inner{
  max-width:1320px;margin:0 auto;
  padding:12px 22px;
  display:flex;align-items:center;justify-content:space-between;
}
.tb-brand{display:flex;align-items:center;gap:13px}
.tb-logo-mark{
  width:44px;height:44px;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.tb-logo-mark svg{
  width:100%;height:100%;
  fill:var(--gold);
  filter:drop-shadow(0 1px 1px rgba(0,0,0,.25));
}
.tb-brand-text{display:flex;flex-direction:column;line-height:1.15}
.tb-brand-name{color:var(--white);font-weight:600;font-size:15px}
.tb-brand-sub{
  color:var(--gold);font-size:11px;font-weight:500;
  letter-spacing:1.5px;text-transform:uppercase;
}
.tb-cart-toggle{
  display:flex;align-items:center;gap:8px;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(214,195,144,.32);
  color:var(--white);
  padding:9px 15px;border-radius:10px;
  font-family:var(--body);font-size:13.5px;font-weight:500;
  cursor:pointer;transition:background var(--ease);
}
.tb-cart-toggle:hover{background:rgba(255,255,255,.14)}
.tb-cart-toggle svg{color:var(--gold)}
.tb-cart-count{
  background:var(--gold);color:var(--navy-deep);
  font-weight:700;font-size:12px;
  min-width:20px;height:20px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  padding:0 6px;
}

/* ============================ PROGRESS ============================ */
.tb-progress{
  background:var(--white);
  border-bottom:1px solid var(--line);
  padding:14px 22px;
  display:flex;justify-content:center;gap:6px;
  flex-shrink:0;
  overflow-x:auto;
}
.tb-pstep{
  display:flex;align-items:center;gap:9px;
  flex-shrink:0;
}
.tb-pstep-dot{
  width:27px;height:27px;border-radius:50%;
  border:2px solid var(--line);
  background:var(--white);color:var(--muted);
  font-size:12.5px;font-weight:700;
  display:flex;align-items:center;justify-content:center;
  transition:all var(--ease);
}
.tb-pstep-label{
  font-size:12.5px;font-weight:500;color:var(--muted);
  white-space:nowrap;
}
.tb-pstep-line{
  width:26px;height:2px;background:var(--line);flex-shrink:0;
}
.tb-pstep.active .tb-pstep-dot{
  border-color:var(--navy);background:var(--navy);color:var(--white);
}
.tb-pstep.active .tb-pstep-label{color:var(--navy);font-weight:600}
.tb-pstep.done .tb-pstep-dot{
  border-color:var(--gold-deep);background:var(--gold);color:var(--navy-deep);
}
.tb-pstep.done .tb-pstep-label{color:var(--ink)}
.tb-pstep.clickable{cursor:pointer}

/* ============================ MAIN LAYOUT ============================ */
.tb-main{
  flex:1;
  max-width:1320px;width:100%;margin:0 auto;
  padding:22px;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:22px;
  min-height:0;
}

/* ---------- PREVIEW PANE ---------- */
.tb-preview-pane{
  display:flex;flex-direction:column;gap:14px;
}
.tb-preview-frame{
  flex:1;
  background:
    radial-gradient(ellipse at 50% 38%,rgba(255,255,255,.9),transparent 62%),
    linear-gradient(160deg,#e9ebef 0%,#dfe2e8 55%,#d4d8e0 100%);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow-sm),inset 0 1px 0 rgba(255,255,255,.6);
  display:flex;align-items:center;justify-content:center;
  padding:18px;
  min-height:380px;position:relative;overflow:hidden;
}
.tb-preview-stage{
  display:flex;align-items:flex-end;justify-content:center;
  width:100%;height:100%;position:relative;z-index:1;
}
.tb-preview-readout{
  background:var(--white);
  border:1px solid var(--line);
  border-radius:var(--radius-sm);
  padding:13px 16px;
  display:flex;flex-wrap:wrap;gap:7px 18px;
}
.tb-ro-item{display:flex;flex-direction:column;gap:1px}
.tb-ro-k{font-size:10.5px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);font-weight:600}
.tb-ro-v{font-size:13.5px;font-weight:600;color:var(--ink)}

/* trophy preview pieces */
.pv-trophy{position:relative;display:flex;flex-direction:column;align-items:center;
  transition:transform var(--ease)}
.pv-topper{filter:drop-shadow(3px 5px 5px rgba(0,0,0,.28));z-index:5;display:block}
.pv-topper img{display:block;height:100%;width:auto}
.pv-column{
  width:46px;border-radius:3px;
  background-size:100% auto;background-repeat:repeat-y;
  box-shadow:inset 9px 0 13px -6px rgba(0,0,0,.45),inset -9px 0 13px -6px rgba(0,0,0,.45);
  position:relative;z-index:3;
}
.pv-cap{
  width:54px;height:11px;border-radius:50%;
  background:linear-gradient(90deg,var(--gold-deep),var(--gold-bright),var(--gold-deep));
  box-shadow:0 2px 4px rgba(0,0,0,.25);z-index:4;
}
.pv-base{
  background-size:cover;background-position:center;
  border-radius:4px;
  box-shadow:0 5px 12px rgba(0,0,0,.32),inset 0 2px 3px rgba(255,255,255,.18);
  z-index:2;
}
.pv-plate{
  position:absolute;left:50%;transform:translateX(-50%);
  background:linear-gradient(180deg,#fdb931,#f5d683 50%,#c49205);
  border-radius:2px;
  box-shadow:0 1px 3px rgba(0,0,0,.4);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  z-index:6;
}
.pv-plate span{
  font-family:var(--display);color:#3a2c08;
  font-size:8px;line-height:1.25;font-weight:600;
  white-space:nowrap;
}
.pv-trim{
  position:absolute;z-index:7;
  filter:drop-shadow(2px 3px 4px rgba(0,0,0,.3));
}
.pv-trim img{display:block;width:100%;height:auto}
.pv-multi-row{display:flex;align-items:flex-end;gap:0;position:relative}
.pv-figure-base{filter:drop-shadow(3px 5px 6px rgba(0,0,0,.3));z-index:5}
.pv-figure-base img{display:block;height:100%;width:auto}
.pv-empty{
  position:absolute;inset:0;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:14px;text-align:center;padding:30px;
  pointer-events:none;
}
.pv-empty-crown{
  width:130px;height:130px;
  fill:var(--gold);
  filter:drop-shadow(0 4px 14px rgba(35,51,84,.18));
  opacity:.88;
}
.pv-empty-title{
  font-family:var(--display);font-weight:600;
  font-size:34px;line-height:1.1;color:var(--navy);
  letter-spacing:-.5px;
}
.pv-empty-sub{
  font-size:15px;color:var(--muted);font-weight:500;
  letter-spacing:.3px;
}

/* ---------- STEP PANE ---------- */
.tb-step-pane{
  background:var(--white);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow-sm);
  display:flex;flex-direction:column;
  min-height:0;overflow:hidden;
}
.tb-step-scroll{
  flex:1;overflow-y:auto;padding:24px 26px;
}
.tb-step{display:none;animation:stepIn .35s var(--ease)}
.tb-step.active{display:block}
@keyframes stepIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

.tb-step-eyebrow{
  font-size:11.5px;font-weight:700;letter-spacing:1.4px;
  text-transform:uppercase;color:var(--gold-deep);
}
.tb-step-title{
  font-family:var(--display);font-weight:600;
  font-size:25px;line-height:1.2;color:var(--navy);
  margin:3px 0 4px;
}
.tb-step-hint{font-size:13.5px;color:var(--muted);margin-bottom:18px}

/* ---------- type cards ---------- */
.tb-type-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:12px;
}
.tb-type-card{
  border:2px solid var(--line);border-radius:var(--radius-sm);
  padding:16px 14px;cursor:pointer;background:var(--white);
  transition:all var(--ease);text-align:left;
  display:flex;flex-direction:column;gap:4px;
}
.tb-type-card:hover{border-color:var(--gold);box-shadow:var(--shadow-sm)}
.tb-type-card.selected{
  border-color:var(--navy);
  background:linear-gradient(160deg,#fbfaf6,#f4f1e6);
  box-shadow:var(--shadow-sm);
}
.tb-type-card.selected .tb-type-name{color:var(--navy)}
.tb-type-icon{
  width:34px;height:34px;border-radius:8px;
  background:var(--paper-warm);
  display:flex;align-items:center;justify-content:center;
  font-size:18px;margin-bottom:5px;
}
.tb-type-card.selected .tb-type-icon{background:var(--gold)}
.tb-type-name{font-weight:600;font-size:15px;color:var(--ink)}
.tb-type-price{font-size:12.5px;color:var(--muted)}
.tb-type-price b{color:var(--gold-deep);font-weight:700}

/* ---------- swatches ---------- */
.tb-field{margin-bottom:22px}
.tb-field-label{
  font-size:12.5px;font-weight:700;color:var(--navy);
  text-transform:uppercase;letter-spacing:.7px;
  margin-bottom:9px;display:flex;justify-content:space-between;align-items:baseline;
}
.tb-field-label .tb-fl-aux{
  font-weight:500;text-transform:none;letter-spacing:0;
  color:var(--muted);font-size:12px;
}
.tb-swatch-row{display:flex;flex-wrap:wrap;gap:10px}
.tb-swatch{
  width:50px;height:50px;border-radius:9px;
  border:2px solid var(--line);cursor:pointer;
  background-size:cover;background-position:center;
  transition:all var(--ease);position:relative;
}
.tb-swatch:hover{transform:translateY(-2px)}
.tb-swatch.selected{
  border-color:var(--navy);
  box-shadow:0 0 0 3px rgba(214,195,144,.55);
}
.tb-swatch.selected::after{
  content:"\2713";position:absolute;top:-7px;right:-7px;
  width:19px;height:19px;border-radius:50%;
  background:var(--navy);color:var(--white);
  font-size:11px;font-weight:700;
  display:flex;align-items:center;justify-content:center;
}
.tb-swatch-cap{font-size:11px;color:var(--muted);text-align:center;width:50px;margin-top:3px}
.tb-swatch-wrap{display:flex;flex-direction:column;align-items:center}

/* ---------- height slider ---------- */
.tb-slider-wrap{padding:4px 2px}
.tb-slider{
  -webkit-appearance:none;appearance:none;width:100%;height:6px;
  border-radius:4px;background:var(--paper-warm);outline:none;
}
.tb-slider::-webkit-slider-thumb{
  -webkit-appearance:none;width:24px;height:24px;border-radius:50%;
  background:linear-gradient(145deg,var(--gold-bright),var(--gold-deep));
  border:3px solid var(--white);box-shadow:var(--shadow-sm);cursor:pointer;
}
.tb-slider::-moz-range-thumb{
  width:24px;height:24px;border-radius:50%;
  background:linear-gradient(145deg,var(--gold-bright),var(--gold-deep));
  border:3px solid var(--white);box-shadow:var(--shadow-sm);cursor:pointer;
}
.tb-slider-marks{display:flex;justify-content:space-between;margin-top:6px}
.tb-slider-marks span{font-size:11.5px;color:var(--muted)}
.tb-height-now{
  font-family:var(--display);font-size:22px;font-weight:600;
  color:var(--navy);text-align:center;margin-bottom:8px;
}

/* ---------- figure / trim picker ---------- */
.tb-picker-tools{display:flex;gap:9px;margin-bottom:13px}
.tb-select{
  flex:1;padding:9px 11px;border:1.5px solid var(--line);
  border-radius:var(--radius-sm);font-family:var(--body);
  font-size:13.5px;color:var(--ink);background:var(--white);cursor:pointer;
}
.tb-select:focus{outline:none;border-color:var(--gold)}
.tb-item-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:12px;
  max-height:none;overflow-y:visible;padding:3px;
}
.tb-item{
  border:2px solid var(--line);border-radius:var(--radius-sm);
  padding:14px 8px 10px;cursor:pointer;background:var(--white);
  transition:all var(--ease);text-align:center;
}
.tb-item:hover{border-color:var(--gold)}
.tb-item.selected{border-color:var(--navy);background:#fbfaf6}
.tb-item img{
  width:100%;height:120px;object-fit:contain;display:block;margin-bottom:8px;
}
.tb-item span{font-size:12px;color:var(--ink);line-height:1.3;display:block;font-weight:500}
.tb-item .tb-item-pm{color:var(--gold-deep);font-weight:700;font-size:11px}
.tb-item-none{
  display:flex;align-items:center;justify-content:center;
  min-height:148px;color:var(--muted);font-size:13px;font-weight:600;
}
.tb-empty-msg{
  grid-column:1/-1;text-align:center;color:var(--muted);
  padding:30px 10px;font-size:13px;
}

/* ---------- engraving / plate inputs ---------- */
.tb-mode-toggle{
  display:flex;gap:7px;margin-bottom:16px;
  background:var(--paper-warm);padding:4px;border-radius:10px;
}
.tb-mode-btn{
  flex:1;padding:8px;border:none;background:transparent;
  font-family:var(--body);font-size:13px;font-weight:600;color:var(--muted);
  border-radius:7px;cursor:pointer;transition:all var(--ease);
}
.tb-mode-btn.active{background:var(--white);color:var(--navy);box-shadow:var(--shadow-sm)}
.tb-text-input{
  width:100%;padding:10px 12px;border:1.5px solid var(--line);
  border-radius:var(--radius-sm);font-family:var(--body);font-size:14px;
  margin-bottom:9px;
}
.tb-text-input:focus{outline:none;border-color:var(--gold)}
.tb-input-label{font-size:12px;color:var(--muted);font-weight:600;margin-bottom:4px;display:block}
.tb-engrave-table{width:100%;border-collapse:collapse;font-size:13px}
.tb-engrave-table th{
  background:var(--navy);color:var(--white);font-weight:600;
  font-size:11px;text-transform:uppercase;letter-spacing:.5px;
  padding:7px 6px;
}
.tb-engrave-table td{border:1px solid var(--line);padding:0}
.tb-engrave-table td.rownum{
  background:var(--paper-warm);text-align:center;font-weight:700;
  color:var(--muted);width:36px;font-size:12px;
}
.tb-engrave-table input{
  width:100%;border:none;padding:8px;font-family:var(--body);font-size:13px;
  background:transparent;
}
.tb-engrave-table input:focus{outline:none;background:#fbfaf6}
.tb-table-scroll{max-height:280px;overflow-y:auto;border:1px solid var(--line);border-radius:var(--radius-sm)}
.tb-apply-all{
  background:rgba(255,255,255,.15);color:var(--white);
  border:1px solid rgba(214,195,144,.4);
  font-family:var(--body);font-size:10px;font-weight:600;letter-spacing:.3px;
  text-transform:none;padding:3px 7px;border-radius:5px;cursor:pointer;
  transition:background var(--ease);white-space:nowrap;
}
.tb-apply-all:hover{background:rgba(255,255,255,.28)}
.tb-upload-zone{
  border:2px dashed var(--line);border-radius:var(--radius-sm);
  padding:28px 16px;text-align:center;cursor:pointer;
  transition:all var(--ease);
}
.tb-upload-zone:hover{border-color:var(--gold);background:#fbfaf6}
.tb-upload-zone svg{color:var(--gold-deep);margin-bottom:8px}
.tb-upload-zone p{font-size:13px;color:var(--ink);font-weight:600}
.tb-upload-zone small{font-size:11.5px;color:var(--muted)}

/* ---------- quantity ---------- */
.tb-qty-wrap{display:flex;align-items:center;gap:0;width:fit-content}
.tb-qty-btn{
  width:42px;height:42px;border:1.5px solid var(--line);
  background:var(--white);font-size:20px;color:var(--navy);
  cursor:pointer;transition:all var(--ease);
}
.tb-qty-btn:first-child{border-radius:9px 0 0 9px}
.tb-qty-btn:last-child{border-radius:0 9px 9px 0}
.tb-qty-btn:hover{background:var(--paper-warm)}
.tb-qty-input{
  width:64px;height:42px;border:1.5px solid var(--line);border-left:none;border-right:none;
  text-align:center;font-family:var(--body);font-size:16px;font-weight:600;
}
.tb-qty-input:focus{outline:none}

/* ---------- callouts (informational notices) ---------- */
.tb-callout{
  display:flex;gap:11px;align-items:flex-start;
  padding:13px 15px;
  background:linear-gradient(160deg,#fbf6e6,#f4eccf);
  border:1px solid var(--gold);
  border-left:4px solid var(--gold-deep);
  border-radius:var(--radius-sm);
  font-size:13px;line-height:1.45;color:var(--navy-deep);
  box-shadow:var(--shadow-sm);
}
.tb-callout svg{color:var(--gold-deep);flex-shrink:0;margin-top:1px}
.tb-callout span b{font-weight:600;color:var(--navy)}

/* ---------- review ---------- */
.tb-review-card{
  border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:16px;margin-bottom:14px;
}
.tb-review-row{
  display:flex;justify-content:space-between;
  padding:6px 0;border-bottom:1px dashed var(--line);font-size:13.5px;
}
.tb-review-row:last-child{border-bottom:none}
.tb-review-row .k{color:var(--muted)}
.tb-review-row .v{font-weight:600;color:var(--ink)}

/* ---------- step footer ---------- */
.tb-step-footer{
  border-top:1px solid var(--line);
  padding:14px 22px;
  display:flex;align-items:center;justify-content:space-between;
  flex-shrink:0;background:var(--white);
}
.tb-price-block{display:flex;flex-direction:column;line-height:1.15}
.tb-price-label{font-size:11px;text-transform:uppercase;letter-spacing:.7px;color:var(--muted);font-weight:600}
.tb-price-value{font-family:var(--display);font-size:23px;font-weight:600;color:var(--navy)}
.tb-step-nav{display:flex;gap:9px}

/* ---------- buttons ---------- */
.tb-btn{
  font-family:var(--body);font-weight:600;font-size:14px;
  padding:11px 22px;border-radius:10px;cursor:pointer;
  border:1.5px solid transparent;transition:all var(--ease);
}
.tb-btn-primary{
  background:var(--navy);color:var(--white);
}
.tb-btn-primary:hover{background:var(--navy-soft)}
.tb-btn-primary:disabled{background:var(--line);color:var(--muted);cursor:not-allowed}
.tb-btn-ghost{
  background:var(--white);color:var(--navy);border-color:var(--line);
}
.tb-btn-ghost:hover{border-color:var(--navy);background:var(--paper)}
.tb-btn-ghost:disabled{color:var(--muted);cursor:not-allowed;opacity:.5}
.tb-btn-full{width:100%;margin-top:8px}
.tb-btn-gold{
  background:linear-gradient(145deg,var(--gold-bright),var(--gold-deep));
  color:var(--navy-deep);
}

/* ============================ ORDER DRAWER ============================ */
.tb-drawer-overlay{
  position:fixed;inset:0;background:rgba(20,28,48,.55);
  backdrop-filter:blur(3px);
  opacity:0;visibility:hidden;transition:all var(--ease);z-index:90;
}
.tb-drawer-overlay.open{opacity:1;visibility:visible}
.tb-drawer{
  position:fixed;top:0;right:0;height:100%;
  width:400px;max-width:92vw;
  background:var(--white);box-shadow:var(--shadow-lg);
  transform:translateX(100%);transition:transform var(--ease);
  z-index:91;display:flex;flex-direction:column;
}
.tb-drawer.open{transform:translateX(0)}
.tb-drawer-head{
  background:var(--navy);color:var(--white);
  padding:16px 20px;display:flex;align-items:center;justify-content:space-between;
  border-bottom:3px solid var(--gold);
}
.tb-drawer-head h3{font-family:var(--display);font-weight:600;font-size:19px}
.tb-drawer-close{
  background:none;border:none;color:var(--white);font-size:26px;
  cursor:pointer;width:32px;height:32px;border-radius:7px;
}
.tb-drawer-close:hover{background:rgba(255,255,255,.15)}
.tb-drawer-body{flex:1;overflow-y:auto;padding:16px}
.tb-drawer-empty{
  text-align:center;color:var(--muted);padding:50px 20px;
  display:flex;flex-direction:column;align-items:center;gap:12px;
}
.tb-drawer-empty svg{opacity:.35}
.tb-line{
  display:flex;gap:12px;padding:13px;
  border:1px solid var(--line);border-radius:var(--radius-sm);
  margin-bottom:11px;
}
.tb-line-thumb{
  width:60px;height:72px;flex-shrink:0;
  background:var(--paper-warm);border-radius:7px;
  display:flex;align-items:flex-end;justify-content:center;
  overflow:hidden;
}
.tb-line-thumb img{max-width:100%;max-height:100%;object-fit:contain}
.tb-line-info{flex:1;min-width:0}
.tb-line-name{font-weight:600;font-size:13.5px;color:var(--navy)}
.tb-line-spec{font-size:11.5px;color:var(--muted);margin:2px 0 5px;line-height:1.4;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tb-line-foot{display:flex;align-items:center;justify-content:space-between}
.tb-line-qty{font-size:12px;color:var(--ink);font-weight:600}
.tb-line-price{font-family:var(--display);font-weight:600;color:var(--navy);font-size:15px}
.tb-line-remove{
  background:none;border:none;color:var(--muted);
  font-size:11px;cursor:pointer;text-decoration:underline;padding:0;
}
.tb-line-remove:hover{color:#b3402f}
.tb-drawer-foot{
  border-top:1px solid var(--line);padding:16px 18px;flex-shrink:0;
}
.tb-drawer-total{
  display:flex;justify-content:space-between;align-items:baseline;
  font-family:var(--display);font-size:18px;font-weight:600;color:var(--navy);
}
.tb-drawer-note{
  font-size:11px;color:var(--muted);margin:7px 0 4px;line-height:1.45;
}

/* ============================ TOAST ============================ */
.tb-toast{
  position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);
  background:var(--navy);color:var(--white);
  padding:12px 22px;border-radius:11px;
  font-size:13.5px;font-weight:500;
  box-shadow:var(--shadow-lg);
  border-left:3px solid var(--gold);
  opacity:0;visibility:hidden;transition:all var(--ease);z-index:120;
}
.tb-toast.show{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}

/* ============================ RESPONSIVE ============================ */
@media(max-width:880px){
  .tb-main{
    grid-template-columns:1fr;
    padding:14px;gap:14px;
  }
  .tb-preview-pane{order:1}
  .tb-step-pane{order:2;min-height:480px}
  .tb-preview-frame{min-height:260px;padding:18px}
  .tb-pstep-label{display:none}
  .tb-pstep-line{width:14px}
  .tb-progress{padding:11px 14px;gap:5px}
  .tb-type-grid{grid-template-columns:1fr}
  .tb-item-grid{grid-template-columns:repeat(3,1fr)}
  .tb-step-scroll{padding:18px 18px}
  .tb-step-title{font-size:21px}
  .tb-header-inner{padding:10px 14px}
}
@media(max-width:480px){
  .tb-item-grid{grid-template-columns:repeat(2,1fr)}
  .tb-step-footer{padding:11px 14px}
  .tb-btn{padding:10px 16px;font-size:13px}
}

/* ==========================================================================
   PORTED PREVIEW ENGINE  — verbatim geometry from the original Shopify
   customizer (trophy-customizer.css lines 71, 515-692). This is the proven
   rendering: anchor, columns, lid, eagles, cup, trim, base, plate.
   Do not hand-tune these numbers — they are matched to the trophy images.
   ========================================================================== */

.preview-stage{
  width:100%;height:100%;position:relative;
  display:flex;justify-content:center;align-items:flex-end;
  padding-bottom:8px;perspective:1000px;
}
.trophy-anchor{
  position:relative;width:600px;height:400px;
  display:flex;justify-content:center;
  transition:transform .3s ease,transform-origin .3s ease;
  transform-origin:bottom center;
}
.trophy-base{
  position:absolute;bottom:0;left:50%;transform:translateX(-50%);
  height:25px;background-color:#222;z-index:10;background-size:cover;
  display:flex;align-items:center;justify-content:center;
  box-shadow:inset 0 2px 4px rgba(255,255,255,.4),inset 0 -2px 4px rgba(0,0,0,.6),0 10px 25px rgba(0,0,0,.4);
  transition:all .3s ease;
}
.engraving-plate{
  width:95%;height:75%;
  background:linear-gradient(180deg,#FDB931 0%,#F5D683 50%,#C49205 100%);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  font-family:"Times New Roman",serif;font-size:8px;font-weight:bold;color:#000;
  text-transform:uppercase;
  box-shadow:0 1px 2px rgba(0,0,0,.3);border-radius:1px;
  white-space:nowrap;overflow:hidden;line-height:1.2;
}
.trophy-trim-wrapper{
  position:absolute;bottom:22px;
  display:flex;justify-content:center;align-items:flex-end;
  z-index:15;transition:all .3s ease;
}
.trophy-trim-img{
  max-width:100%;max-height:100%;object-fit:contain;
  transform-origin:bottom center;transition:transform .3s ease;
}
.trophy-column{
  position:absolute;bottom:0;width:50px;height:225px;z-index:5;
  transition:all .3s ease;background-repeat:repeat-y;background-size:100% auto;
  box-shadow:inset 8px 0 12px -4px rgba(0,0,0,.5),inset -8px 0 12px -4px rgba(0,0,0,.5);
}
.col-center-back{z-index:4;filter:brightness(.85);width:46px}
.col-back{z-index:4;filter:brightness(.65);width:48px}
.trophy-top-circle{
  position:absolute;bottom:98%;left:50%;transform:translateX(-50%);
  width:54px;height:12px;
  background:linear-gradient(90deg,#C6A664 0%,#F5D683 40%,#E6C87C 60%,#A08343 100%);
  border-radius:50%;box-shadow:0 2px 4px rgba(0,0,0,.3);z-index:6;
}
.trophy-topper-wrapper{
  position:absolute;bottom:calc(100% + 20px);left:50%;transform:translateX(-50%);
  width:140px;height:0;display:flex;justify-content:center;align-items:flex-end;z-index:20;
}
.trophy-topper-img{
  width:130px;height:auto;margin-bottom:-2px;
  filter:drop-shadow(5px 5px 10px rgba(0,0,0,.3));transition:transform .3s ease;
}
.lid-container{
  position:absolute;left:50%;transform:translateX(-50%);
  z-index:20;display:flex;justify-content:center;
}
.trophy-lid{
  position:absolute;bottom:0;left:0;right:0;height:25px;
  background-color:#222;background-size:cover;
  box-shadow:inset 0 2px 4px rgba(255,255,255,.4),inset 0 -2px 4px rgba(0,0,0,.6),0 2px 5px rgba(0,0,0,.4);
  z-index:1;
}
.lid-figure{
  position:absolute;bottom:22px;height:80px;width:80px;
  display:flex;justify-content:center;align-items:flex-end;z-index:21;
  transition:all .3s ease;
}
.lid-figure img{max-height:100%;max-width:100%;object-fit:contain}
.lid-figure.back{z-index:20;filter:brightness(.85)}
.trophy-cup{
  position:absolute;bottom:15px;left:50%;transform:translateX(-50%);
  display:flex;justify-content:center;align-items:flex-end;z-index:15;
}
.trophy-cup img{width:100%;height:auto;display:block}
.on-cup-wrapper{
  position:absolute;left:50%;transform:translateX(-50%);width:140px;height:0;
  display:flex;justify-content:center;align-items:flex-end;z-index:22;
}
.base-figure-wrapper{
  position:absolute;bottom:135%;left:50%;transform:translateX(-50%);
  width:140px;height:140px;display:flex;justify-content:center;align-items:flex-end;
  z-index:25;pointer-events:none;
}
.base-figure-img{
  max-width:100%;max-height:100%;object-fit:contain;
  filter:drop-shadow(3px 3px 8px rgba(0,0,0,.4));
}
