/* Mania Print — styles.css */

:root{
  --bg:#0a1628;
  --panel:#0f1f3a;
  --muted:#8b9dc3;
  --text:#e8f0ff;
  --accent:#4fc3f7;
  --accent-2:#2196f3;
  --accent-light:#64b5f6;
  --glass: rgba(79,195,247,0.08);
  --radius:16px;
  --maxw:100%;
  --pad:40px;
  --transition:200ms ease;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial;
}

/* Reset & base */
*{box-sizing:border-box; -webkit-tap-highlight-color:transparent}
html,body{height:%;margin:0;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}
.container{max-width:var(--maxw);margin:0 auto;padding:32px var(--pad)}

/* Text selection / cursor behaviour */
h1,h2,h3,h4,h5,h6,p,span,div,a,button,label,.small,.note{user-select:none;cursor:default}
a,button,.cta,.btn,.chip{cursor:pointer !important}
input,textarea{user-select:text;cursor:text}

/* Header - Updated with larger logo without increasing nav height */
/* Header - Compact logo, thin nav bar */
header.site-header{
  position:sticky;
  top:0;
  background:rgba(10,22,40,0.95);
  backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(79,195,247,0.15);
  z-index:50;
  box-shadow:0 2px 20px rgba(0,0,0,0.3);
}
header .container{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  padding:10px var(--pad);
  padding:8px var(--pad);
}
.header-container{
  display:flex;
  align-items:center;
  width:100%;
}
.logo-container{
  display:flex;
  align-items:center;
  gap:12px;
  flex:0 0 auto;
}
.logo-img{
  width:85px;
  height:115px;
  width:40px;
  height:40px;
  object-fit:contain;
}
.logo{
  font-weight:900;
  letter-spacing:-0.03em;
  color:var(--text);
  text-decoration:none;
  font-size:2rem;
  font-size:1.4rem;
  background:linear-gradient(135deg, var(--accent-light) 0%, var(--accent) 100%);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  white-space:nowrap;
}
.nav{
  display:flex;
  gap:1px;
  flex:1;
  justify-content:flex-start;
  align-items:center;
  margin-left:24px;
}
.nav a{
  color:var(--muted);
  text-decoration:none;
  padding:8px 14px;
  border-radius:8px;
  font-weight:600;
  transition:var(--transition);
  white-space:nowrap;
  font-size:0.95rem;
}
.nav a:hover{
  color:var(--text);
  background:rgba(79,195,247,0.1);
}
.nav a.nav-active{
  color:var(--text);
  background:rgba(79,195,247,0.15);
  box-shadow:0 0 20px rgba(79,195,247,0.2);
}
.nav a.nav-products{
  background:linear-gradient(135deg,var(--accent-light),var(--accent));
  color:#0a1628;
  font-weight:700;
  padding:8px 20px;
  box-shadow:0 2px 10px rgba(79,195,247,0.3);
  margin-left:8px;
}
.nav a.nav-products:hover{
  transform:translateY(-1px);
  box-shadow:0 4px 15px rgba(79,195,247,0.4);
}

.cta{
  background:linear-gradient(135deg,var(--accent-light),var(--accent));
  color:#0a1628;
  padding:8px 16px;
  border-radius:8px;
  font-weight:700;
  text-decoration:none;
  border:none;
  outline:none;
  cursor:pointer;
  transition:var(--transition);
  box-shadow:0 4px 15px rgba(79,195,247,0.3);
  white-space:nowrap;
  flex:0 0 auto;
  font-size:0.9rem;
}
.cta:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(79,195,247,0.4)}
.cta.topmargin{display:inline-block;margin-top:10px}
.cta.ghost{background:transparent;border:1px solid rgba(79,195,247,0.3);color:var(--accent-light);box-shadow:none}
.cta.ghost:hover{background:rgba(79,195,247,0.1);border-color:var(--accent)}

