:root{--blue:#1597e5;--blue-dark:#092b44;--cyan:#4ac7ff;--soft:#eef8ff;--soft2:#f7fcff;--text:#102a3a;--muted:#607686;--border:#cdeeff;--white:#fff;--shadow:0 20px 60px rgba(9,43,68,.12)}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Inter,Segoe UI,Arial,sans-serif;color:var(--text);background:linear-gradient(180deg,#f5fbff 0%,#fff 40%,#f8fcff 100%)}.container{width:min(1160px,92%);margin:auto}.topbar{position:sticky;top:0;z-index:20;backdrop-filter:blur(16px);background:rgba(255,255,255,.86);border-bottom:1px solid var(--border)}.nav{display:flex;align-items:center;justify-content:space-between;padding:18px 0}.brand img{height:140px;width:auto;display:block}nav{display:flex;gap:20px;align-items:center}nav a{text-decoration:none;color:var(--blue-dark);font-weight:700;font-size:15px}.nav-cta{background:var(--blue);color:white!important;padding:12px 18px;border-radius:999px;box-shadow:0 10px 30px rgba(21,151,229,.28)}.menu-btn{display:none;border:none;background:var(--soft);border-radius:12px;padding:10px 12px;font-size:22px;color:var(--blue-dark)}.hero{padding:82px 0 60px;overflow:hidden}.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:50px;align-items:center}.badge{display:inline-flex;background:var(--soft);color:var(--blue);border:1px solid var(--border);border-radius:999px;padding:10px 16px;font-weight:800;margin-bottom:22px}h1{font-size:clamp(42px,6vw,72px);line-height:.95;margin:0 0 22px;letter-spacing:-2.5px}.hero p{font-size:20px;line-height:1.55;color:var(--muted);max-width:640px}.hero-actions{display:flex;gap:14px;margin:28px 0 22px;flex-wrap:wrap}.btn{display:inline-flex;align-items:center;justify-content:center;border:none;border-radius:18px;padding:15px 22px;text-decoration:none;font-weight:900;cursor:pointer;transition:.2s ease}.btn:hover{transform:translateY(-2px)}.primary{background:linear-gradient(135deg,var(--blue),var(--cyan));color:white;box-shadow:0 18px 42px rgba(21,151,229,.28)}.secondary{background:white;color:var(--blue-dark);border:1px solid var(--border)}.full{width:100%}.trust{display:flex;gap:16px;flex-wrap:wrap;color:var(--muted);font-weight:700}.hero-card{min-height:470px;position:relative;border-radius:34px;background:radial-gradient(circle at 30% 20%,#d9f4ff 0%,transparent 35%),linear-gradient(145deg,#fff,#e9f8ff);border:1px solid var(--border);box-shadow:var(--shadow);overflow:hidden}.paper{position:absolute;width:230px;height:310px;background:white;border-radius:22px;box-shadow:0 24px 50px rgba(9,43,68,.16);border:1px solid var(--border)}.paper-a{top:60px;left:55px;transform:rotate(-12deg)}.paper-b{right:45px;top:105px;transform:rotate(10deg);background:linear-gradient(180deg,#fff,#eef9ff)}.print-card{position:absolute;left:50%;bottom:42px;transform:translateX(-50%);width:80%;background:rgba(255,255,255,.9);border:1px solid var(--border);border-radius:26px;padding:28px;box-shadow:0 20px 50px rgba(9,43,68,.12)}.print-card h3{margin:0 0 8px;font-size:26px}.print-card p{color:var(--muted);line-height:1.5}.print-card a{font-weight:900;color:var(--blue);text-decoration:none}.section{padding:72px 0}.section-title{text-align:center;max-width:760px;margin:0 auto 34px}.section-title.left{text-align:left;margin-left:0}.section-title span,.highlight span{color:var(--blue);text-transform:uppercase;font-size:13px;font-weight:900;letter-spacing:1px}.section-title h2,.highlight h2{font-size:clamp(30px,4vw,48px);letter-spacing:-1.4px;margin:10px 0;color:var(--blue-dark)}.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.card,.product,.order-form,.map-card,.highlight-box{background:white;border:1px solid var(--border);border-radius:28px;box-shadow:var(--shadow)}.card{padding:28px}.icon{width:54px;height:54px;display:grid;place-items:center;background:var(--soft);border-radius:18px;font-size:28px;margin-bottom:18px}.card h3,.product h3{font-size:22px;margin:0 0 10px}.card p,.product p,.muted{color:var(--muted);line-height:1.6}.order-section{background:linear-gradient(180deg,var(--soft2),#fff)}.order-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:34px;align-items:start}.steps{display:grid;gap:14px;margin-top:28px}.steps div{display:flex;align-items:center;gap:14px;background:white;border:1px solid var(--border);border-radius:18px;padding:14px}.steps strong{width:36px;height:36px;display:grid;place-items:center;border-radius:50%;background:var(--blue);color:white}.order-form{padding:28px;display:grid;gap:16px}label{display:grid;gap:8px;font-weight:800;color:var(--blue-dark)}input,select,textarea{width:100%;border:1px solid var(--border);border-radius:16px;padding:14px 15px;font:inherit;outline:none;background:#fbfdff}input:focus,select:focus,textarea:focus{border-color:var(--blue);box-shadow:0 0 0 4px rgba(21,151,229,.12)}small{color:var(--muted);font-weight:500}.two{display:grid;grid-template-columns:1fr 1fr;gap:14px}.product-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.product{padding:24px}.product span{display:inline-block;margin-top:12px;color:var(--blue);font-weight:900}.highlight{padding-top:20px}.highlight-box{padding:40px;display:flex;justify-content:space-between;gap:20px;align-items:center;background:linear-gradient(135deg,#fff,#eaf8ff)}.contact-grid{display:grid;grid-template-columns:1fr .8fr;gap:28px}.contact-list{display:grid;gap:12px;margin-top:20px}.contact-list a,.contact-list span{display:block;text-decoration:none;color:var(--blue-dark);background:white;border:1px solid var(--border);border-radius:18px;padding:16px;font-weight:800}.map-card{min-height:320px;display:grid;place-content:center;text-align:center;padding:30px;background:linear-gradient(135deg,#eaf8ff,#fff)}.whatsapp-float{position:fixed;right:20px;bottom:20px;z-index:30;background:#25d366;color:white;text-decoration:none;font-weight:900;border-radius:999px;padding:16px 20px;box-shadow:0 12px 32px rgba(37,211,102,.35)}footer{border-top:1px solid var(--border);padding:28px 0;background:white}.footer-inner{display:flex;align-items:center;justify-content:space-between;gap:18px;color:var(--muted)}.footer-inner img{height:110px}@media(max-width:900px){.menu-btn{display:block}nav{display:none;position:absolute;left:4%;right:4%;top:82px;background:white;border:1px solid var(--border);border-radius:22px;padding:18px;box-shadow:var(--shadow);flex-direction:column;align-items:stretch}nav.open{display:flex}.hero-grid,.order-grid,.contact-grid{grid-template-columns:1fr}.cards{grid-template-columns:1fr 1fr}.product-grid{grid-template-columns:1fr 1fr}.hero{padding-top:44px}}@media(max-width:620px){.cards,.product-grid,.two{grid-template-columns:1fr}h1{font-size:42px}.hero-card{min-height:360px}.paper{width:180px;height:240px}.highlight-box{display:block}.footer-inner{flex-direction:column;text-align:center}}
.domain-note{
  background:#eef8ff;
  border:1px solid var(--border);
  color:var(--blue-dark);
  padding:14px 16px;
  border-radius:18px;
  font-weight:700;
  line-height:1.45;
}
@media(max-width:900px){
  .brand img{height:96px}
}

.calculator-box{
  display:grid;
  gap:16px;
  background:linear-gradient(135deg,#eef8ff,#ffffff);
  border:1px solid var(--border);
  border-radius:22px;
  padding:18px;
}
.price-result{
  background:white;
  border:1px solid var(--border);
  border-radius:20px;
  padding:18px;
  display:grid;
  gap:6px;
  text-align:center;
}
.price-result span{
  color:var(--muted);
  font-weight:800;
}
.price-result strong{
  color:var(--blue);
  font-size:38px;
  letter-spacing:-1px;
}
.price-result small{
  color:var(--muted);
  font-weight:700;
}

.extras-box{
  background:white;
  border:1px solid var(--border);
  border-radius:20px;
  padding:16px;
  display:grid;
  gap:10px;
}
.extras-box h3{
  margin:0 0 4px;
  color:var(--blue-dark);
}
.check-line{
  display:flex;
  align-items:center;
  gap:10px;
  font-weight:800;
  color:var(--blue-dark);
}
.check-line input{
  width:auto;
  transform:scale(1.2);
}
.price-breakdown{
  display:grid;
  gap:8px;
  color:var(--muted);
  font-weight:700;
  background:#fbfdff;
  border:1px solid var(--border);
  border-radius:18px;
  padding:14px;
}
.price-breakdown div{
  display:flex;
  justify-content:space-between;
  gap:12px;
  border-bottom:1px dashed #d9edf8;
  padding-bottom:6px;
}
.price-breakdown div:last-child{
  border-bottom:0;
  padding-bottom:0;
}

.drop-zone{
  border:2px dashed var(--blue);
  background:linear-gradient(135deg,#eef8ff,#ffffff);
  border-radius:24px;
  padding:26px 18px;
  text-align:center;
  display:grid;
  gap:8px;
  cursor:pointer;
  transition:.2s ease;
}
.drop-zone:hover,
.drop-zone.dragover{
  background:#e2f5ff;
  transform:translateY(-2px);
  box-shadow:0 18px 42px rgba(21,151,229,.16);
}
.drop-zone.loaded{
  border-style:solid;
  background:#eafff6;
  border-color:#25d366;
}
.drop-icon{
  width:58px;
  height:58px;
  display:grid;
  place-items:center;
  margin:0 auto 4px;
  border-radius:20px;
  background:white;
  font-size:32px;
  box-shadow:0 12px 30px rgba(9,43,68,.10);
}
.drop-zone strong{
  color:var(--blue-dark);
  font-size:20px;
}
.drop-zone span{
  color:var(--blue);
  font-weight:900;
}
.drop-zone small{
  color:var(--muted);
  font-weight:700;
}
.copies-input{
  font-size:22px;
  font-weight:900;
  color:var(--blue-dark);
  text-align:center;
}

.cart-box{
  background:white;
  border:1px solid var(--border);
  border-radius:22px;
  padding:16px;
  display:grid;
  gap:14px;
}
.cart-head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
}
.cart-head h3{
  margin:0;
  color:var(--blue-dark);
}
.mini-btn{
  border:1px solid var(--border);
  background:#eef8ff;
  color:var(--blue-dark);
  border-radius:999px;
  padding:9px 12px;
  font-weight:900;
  cursor:pointer;
}
.cart-items{
  display:grid;
  gap:12px;
}
.cart-item{
  border:1px solid var(--border);
  background:#fbfdff;
  border-radius:18px;
  padding:14px;
  display:grid;
  gap:10px;
}
.cart-item-title{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:flex-start;
}
.cart-item-title strong{
  color:var(--blue-dark);
  overflow-wrap:anywhere;
}
.remove-file{
  border:none;
  background:#ffecec;
  color:#a50000;
  border-radius:999px;
  padding:7px 10px;
  font-weight:900;
  cursor:pointer;
}
.cart-controls{
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  gap:10px;
}
.locked-input{
  background:#eef8ff!important;
  color:#607686!important;
  cursor:not-allowed;
  font-weight:900;
  text-align:center;
}
.copy-input{
  font-size:20px;
  font-weight:900;
  text-align:center;
  color:var(--blue-dark);
}
.cart-total-pages{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:center;
  background:#eef8ff;
  border:1px solid var(--border);
  border-radius:18px;
  padding:14px;
}
.cart-total-pages span{
  color:var(--muted);
  font-weight:900;
}
.cart-total-pages strong{
  color:var(--blue);
  font-size:22px;
}
.empty-cart{
  margin:0;
  color:var(--muted);
  font-weight:800;
}
@media(max-width:620px){
  .cart-controls{grid-template-columns:1fr}
  .cart-head{display:grid}
}

.current-job-box{
  background:linear-gradient(135deg,#eef8ff,#ffffff);
  border:1px solid var(--border);
  border-radius:26px;
  padding:20px;
  display:grid;
  gap:16px;
}
.current-job-box h3{
  margin:0;
  color:var(--blue-dark);
}
.current-preview{
  background:white;
  border:1px solid var(--border);
  border-radius:20px;
  padding:16px;
  display:grid;
  gap:6px;
  text-align:center;
}
.current-preview span{
  color:var(--muted);
  font-weight:900;
}
.current-preview strong{
  font-size:30px;
  color:var(--blue);
}
.current-preview small{
  color:var(--muted);
  font-weight:700;
}
.total-live{
  border:2px solid var(--blue);
}
.cart-summary-box{
  background:white;
  border:1px solid var(--border);
  border-radius:22px;
  padding:16px;
  display:grid;
  gap:10px;
}
.cart-summary-box h3{
  margin:0;
  color:var(--blue-dark);
}
.summary-help{
  margin:0;
  color:var(--muted);
  font-weight:700;
}
.cart-item-meta{
  display:grid;
  gap:4px;
  color:var(--muted);
  font-weight:700;
}
.cart-item-subtotal{
  color:var(--blue);
  font-weight:900;
}

.cart-top-btn{
  border:1px solid var(--border);
  background:#eef8ff;
  color:var(--blue-dark);
  border-radius:999px;
  padding:11px 15px;
  font-weight:900;
  cursor:pointer;
  box-shadow:0 10px 24px rgba(21,151,229,.12);
}
.cart-top-btn strong{color:var(--blue)}
.cart-drawer{
  position:fixed;
  top:0;
  right:-430px;
  width:min(420px,94vw);
  height:100vh;
  background:white;
  z-index:80;
  box-shadow:-20px 0 70px rgba(9,43,68,.20);
  border-left:1px solid var(--border);
  transition:.25s ease;
  display:grid;
  grid-template-rows:auto 1fr auto;
}
.cart-drawer.open{right:0}
.drawer-backdrop{
  position:fixed;
  inset:0;
  background:rgba(9,43,68,.25);
  z-index:70;
  display:none;
}
.drawer-backdrop.open{display:block}
.cart-drawer-header{
  padding:22px;
  border-bottom:1px solid var(--border);
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:flex-start;
  background:linear-gradient(135deg,#eef8ff,#ffffff);
}
.cart-drawer-header span{
  color:var(--muted);
  font-weight:900;
}
.cart-drawer-header h3{
  margin:6px 0 0;
  color:var(--blue);
  font-size:32px;
}
.cart-drawer-header button{
  border:none;
  background:white;
  color:var(--blue-dark);
  width:40px;
  height:40px;
  border-radius:50%;
  font-size:26px;
  cursor:pointer;
  box-shadow:0 8px 20px rgba(9,43,68,.10);
}
.drawer-items{
  padding:18px;
  overflow:auto;
  display:grid;
  align-content:start;
  gap:12px;
}
.drawer-item{
  border:1px solid var(--border);
  border-radius:18px;
  padding:14px;
  display:grid;
  gap:8px;
  background:#fbfdff;
}
.drawer-item strong{overflow-wrap:anywhere;color:var(--blue-dark)}
.drawer-item small{color:var(--muted);font-weight:800;line-height:1.4}
.drawer-actions{
  padding:18px;
  border-top:1px solid var(--border);
  display:grid;
  gap:10px;
}
.pdf-preview-box{
  background:white;
  border:1px solid var(--border);
  border-radius:20px;
  padding:14px;
  display:none;
  gap:10px;
}
.pdf-preview-box.show{display:grid}
.pdf-preview-box canvas{
  max-width:100%;
  border-radius:14px;
  border:1px solid var(--border);
  background:white;
  box-shadow:0 14px 30px rgba(9,43,68,.10);
}
.pdf-preview-meta{
  color:var(--muted);
  font-weight:800;
}
.upload-notice{
  background:#fff8e8;
  border:1px solid #ffe0a3;
  color:#7a5200;
  border-radius:16px;
  padding:12px 14px;
  font-weight:800;
  line-height:1.45;
}
@media(max-width:900px){
  .cart-top-btn{width:100%;text-align:center}
}

.checkout-modal{
  position:fixed;
  inset:0;
  background:rgba(9,43,68,.35);
  z-index:100;
  display:none;
  align-items:center;
  justify-content:center;
  padding:20px;
}
.checkout-modal.open{
  display:flex;
}
.checkout-card{
  width:min(720px,96vw);
  max-height:92vh;
  overflow:auto;
  background:white;
  border:1px solid var(--border);
  border-radius:30px;
  box-shadow:0 30px 90px rgba(9,43,68,.25);
  padding:28px;
  position:relative;
}
.checkout-close{
  position:absolute;
  top:16px;
  right:16px;
  border:none;
  background:#eef8ff;
  color:var(--blue-dark);
  width:42px;
  height:42px;
  border-radius:50%;
  font-size:26px;
  font-weight:900;
  cursor:pointer;
}
.checkout-title span{
  color:var(--blue);
  font-weight:900;
  text-transform:uppercase;
  font-size:13px;
  letter-spacing:1px;
}
.checkout-title h2{
  margin:8px 0;
  color:var(--blue-dark);
  font-size:34px;
  letter-spacing:-1px;
}
.checkout-title p{
  color:var(--muted);
  font-weight:700;
  line-height:1.5;
}
.checkout-summary{
  display:grid;
  gap:10px;
  background:#fbfdff;
  border:1px solid var(--border);
  border-radius:22px;
  padding:18px;
  margin:18px 0;
}
.checkout-summary div{
  display:flex;
  justify-content:space-between;
  gap:14px;
  border-bottom:1px dashed #d9edf8;
  padding-bottom:8px;
  color:var(--muted);
  font-weight:800;
}
.checkout-summary div:last-child{
  border-bottom:0;
  padding-bottom:0;
  color:var(--blue-dark);
  font-size:22px;
}
.checkout-summary strong{
  color:var(--blue);
}
.payment-methods{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
}
.payment-card{
  border:2px solid var(--border);
  background:linear-gradient(135deg,#ffffff,#eef8ff);
  border-radius:24px;
  padding:20px;
  text-align:left;
  display:grid;
  gap:8px;
  cursor:pointer;
  transition:.2s ease;
}
.payment-card:hover{
  border-color:var(--blue);
  transform:translateY(-2px);
  box-shadow:0 18px 42px rgba(21,151,229,.16);
}
.payment-card strong{
  font-size:22px;
  color:var(--blue-dark);
}
.payment-card span{
  color:var(--muted);
  font-weight:800;
  line-height:1.45;
}
.payment-result{
  margin-top:18px;
  display:none;
  background:#eef8ff;
  border:1px solid var(--border);
  border-radius:22px;
  padding:18px;
  color:var(--blue-dark);
  font-weight:800;
  line-height:1.6;
}
.payment-result.show{
  display:block;
}
.payment-result .pay-ref{
  font-size:22px;
  color:var(--blue);
  font-weight:900;
}
@media(max-width:620px){
  .payment-methods{grid-template-columns:1fr}
  .checkout-title h2{font-size:28px}
}
