

:root {
  --black:  #0c0f12;
  --dark:   #111518;
  --mid:    #161c24;
  --panel:  #1a2030;
  --slate:  #3A4250;
  --cyan:   #29B5E8;
  --orange: #E85D20;
  --text:   #c8d8e4;
  --muted:  #5a7080;
  --border: rgba(41,181,232,0.14);
  --f-disp: 'Nunito Sans', sans-serif;
  --f-mono: 'Share Tech Mono', monospace;
}






/* ── TOP STRIPE ── */
.top-stripe {
  height:2px;
  background:linear-gradient(90deg, var(--orange), var(--cyan) 55%, transparent);
  margin-top:64px; /* push below fixed site header */
}

/* ── HEADER ── */











/* ── LAYOUT ── */
.cfg-layout {
  display:grid;
  grid-template-columns:1fr 380px;
  min-height:calc(100vh - 58px);
}

/* ── LEFT — VIEWER ── */
.cfg-viewer {
  background:var(--dark);
  display:flex; flex-direction:column;
  border-right:1px solid var(--border);
}

/* Angle tabs */
.angle-tabs {
  display:flex; gap:0;
  border-bottom:1px solid var(--border);
  background:var(--black);
  padding:0 24px;
}
.angle-tab {
  padding:10px 16px;
  font-family:var(--f-mono); font-size:9px; letter-spacing:.18em;
  text-transform:uppercase; color:var(--muted);
  cursor:pointer; border-bottom:2px solid transparent;
  transition:color .2s, border-color .2s;
  white-space:nowrap;
}
.angle-tab.active { color:var(--cyan); border-bottom-color:var(--cyan); }
.angle-tab:hover { color:var(--text); }

/* Boat canvas */
.boat-canvas {
  flex:1; position:relative;
  display:flex; align-items:center; justify-content:center;
  padding:48px;
  min-height:420px;
  overflow:hidden;
}
/* Blueprint grid */
.boat-canvas::before {
  content:'';
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(41,181,232,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(41,181,232,.04) 1px, transparent 1px);
  background-size:40px 40px;
}
.boat-img-wrap { position:relative; z-index:2; width:100%; max-width:680px; }
.boat-img-wrap img {
  width:100%; height:auto;
  filter:drop-shadow(0 20px 60px rgba(0,0,0,.6));
  transition:opacity .4s;
}
.boat-img-wrap img.fading { opacity:0; }

/* Corner brackets */
.bracket { position:absolute; width:20px; height:20px; }
.bracket.tl { top:16px; left:16px; border-top:1.5px solid rgba(41,181,232,.3); border-left:1.5px solid rgba(41,181,232,.3); }
.bracket.tr { top:16px; right:16px; border-top:1.5px solid rgba(41,181,232,.3); border-right:1.5px solid rgba(41,181,232,.3); }
.bracket.bl { bottom:16px; left:16px; border-bottom:1.5px solid rgba(41,181,232,.3); border-left:1.5px solid rgba(41,181,232,.3); }
.bracket.br { bottom:16px; right:16px; border-bottom:1.5px solid rgba(41,181,232,.3); border-right:1.5px solid rgba(41,181,232,.3); }

/* Scan line animation */
.scan-line {
  position:absolute; left:0; right:0; height:1px;
  background:linear-gradient(90deg, transparent, rgba(41,181,232,.4), transparent);
  animation:scan 4s linear infinite;
  pointer-events:none; z-index:3;
}
@keyframes scan { 0%{top:10%} 100%{top:90%} }

/* Model info strip */
.model-strip {
  background:rgba(12,15,18,.8);
  border-top:1px solid var(--border);
  padding:14px 28px;
  display:flex; align-items:center; gap:24px;
}
.ms-badge img { height:40px; width:auto; }
.ms-name {
  font-weight:900; font-size:18px; letter-spacing:.06em;
  text-transform:uppercase; color:#fff;
}
.ms-class {
  font-family:var(--f-mono); font-size:9px; letter-spacing:.18em;
  color:rgba(41,181,232,.5); text-transform:uppercase;
}
.ms-right { margin-left:auto; display:flex; gap:20px; }
.ms-stat {}
.ms-stat-lbl {
  font-family:var(--f-mono); font-size:8px; letter-spacing:.16em;
  color:var(--muted); text-transform:uppercase; display:block; margin-bottom:2px;
}
.ms-stat-val {
  font-weight:700; font-size:16px; color:var(--cyan); letter-spacing:.04em;
}