/* Hero - Reduced top margin, increased internal spacing */
/* Hero - Reduced top margin */
.hero{
  margin:4px auto 0;
  margin:8px auto 0;
  padding:48px 36px;
  border-radius:20px;
  background:var(--panel);
  border:1px solid rgba(79,195,247,0.2);
  display:grid;
  grid-template-columns:1fr 420px;
  gap:36px;
  align-items:center;
  box-shadow:0 8px 32px rgba(0,0,0,0.2);
}
.hero h1{margin:0 0 20px 0;font-size:2.3rem;letter-spacing:-0.03em;line-height:1.2}
.hero p.lead{color:var(--muted);margin:0 0 28px 0;font-size:1.05rem;line-height:1.6}
.hero .kpis{display:flex;gap:12px;margin-top:0;margin-bottom:0}
.kpi{background:rgba(79,195,247,0.06);padding:12px;border-radius:14px;border:1px solid rgba(79,195,247,0.15);min-width:130px;text-align:center;transition:var(--transition)}
.kpi:hover{background:rgba(79,195,247,0.1);border-color:rgba(79,195,247,0.25)}
.kpi b{display:block;font-size:1.3rem;color:var(--accent-light)}

/* Reusable card */
.card{background:var(--panel);border-radius:14px;padding:20px;border:1px solid rgba(79,195,247,0.15);box-shadow:0 4px 16px rgba(0,0,0,0.1)}

/* Services */
.services{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;margin-top:24px}
.service{transition:var(--transition)}
.service:hover{transform:translateY(-2px);border-color:rgba(79,195,247,0.3);box-shadow:0 8px 24px rgba(0,0,0,0.2)}
.service h3{margin:0 0 10px 0;color:var(--accent-light)}
.service p{margin:0;color:var(--muted);line-height:1.5}

/* Process + quote calculator - Updated calculator to match height */
/* Process + quote calculator - Matched heights */
.split{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:24px}
.steps{display:flex;flex-direction:column;gap:14px;height:100%}
.step{display:flex;gap:14px;align-items:flex-start;transition:var(--transition)}
.step:hover{transform:translateX(4px)}
.step .num{background:linear-gradient(135deg,var(--accent-light),var(--accent));padding:10px 14px;border-radius:12px;color:#0a1628;font-weight:800;box-shadow:0 2px 10px rgba(79,195,247,0.3)}

/* Quote Calculator - Resized to match How it Works height */
/* Quote Calculator - Compact to match How it Works */
.quote-calculator{
  background:var(--panel);
  border:1px solid rgba(79,195,247,0.2);
  border-radius:14px;
  padding:24px;
  padding:20px;
  height:100%;
  display:flex;
  flex-direction:column;
}
.quote-calculator h2{
  margin:0 0 8px 0;
  font-size:1.5rem;
  margin:0 0 4px 0;
  font-size:1.3rem;
}
.quote-calculator > .note{
  margin:0 0 16px 0;
  margin:0 0 12px 0;
  font-size:0.88rem;
}
.calculator-form{
  display:flex;
  flex-direction:column;
  gap:12px;
  gap:10px;
  flex:1;
}
.form-group{
  display:flex;
  flex-direction:column;
  gap:6px;
  gap:4px;
}
.form-group label{
  font-weight:600;
  font-size:0.9rem;
  font-size:0.85rem;
  color:var(--text);
}
.calculator-result{
  margin-top:16px;
  padding:16px;
  margin-top:12px;
  padding:12px;
  background:rgba(79,195,247,0.08);
  border-radius:12px;
  border:1px solid rgba(79,195,247,0.2);
  text-align:center;
}
.calculator-result .estimate{
  font-size:2rem;
  font-size:1.8rem;
  font-weight:800;
  color:var(--accent-light);
  margin:8px 0;
  margin:6px 0;
}
.calculator-result .note{
  margin:0;
  font-size:0.8rem;
}

.pricing{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px}
.price{padding:20px;border-radius:14px;background:var(--panel);border:1px solid rgba(79,195,247,0.15);transition:var(--transition)}
.price:hover{border-color:rgba(79,195,247,0.3);box-shadow:0 8px 24px rgba(0,0,0,0.2)}
.price h4{margin:0 0 10px 0;color:var(--accent-light)}

/* FAQ */
.faq{margin-top:28px}
.faq details{background:var(--panel);padding:18px 20px;border-radius:14px;border:1px solid rgba(79,195,247,0.15);margin-bottom:12px;transition:var(--transition)}
.faq details:hover{background:rgba(79,195,247,0.08);border-color:rgba(79,195,247,0.25)}
.faq summary{font-weight:700;color:var(--text);cursor:pointer;padding:4px 0}
.faq details[open] summary{margin-bottom:16px;padding-bottom:14px;border-bottom:1px solid rgba(79,195,247,0.15)}
.faq details .small{line-height:1.6;color:var(--muted);padding-top:8px}

/* Contact & forms */
.contact{display:grid;grid-template-columns:1fr 360px;gap:24px;margin-top:28px}
form.fieldset{display:flex;flex-direction:column;gap:12px}
input,textarea,select{background:rgba(79,195,247,0.03);border:1px solid rgba(79,195,247,0.15);padding:12px;border-radius:10px;color:var(--text);outline:none;resize:none;transition:var(--transition)}
input:focus,textarea:focus,select:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(79,195,247,0.1)}
input::placeholder,textarea::placeholder{color:var(--muted)}
.note{color:var(--muted);font-size:0.95rem;line-height:1.5}

/* Custom select */
.custom-select{position:relative;min-width:180px}
.custom-select-button{background:rgba(79,195,247,0.03);border:1px solid rgba(79,195,247,0.15);color:var(--text);padding:10px 14px;border-radius:10px;cursor:pointer;width:100%;text-align:left;font-weight:600;font-size:0.9rem;transition:var(--transition)}
.custom-select-button:hover{background:rgba(79,195,247,0.08);border-color:var(--accent)}
.custom-select-options{position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--panel);border:1px solid rgba(79,195,247,0.2);border-radius:12px;overflow:hidden;z-index:100;box-shadow:0 8px 32px rgba(0,0,0,0.4)}
.custom-select-options.hidden{display:none}
.custom-select-option{padding:12px 14px;cursor:pointer;transition:var(--transition);font-size:0.9rem;color:var(--text)}
.custom-select-option:hover{background:rgba(79,195,247,0.1)}
.custom-select-option.disabled{color:var(--muted);opacity:0.5;cursor:not-allowed}
.custom-select-option.disabled:hover{background:transparent}
.hidden{display:none}

/* Footer */
footer.container{margin-top:40px;padding:28px var(--pad);border-top:1px solid rgba(79,195,247,0.15)}
footer{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}
.small{color:var(--muted);font-size:0.9rem}

/* Products page / tools styles */

/* Tools hero */
.tools-hero{margin-top:20px}
.tools-hero h1{margin:0 0 8px 0;font-size:2.2rem;letter-spacing:-0.03em}
.tools-hero .small{color:var(--muted);margin:0;font-size:1rem;line-height:1.5}

/* Back button */
.btn.back{
  background:transparent;border:none;color:var(--muted);font-size:0.9rem;padding:8px 12px;text-decoration:none;display:inline-flex;align-items:center;gap:6px;transition:var(--transition)
}
.btn.back:hover{color:var(--text);background:rgba(79,195,247,0.08)}
.btn.back::before{content:'←';font-size:1.1rem}

/* Controls / search */
.controls{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-top:20px}
.search{position:relative;flex:1;min-width:280px;display:flex;align-items:center;background:rgba(79,195,247,0.03);border:1px solid rgba(79,195,247,0.15);border-radius:12px;padding:10px 14px;transition:var(--transition)}
.search:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px rgba(79,195,247,0.1)}
.search svg{color:var(--muted);margin-right:10px;flex-shrink:0}
.search input{background:transparent;border:none;outline:none;color:var(--text);flex:1;font-size:0.95rem}
.search input::placeholder{color:var(--muted)}