/* ── RIGHT — PANEL ── */
.cfg-panel {
  background:var(--panel);
  display:flex; flex-direction:column;
  max-height:calc(100vh - 58px);
  overflow:hidden; /* panel itself doesn't scroll */
}

/* Scrollable content area inside panel */
.cfg-panel-scroll {
  flex:1;
  overflow-y:auto;
  overflow-x:hidden;
}
.cfg-panel-scroll::-webkit-scrollbar { width:4px; }
.cfg-panel-scroll::-webkit-scrollbar-track { background:transparent; }
.cfg-panel-scroll::-webkit-scrollbar-thumb { background:rgba(41,181,232,.2); }

/* Panel section */
.panel-section {
  padding:20px 24px;
  border-bottom:1px solid rgba(255,255,255,.05);
}
.panel-section:last-child { border-bottom:none; }
.panel-section-title {
  font-family:var(--f-disp);
  font-weight:900;
  font-size:14px;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:#fff;
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:14px;
}
.panel-section-title .step-tag {
  font-family:var(--f-mono);
  font-size:8px; letter-spacing:.2em;
  color:rgba(41,181,232,.35);
  font-weight:400;
  text-transform:uppercase;
}

/* Component accordion */
.component-list { display:flex; flex-direction:column; gap:2px; }
.component-item {
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.05);
  overflow:hidden;
  transition:border-color .2s;
}
.component-item.selected { border-color:rgba(41,181,232,.2); }

.component-header {
  display:flex; align-items:center; gap:10px;
  padding:10px 14px; cursor:pointer;
  transition:background .15s;
}
.component-header:hover { background:rgba(255,255,255,.03); }

.comp-num {
  font-family:var(--f-mono); font-size:10px;
  color:rgba(41,181,232,.3); width:20px; flex-shrink:0;
}
.comp-name {
  font-weight:600; font-size:12px; letter-spacing:.06em;
  text-transform:uppercase; color:var(--text); flex:1;
}
.comp-selected-swatch {
  width:20px; height:20px; border-radius:50%;
  border:2px solid rgba(255,255,255,.15);
  flex-shrink:0; transition:border-color .2s;
}
.component-item.selected .comp-selected-swatch { border-color:var(--cyan); }
.comp-selected-name {
  font-family:var(--f-mono); font-size:8px; letter-spacing:.1em;
  color:var(--muted); text-transform:uppercase;
  white-space:nowrap;
}
.comp-chevron {
  width:6px; height:6px;
  border-right:1.5px solid var(--muted);
  border-bottom:1.5px solid var(--muted);
  transform:rotate(45deg); transition:transform .2s;
  flex-shrink:0;
}
.component-item.open .comp-chevron { transform:rotate(-135deg); }

/* Colour picker dropdown */
.colour-picker {
  display:none; padding:14px;
  background:rgba(0,0,0,.2);
  border-top:1px solid rgba(255,255,255,.05);
}
.component-item.open .colour-picker { display:block; }

.colour-grid {
  display:grid; grid-template-columns:repeat(5,1fr);
  gap:6px;
}
.colour-option {
  display:flex; flex-direction:column; align-items:center; gap:4px;
  cursor:pointer;
}
.colour-dot {
  width:32px; height:32px; border-radius:50%;
  border:2px solid rgba(255,255,255,.12);
  transition:border-color .15s, transform .15s;
  position:relative;
}
.colour-option:hover .colour-dot { border-color:rgba(255,255,255,.4); transform:scale(1.1); }
.colour-option.selected .colour-dot { border-color:var(--cyan); }
.colour-option.selected .colour-dot::after {
  content:'';
  position:absolute; inset:3px;
  border-radius:50%;
  border:2px solid rgba(255,255,255,.6);
}
.colour-name {
  font-family:var(--f-mono); font-size:7px; letter-spacing:.08em;
  color:var(--muted); text-transform:uppercase; text-align:center;
  line-height:1.2;
}
.colour-option.selected .colour-name { color:var(--cyan); }

/* Colour summary bar */
.colour-summary {
  padding:16px 24px;
  background:rgba(0,0,0,.2);
  border-bottom:1px solid var(--border);
}
.cs-title {
  font-family:var(--f-mono); font-size:8px; letter-spacing:.2em;
  color:rgba(41,181,232,.4); text-transform:uppercase; margin-bottom:10px;
}
.cs-swatches {
  display:grid; grid-template-columns:repeat(8,1fr); gap:4px;
}
.cs-swatch-item { display:flex; flex-direction:column; align-items:center; gap:3px; }
.cs-dot {
  width:28px; height:28px; border-radius:4px;
  border:1px solid rgba(255,255,255,.1);
}
.cs-lbl {
  font-family:var(--f-mono); font-size:6px; letter-spacing:.06em;
  color:var(--muted); text-transform:uppercase; text-align:center;
  line-height:1.2;
}

/* Model selector */
.model-selector { display:grid; grid-template-columns:1fr 1fr; gap:4px; }
.model-opt {
  padding:12px; border:1px solid rgba(255,255,255,.08);
  cursor:pointer; transition:all .2s; text-align:center;
  background:rgba(0,0,0,.15);
}
.model-opt.active { border-color:var(--cyan); background:rgba(41,181,232,.06); }
.model-opt img { height:28px; width:auto; margin:0 auto 6px; }
.model-opt-name {
  font-weight:700; font-size:11px; letter-spacing:.08em;
  text-transform:uppercase; color:#fff; display:block;
}
.model-opt-class {
  font-family:var(--f-mono); font-size:8px; letter-spacing:.1em;
  color:var(--muted); display:block; margin-top:2px;
}
.model-opt.active .model-opt-class { color:var(--cyan); }

/* Pilot hand */
.hand-selector { display:grid; grid-template-columns:1fr 1fr; gap:4px; }
.hand-opt {
  padding:10px 14px; border:1px solid rgba(255,255,255,.08);
  cursor:pointer; transition:all .2s; text-align:center;
  font-weight:600; font-size:12px; letter-spacing:.1em;
  text-transform:uppercase; color:var(--muted);
  background:rgba(0,0,0,.15);
}
.hand-opt.active { border-color:var(--orange); color:var(--orange); background:rgba(232,93,32,.06); }

/* Input */
.cfg-input {
  width:100%;
  background:rgba(0,0,0,.25);
  border:1px solid rgba(255,255,255,.08);
  padding:10px 14px;
  font-family:var(--f-disp); font-size:13px;
  color:var(--text); outline:none;
  transition:border-color .2s;
}
.cfg-input:focus { border-color:rgba(41,181,232,.35); }
.cfg-input::placeholder { color:rgba(90,112,128,.5); }
.cfg-label {
  font-family:var(--f-mono); font-size:8px; letter-spacing:.2em;
  text-transform:uppercase; color:rgba(41,181,232,.35);
  display:block; margin-bottom:6px;
}

/* Notes */
.cfg-textarea {
  width:100%; height:70px; resize:none;
  background:rgba(0,0,0,.25);
  border:1px solid rgba(255,255,255,.08);
  padding:10px 14px;
  font-family:var(--f-disp); font-size:13px; color:var(--text);
  outline:none; transition:border-color .2s;
}
.cfg-textarea:focus { border-color:rgba(41,181,232,.35); }