/* Chips */
.chips{display:flex;gap:8px;flex-wrap:wrap;margin-top:16px}
.chip{background:rgba(79,195,247,0.05);border:1px solid rgba(79,195,247,0.15);padding:8px 14px;border-radius:10px;color:var(--muted);font-weight:600;font-size:0.85rem;cursor:pointer;transition:var(--transition);border:none;outline:none}
.chip:hover{background:rgba(79,195,247,0.1);color:var(--text)}
.chip.active{background:linear-gradient(135deg,var(--accent-light),var(--accent));color:#0a1628;box-shadow:0 2px 10px rgba(79,195,247,0.3)}

/* Cards grid & product cards */
.cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;margin-top:24px}
.tool-card{
  background:var(--panel);
  border:1px solid rgba(79,195,247,0.15);
  border-radius:16px;
  padding:20px;
  transition:var(--transition);
  display:flex;
  flex-direction:column;
  min-height:320px;
}
.tool-card:hover{border-color:rgba(79,195,247,0.3);transform:translateY(-3px);box-shadow:0 12px 32px rgba(0,0,0,0.3)}
.card-top{display:flex;gap:14px;align-items:flex-start;flex:1}
.icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.3rem;flex-shrink:0;overflow:hidden;box-shadow:0 4px 12px rgba(0,0,0,0.2)}
.tool-card h3{margin:0 0 8px 0;font-size:1.15rem;color:var(--accent-light)}
.card-desc{margin:0 0 8px 0;color:var(--muted);font-size:0.93rem;line-height:1.5}
.card-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:auto}
.card-tags .chip{font-size:0.75rem;padding:5px 10px;background:rgba(79,195,247,0.08);border:1px solid rgba(79,195,247,0.1);cursor:default}
.card-actions{display:flex;gap:10px;align-items:center;margin-top:16px;padding-top:0;border-top:none}
.btn{padding:9px 15px;border-radius:9px;font-weight:700;text-decoration:none;border:none;outline:none;cursor:pointer;transition:var(--transition);font-size:0.88rem;display:inline-block}
.btn.primary{background:linear-gradient(135deg,var(--accent-light),var(--accent));color:#0a1628;box-shadow:0 2px 10px rgba(79,195,247,0.3)}
.btn.primary:hover{transform:translateY(-1px);box-shadow:0 4px 15px rgba(79,195,247,0.4)}
.btn.ghost{background:transparent;border:1px solid rgba(79,195,247,0.2);color:var(--accent-light)}
.btn.ghost:hover{background:rgba(79,195,247,0.08);border-color:var(--accent)}
.btn.small{padding:7px 12px;font-size:0.82rem}
.btn:disabled{
  opacity:0.4;
  cursor:not-allowed;
}
.btn:disabled:hover{
  transform:none;
  box-shadow:none;
  background:transparent;
}
.card-actions .price{margin-left:auto;font-weight:800;color:var(--accent-light);font-size:1.1rem}

/* 3D Viewer Modal - Updated with color picker */
#viewer-modal{
  position:fixed;
  left:0; top:0; right:0; bottom:0;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(0,0,0,0.9);
  z-index:9999;
  padding:20px;
}
#viewer-modal-inner{
  max-width:1000px;
  width:100%;
  height:80vh;
  background:var(--panel);
  border-radius:18px;
  border:1px solid rgba(79,195,247,0.2);
  box-shadow:0 12px 48px rgba(0,0,0,0.5);
  display:flex;
  flex-direction:column;
  overflow:hidden;
}
#viewer-modal-header{
  padding:20px 24px;
  border-bottom:1px solid rgba(79,195,247,0.15);
  display:flex;
  justify-content:space-between;
  align-items:center;
}
#viewer-modal-header h2{
  margin:0;
  color:var(--accent-light);
  font-size:1.5rem;
}
#viewer-canvas-container{
  flex:1;
  position:relative;
  background:linear-gradient(135deg, rgba(10,22,40,0.8), rgba(15,31,58,0.8));
  overflow:hidden;
}
#viewer-canvas{
  width:100%;
  height:100%;
  display:block;
}
.viewer-controls{
  position:absolute;
  bottom:20px;
  left:50%;
  transform:translateX(-50%);
  display:flex;
  gap:12px;
  background:rgba(15,31,58,0.95);
  padding:12px 16px;
  border-radius:12px;
  border:1px solid rgba(79,195,247,0.2);
  flex-wrap:wrap;
  justify-content:center;
}
.viewer-controls button{
  background:rgba(79,195,247,0.1);
  border:1px solid rgba(79,195,247,0.2);
  color:var(--text);
  padding:8px 14px;
  border-radius:8px;
  cursor:pointer;
  font-weight:600;
  font-size:0.85rem;
  transition:var(--transition);
}
.viewer-controls button:hover{
  background:rgba(79,195,247,0.2);
  border-color:var(--accent);
}
.color-picker-container{
  display:flex;
  gap:8px;
  align-items:center;
}
.color-swatch{
  width:32px;
  height:32px;
  border-radius:6px;
  border:2px solid rgba(79,195,247,0.3);
  cursor:pointer;
  transition:var(--transition);
}
.color-swatch:hover{
  border-color:var(--accent);
  transform:scale(1.1);
}
.color-swatch.active{
  border-color:var(--accent-light);
  box-shadow:0 0 10px rgba(79,195,247,0.5);
}
.viewer-loading{
  position:absolute;
  top:50%;
  left:50%;
  transform:translate(-50%, -50%);
  color:var(--accent-light);
  font-size:1.2rem;
  font-weight:600;
  text-align:center;
  max-width:80%;
}