/* CTA */
.cfg-cta {
  padding:16px 24px;
  display:flex; flex-direction:column; gap:8px;
  background:rgba(12,15,18,.95);
  border-top:1px solid var(--border);
  flex-shrink:0; /* never shrink — always visible */
}
.btn-full {
  display:block; width:100%; padding:13px;
  font-family:var(--f-disp); font-weight:700;
  font-size:13px; letter-spacing:.16em; text-transform:uppercase;
  cursor:pointer; border:none; text-align:center; transition:all .2s;
}
.btn-submit { background:var(--cyan); color:var(--black); }
.btn-submit:hover { background:#44c8f5; }
.btn-download { background:transparent; border:1px solid rgba(200,216,228,.18); color:var(--muted); }
.btn-download:hover { border-color:rgba(200,216,228,.35); color:var(--text); }
.cfg-cta-note {
  font-family:var(--f-mono); font-size:8px; letter-spacing:.12em;
  color:var(--muted); text-align:center; text-transform:uppercase;
}

/* Extras legend overlay */
.extras-legend {
  position:absolute;
  bottom:60px; left:20px;
  z-index:10;
  background:rgba(12,15,18,.92);
  border:1px solid var(--border);
  backdrop-filter:blur(10px);
  padding:12px 16px;
  min-width:200px;
  display:none;
}
.extras-legend.visible { display:block; }
.extras-legend::before {
  content:'';
  position:absolute; top:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg, var(--orange), transparent);
}
.el-title {
  font-family:var(--f-mono); font-size:8px; letter-spacing:.22em;
  text-transform:uppercase; color:rgba(232,93,32,.6);
  margin-bottom:10px; display:block;
}
.el-items { display:flex; flex-direction:column; gap:6px; }
.el-item {
  display:flex; align-items:center; gap:8px;
  font-size:11px; color:var(--text);
}
.el-dot {
  width:8px; height:8px; border-radius:50%;
  background:var(--orange); flex-shrink:0;
}

.extra-item-warning.selected {
  border-color:rgba(204,31,31,.4);
  background:rgba(204,31,31,.06);
}
.extra-item-warning.selected .extra-dot {
  background:var(--red); border-color:var(--red);
}

.extra-item {
  display:flex; align-items:center; justify-content:space-between;
  padding:10px 14px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.05);
  cursor:pointer; transition:all .2s; gap:10px;
}
.extra-item:hover { background:rgba(255,255,255,.06); }
.extra-item.selected {
  border-color:rgba(232,93,32,.3);
  background:rgba(232,93,32,.05);
}
.extra-item-left { display:flex; align-items:center; gap:10px; flex:1; }
.extra-dot {
  width:10px; height:10px; border-radius:50%;
  border:2px solid var(--muted); flex-shrink:0;
  transition:all .2s;
}
.extra-item.selected .extra-dot {
  background:var(--orange); border-color:var(--orange);
}
.extra-name {
  font-weight:600; font-size:12px; letter-spacing:.05em;
  text-transform:uppercase; color:#fff;
  transition:color .2s;
}
.extra-item.selected .extra-name { color:#fff; }
.extra-tag {
  font-family:var(--f-mono); font-size:8px; letter-spacing:.1em;
  color:rgba(232,93,32,.5); text-transform:uppercase;
  opacity:0; transition:opacity .2s;
}
.extra-item.selected .extra-tag { opacity:1; }

  margin:0 24px 16px;
  padding:12px 14px;
  border:1px solid rgba(232,93,32,.2);
  background:rgba(232,93,32,.05);
  border-left:3px solid var(--orange);
}
.p2-title {
  font-family:var(--f-mono); font-size:8px; letter-spacing:.2em;
  text-transform:uppercase; color:var(--orange); margin-bottom:3px;
}
.p2-text {
  font-size:11px; color:rgba(200,216,228,.45); line-height:1.6;
}

/* Toast */
.toast {
  position:fixed; bottom:32px; left:50%; transform:translateX(-50%) translateY(20px);
  background:rgba(41,181,232,.95); color:var(--black);
  padding:12px 28px;
  font-family:var(--f-disp); font-weight:700;
  font-size:13px; letter-spacing:.12em; text-transform:uppercase;
  opacity:0; transition:opacity .3s, transform .3s;
  pointer-events:none; z-index:200;
  box-shadow:0 8px 32px rgba(0,0,0,.4);
}
.toast.show { opacity:1; transform:translateX(-50%) translateY(0); }

/* Responsive */
@media (max-width:900px) {
  .top-stripe { margin-top:56px; }
  .cfg-layout {
    grid-template-columns:1fr;
    min-height:auto;
  }
  .cfg-viewer {
    position:sticky;
    top:58px;
    z-index:50;
    height:25vh;
    min-height:180px;
    max-height:260px;
    border-right:none;
    border-bottom:1px solid var(--border);
    flex-direction:column;
  }
  .boat-canvas {
    flex:1;
    min-height:0;
    padding:0;
    overflow:hidden;
  }
  .boat-img-wrap {
    max-width:none;
    width:100%;
    height:100%;
    display:flex;
    align-items:center;
    justify-content:center;
    padding:8% 8% 4% 8%; /* 8% crop all around, less bottom to allow strip */
  }
  .boat-img-wrap img {
    width:auto;
    height:100%;
    max-height:100%;
    max-width:100%;
    object-fit:contain;
  }
  .bracket { display:none; }
  .angle-tabs { overflow-x:auto; padding:0 12px; white-space:nowrap; }
  .angle-tabs::-webkit-scrollbar { display:none; }
  .model-strip { padding:8px 14px; gap:12px; }
  .ms-badge img { height:28px; }
  .ms-name { font-size:14px; }
  .ms-right { gap:12px; }
  .cfg-panel { max-height:none; }
  .scan-line { display:none; }
  .extras-legend { bottom:44px; }
}
@media (max-width:600px) {
  
  
  .colour-grid { grid-template-columns:repeat(5,1fr); }
  .cs-swatches { grid-template-columns:repeat(4,1fr); }
}



/* ── Targeted overrides ── */
:root { --cfg-offset:64px; }
@media (max-width:900px) { :root { --cfg-offset:56px; } }



@media screen and (max-width:782px) {  }

#model-name-strip, #model-class-strip { display:none !important; }
.model-strip { padding:6px 14px !important; gap:12px !important; }
.ms-badge img { height:26px !important; }
.cfg-viewer { position:sticky !important; top:var(--cfg-offset) !important; height:calc(100vh - var(--cfg-offset)) !important; overflow:hidden !important; }
.cfg-panel { height:calc(100vh - var(--cfg-offset)) !important; max-height:calc(100vh - var(--cfg-offset)) !important; position:sticky !important; top:var(--cfg-offset) !important; overflow:hidden !important; }
.cfg-panel-scroll::-webkit-scrollbar { width:6px !important; }
.cfg-panel-scroll::-webkit-scrollbar-track { background:rgba(255,255,255,.06) !important; }
.cfg-panel-scroll::-webkit-scrollbar-thumb { background:rgba(41,181,232,.55) !important; border-radius:2px !important; }
.cs-lbl { color:#fff !important; }
@media (min-width:901px) {
  .cfg-panel-scroll { scroll-snap-type:y proximity; }
  .panel-section, .colour-summary { scroll-snap-align:start; }
}
@media (max-width:900px) {
  .cfg-viewer { height:auto !important; top:56px !important; }
  .boat-canvas { height:36vw !important; min-height:160px !important; max-height:220px !important; padding:0 !important; display:flex !important; align-items:center !important; justify-content:center !important; }
  .boat-img-wrap { max-width:none !important; width:100% !important; height:100% !important; display:flex !important; align-items:center !important; justify-content:center !important; padding:4% 6% !important; }
  .boat-img-wrap img { width:auto !important; height:100% !important; max-width:100% !important; max-height:100% !important; object-fit:contain !important; }
  .cfg-panel { height:auto !important; max-height:none !important; position:static !important; overflow-y:visible !important; }
  .admin-bar .cfg-viewer { top:calc(108px + 14px) !important; }
}

/* ── Canvas label — replaces cfg-header ── */
.cfg-canvas-label {
  position:absolute;
  top:12px; left:14px;
  z-index:10;
  font-family:var(--f-mono);
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:#fff;
  pointer-events:none;
  text-shadow:0 1px 4px rgba(0,0,0,.6);
}

/* Ensure panel sections scroll into view below sticky viewer */
@media (max-width:900px) {
  .panel-section,
  .colour-summary {
    scroll-margin-top: calc(var(--cfg-offset) + 10px);
  }
}