/* Modal */
#simple-modal{
  position:fixed;
  left:0; top:0; right:0; bottom:0;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(0,0,0,0.8);
  z-index:9999;
  padding:20px;
}
#simple-modal > div{
  max-width:600px;
  width:100%;
  background:var(--panel);
  padding:32px;
  border-radius:18px;
  border:1px solid rgba(79,195,247,0.2);
  box-shadow:0 12px 48px rgba(0,0,0,0.5);
}

/* Mobile & Tablet responsive */
@media (max-width:1024px){
  :root{--pad:30px}
  .container{padding:24px var(--pad)}
  .hero{grid-template-columns:1fr;padding:32px 24px;gap:24px}
  .hero h1{font-size:2rem}
  .split{grid-template-columns:1fr}
  .contact{grid-template-columns:1fr}
  .cards-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}
  #viewer-modal-inner{height:70vh}
}

@media (max-width:768px){
  :root{--pad:20px}
  .container{padding:20px var(--pad)}
  header .container{flex-wrap:wrap;padding:8px var(--pad);gap:12px}
  .logo-container{order:1}
  .logo{font-size:1.6rem}
  .logo-img{width:70px;height:70px}
  .logo{font-size:1.2rem}
  .logo-img{width:32px;height:32px}
  .nav{order:2;width:100%;justify-content:flex-start;overflow-x:auto;-webkit-overflow-scrolling:touch;gap:8px;padding:8px 0;margin-left:0}
  .nav a{padding:8px 12px;font-size:0.85rem}
  .hero{padding:24px 20px;gap:20px}
  .hero{padding:24px 20px;gap:20px;margin-top:4px}
  .hero h1{font-size:1.7rem}
  .hero p.lead{font-size:0.95rem}
  .hero .kpis{flex-direction:column;gap:10px}
  .kpi{min-width:100%}
  .services{grid-template-columns:1fr}
  .cards-grid{grid-template-columns:1fr}
  .controls{flex-direction:column;align-items:stretch}
  .search{min-width:100%}
  .custom-select{min-width:100%}
  #viewer-modal-inner{height:60vh}
  .viewer-controls{flex-wrap:wrap;width:90%}
}

@media (max-width:480px){
  :root{--pad:16px}
  .container{padding:16px var(--pad)}
  .logo{font-size:1.4rem}
  .logo-img{width:60px;height:60px}
  .logo{font-size:1.1rem}
  .logo-img{width:28px;height:28px}
  .hero h1{font-size:1.5rem}
  .hero p.lead{font-size:0.9rem}
  .tool-card{min-height:auto}
  .card-top{flex-direction:column;align-items:center;text-align:center}
  .card-actions{flex-wrap:wrap}
  .card-actions .price{width:100%;text-align:center;margin:8px 0 0 0}
  #viewer-modal{padding:10px}
  #viewer-modal-inner{height:85vh}
}

/* Accessibility */
.toast{position:fixed;bottom:24px;right:24px;background:var(--panel);border:1px solid rgba(79,195,247,0.06);padding:12px 18px;border-radius:10px;color:var(--text);font-weight:600;z-index:10000;opacity:0;transform:translateY(10px);transition:all 0.3s ease;pointer-events:none}
.toast.show{opacity:1;transform:translateY(0);pointer-events:auto}
