/* ============================================================
   Importa Fácil RD — Design System v3
   Dominican consumer e-commerce vibe.
   Caribbean ocean blue · Sunset orange · Mint accents · Bold sans
   Modern, friendly, trustworthy — built for everyday shoppers.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@500;600;700;800&family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@500&display=swap');

:root {
  /* Brand: Caribbean ocean → Sunset orange */
  --ocean:#0369a1;        /* deep ocean blue — primary */
  --ocean-2:#0284c7;      /* lighter ocean */
  --ocean-3:#0ea5e9;      /* sky cyan */
  --ocean-soft:#e0f2fe;   /* soft sky tint */

  --sun:#f97316;          /* sunset orange — CTA */
  --sun-2:#ea580c;        /* deeper sunset */
  --sun-soft:#fff7ed;     /* warm cream tint */

  --mint:#10b981;         /* fresh mint — success / accents */
  --mint-2:#059669;
  --mint-soft:#d1fae5;

  --coral:#ef4444;        /* danger / Dominican-flag accent */
  --coral-soft:#fee2e2;

  /* Surfaces */
  --bg:#fafbfc;           /* soft off-white app background */
  --bg-2:#f1f5f9;         /* warm secondary surface */
  --paper:#ffffff;        /* card surface */

  /* Text */
  --ink:#0f172a;          /* primary text */
  --ink-2:#475569;        /* body / muted */
  --ink-3:#94a3b8;        /* hints */
  --line:#e2e8f0;
  --line-2:#f1f5f9;

  /* Status semantics */
  --ok:#10b981;
  --warn:#f59e0b;
  --err:#ef4444;

  /* Legacy aliases (so existing pages keep working) */
  --navy:var(--ocean);
  --navy-2:var(--ocean-2);
  --navy-3:var(--ocean-3);
  --red:var(--sun);
  --red-dark:var(--sun-2);
  --red-soft:var(--sun-soft);
  --gold:var(--mint);
  --gold-2:var(--mint-2);
  --gold-soft:var(--mint-soft);
  --cream:var(--bg);
  --sand:var(--bg-2);

  /* Fonts — modern consumer sans, no luxury serifs */
  --f-display:'Plus Jakarta Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --f-body:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  --f-mono:'JetBrains Mono',ui-monospace,'Courier New',monospace;

  /* Spacing */
  --s1:4px;--s2:8px;--s3:12px;--s4:16px;--s5:20px;--s6:24px;--s8:32px;--s10:40px;--s12:48px;--s16:64px;

  /* Radii — friendlier, more rounded */
  --r-sm:8px;--r-md:12px;--r-lg:18px;--r-xl:24px;--r-2xl:32px;--r-full:999px;

  /* Shadows — softer, more diffuse */
  --sh-sm:0 1px 2px rgba(15,23,42,0.04),0 1px 3px rgba(15,23,42,0.05);
  --sh-md:0 4px 6px -1px rgba(15,23,42,0.06),0 2px 4px -2px rgba(15,23,42,0.05);
  --sh-lg:0 10px 25px -5px rgba(15,23,42,0.08),0 8px 10px -6px rgba(15,23,42,0.05);
  --sh-xl:0 20px 40px -12px rgba(3,105,161,0.18);
  --sh-glow:0 0 0 4px rgba(3,105,161,0.15);
  --sh-cta:0 8px 20px -4px rgba(249,115,22,0.45);

  /* Motion */
  --t-fast:140ms cubic-bezier(0.4,0,0.2,1);
  --t-normal:220ms cubic-bezier(0.4,0,0.2,1);
  --t-bounce:360ms cubic-bezier(0.34,1.56,0.64,1);

  /* Gradients */
  --grad-ocean:linear-gradient(135deg,#0369a1 0%,#0284c7 50%,#0ea5e9 100%);
  --grad-sun:linear-gradient(135deg,#f97316 0%,#fb923c 100%);
  --grad-hero:linear-gradient(135deg,#0369a1 0%,#0c4a6e 35%,#075985 70%,#0369a1 100%);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:var(--f-body);
  color:var(--ink);
  background:var(--bg);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

h1,h2,h3,h4,h5{
  font-family:var(--f-display);
  font-weight:700;
  letter-spacing:-0.02em;
  line-height:1.15;
  color:var(--ink);
}
h1{font-size:38px;letter-spacing:-0.028em}
h2{font-size:28px;letter-spacing:-0.022em}
h3{font-size:20px}
h4{font-size:17px}
p{color:var(--ink-2);line-height:1.65}
a{color:var(--ocean-2);text-decoration:none;transition:color var(--t-fast)}
a:hover{color:var(--ocean);text-decoration:none}
code,.mono{font-family:var(--f-mono);font-size:0.9em}
button{font-family:inherit}

/* === Focus states (a11y) === */
*:focus{outline:none}
*:focus-visible{outline:2px solid var(--ocean-3);outline-offset:2px;border-radius:var(--r-sm)}
button:focus-visible,.btn:focus-visible{outline-offset:3px}

/* === SVG icon sprite === */
.icon{width:18px;height:18px;display:inline-block;vertical-align:-3px;flex-shrink:0;stroke:currentColor;fill:none;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}
.icon-sm{width:14px;height:14px;vertical-align:-2px}
.icon-lg{width:22px;height:22px}
.icon-xl{width:32px;height:32px}

/* === Top nav — light, floating feel === */
.if-nav{
  background:var(--paper);
  color:var(--ink);
  padding:14px 28px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  border-bottom:1px solid var(--line);
  position:sticky;top:0;z-index:50;
  backdrop-filter:blur(12px);
  background:rgba(255,255,255,0.88);
}
.if-nav a{color:var(--ink);text-decoration:none}
.if-logo{display:flex;align-items:center;gap:10px;font-weight:700;font-family:var(--f-display);font-size:18px;transition:opacity var(--t-fast);color:var(--ink)}
.if-logo:hover{opacity:0.85;color:var(--ink)}
.if-logo-mark{
  background:var(--grad-ocean);
  width:36px;height:36px;
  border-radius:10px;
  display:grid;place-items:center;
  font-weight:800;font-size:13px;
  color:#fff;
  box-shadow:0 4px 10px rgba(3,105,161,0.30);
  font-family:var(--f-display);
  letter-spacing:0;
}
.if-right{display:flex;gap:12px;align-items:center;font-size:14px}
.btn-ghost-nav{
  background:transparent;
  color:var(--ink);
  border:1px solid var(--line);
  padding:8px 16px;
  border-radius:var(--r-full);
  cursor:pointer;
  font-size:13px;
  font-weight:600;
  font-family:inherit;
  transition:all var(--t-fast);
  min-height:36px;
}
.btn-ghost-nav:hover{background:var(--ocean-soft);border-color:var(--ocean-3);color:var(--ocean)}

/* === Buttons — bold, rounded, energetic === */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:12px 22px;min-height:44px;
  border-radius:var(--r-full);
  font-family:var(--f-display);font-weight:700;font-size:14px;
  cursor:pointer;border:none;
  transition:transform var(--t-fast),box-shadow var(--t-fast),background var(--t-fast);
  text-decoration:none;line-height:1;letter-spacing:0;white-space:nowrap;
}
.btn:hover{text-decoration:none;transform:translateY(-2px)}
.btn:active{transform:translateY(0)}
.btn-primary{
  background:var(--grad-sun);
  color:#fff;
  box-shadow:var(--sh-cta);
}
.btn-primary:hover{background:var(--sun-2);color:#fff;box-shadow:0 10px 24px -4px rgba(249,115,22,0.55)}
.btn-gold{
  background:var(--mint);
  color:#fff;
  box-shadow:0 4px 12px -2px rgba(16,185,129,0.35);
}
.btn-gold:hover{background:var(--mint-2);color:#fff}
.btn-secondary{
  background:var(--paper);
  color:var(--ocean);
  border:1.5px solid var(--ocean-soft);
}
.btn-secondary:hover{background:var(--ocean-soft);border-color:var(--ocean-3);color:var(--ocean)}
.btn-ocean{
  background:var(--grad-ocean);
  color:#fff;
  box-shadow:0 6px 16px -4px rgba(3,105,161,0.4);
}
.btn-ocean:hover{color:#fff;box-shadow:0 10px 20px -4px rgba(3,105,161,0.5)}
.btn-ghost{background:transparent;color:var(--ink);border:none}
.btn-ghost:hover{background:var(--bg-2);transform:none}
.btn:disabled{opacity:0.5;cursor:not-allowed;transform:none}
.btn-sm{padding:8px 16px;font-size:13px;min-height:36px}
.btn-lg{padding:16px 32px;font-size:16px;min-height:52px}
.btn-block{width:100%}

/* === Cards === */
.card{
  background:var(--paper);
  border-radius:var(--r-lg);
  padding:24px;
  box-shadow:var(--sh-sm);
  border:1px solid var(--line-2);
  transition:box-shadow var(--t-normal),transform var(--t-normal);
}
.card-hover:hover{box-shadow:var(--sh-md);transform:translateY(-2px)}
.card-warm{
  background:linear-gradient(135deg,#fff 0%,var(--sun-soft) 100%);
  border:1px solid #fed7aa;
}
.card-ocean{
  background:linear-gradient(135deg,#fff 0%,var(--ocean-soft) 100%);
  border:1px solid #bae6fd;
}
.card-title{
  font-size:11px;color:var(--ink-2);
  text-transform:uppercase;letter-spacing:0.85px;
  font-weight:700;margin-bottom:14px;
  font-family:var(--f-display);
}

/* === Pills — friendly status chips === */
.pill{
  display:inline-flex;align-items:center;gap:6px;
  padding:5px 12px;border-radius:var(--r-full);
  font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.55px;
  font-family:var(--f-display);line-height:1.4;
}
.pill.pendiente{background:#fef3c7;color:#92400e}
.pill.confirmado{background:#dbeafe;color:#1e40af}
.pill.comprado_eeuu{background:#dbeafe;color:#1e40af}
.pill.en_transito_miami{background:#cffafe;color:#0e7490}
.pill.en_aduanas_rd{background:#fce7f3;color:#9f1239}
.pill.en_reparto{background:#fef3c7;color:#92400e}
.pill.entregado{background:var(--mint-soft);color:#065f46}
.pill.cancelado{background:var(--coral-soft);color:#991b1b}

/* === Forms === */
.field{margin-bottom:16px}
.field label{
  display:block;font-size:13px;color:var(--ink);
  font-weight:600;margin-bottom:6px;
  font-family:var(--f-body);
}
.field input,.field textarea,.field select{
  width:100%;padding:13px 16px;min-height:48px;
  border:1.5px solid var(--line);border-radius:var(--r-md);
  font-size:15px;font-family:inherit;
  background:var(--paper);color:var(--ink);
  transition:border-color var(--t-fast),box-shadow var(--t-fast);
}
.field input:focus,.field textarea:focus,.field select:focus{
  outline:none;border-color:var(--ocean-3);box-shadow:var(--sh-glow);
}
.field input::placeholder,.field textarea::placeholder{color:var(--ink-3)}
.field input:disabled{background:var(--bg-2);color:var(--ink-3)}
.field textarea{min-height:88px;resize:vertical;line-height:1.55}

/* === Hero / banner sections === */
.hero-band{
  background:var(--grad-hero);
  color:#fff;
  padding:56px 28px;
  border-radius:var(--r-2xl);
  position:relative;
  overflow:hidden;
  margin-bottom:32px;
}
.hero-band h1,.hero-band h2{color:#fff}
.hero-band p{color:rgba(255,255,255,0.85)}
.hero-band::before{
  content:'';position:absolute;top:-50%;right:-15%;
  width:60%;height:200%;
  background:radial-gradient(ellipse,rgba(249,115,22,0.25) 0%,transparent 60%);
  pointer-events:none;
}
.hero-band::after{
  content:'';position:absolute;bottom:-30%;left:-10%;
  width:50%;height:120%;
  background:radial-gradient(ellipse,rgba(16,185,129,0.18) 0%,transparent 65%);
  pointer-events:none;
}

/* === Cargo plane loader === */
.cargo-loader{position:relative;width:280px;height:90px;margin:20px auto}
.cargo-loader svg{width:100%;height:100%;overflow:visible}
.cargo-loader .city{
  position:absolute;font-size:11px;color:var(--ink-2);
  font-weight:700;text-transform:uppercase;letter-spacing:0.7px;
  font-family:var(--f-display);
}
.cargo-loader .city-from{top:64px;left:0}
.cargo-loader .city-to{top:64px;right:0}
.cargo-loader .plane{
  fill:var(--sun);transform-origin:center;
  animation:fly 3.2s ease-in-out infinite;
  filter:drop-shadow(0 3px 5px rgba(249,115,22,0.45));
}
.cargo-loader .trail{stroke:var(--ocean-3);stroke-width:2;stroke-dasharray:4 5;fill:none;opacity:0.5}
.cargo-loader .land-from,.cargo-loader .land-to{fill:var(--ocean);opacity:0.18}
@keyframes fly{
  0%{transform:translate(15px,50px) rotate(-8deg);opacity:0}
  10%{opacity:1}
  50%{transform:translate(135px,5px) rotate(0)}
  90%{opacity:1}
  100%{transform:translate(255px,50px) rotate(8deg);opacity:0}
}
.loader-caption{text-align:center;color:var(--ink-2);font-size:14px;margin-top:12px;font-family:var(--f-body)}

/* === Shipping route timeline === */
.route{display:flex;align-items:flex-start;gap:0;padding:28px 8px;overflow-x:auto;-webkit-overflow-scrolling:touch}
.route .stop{flex:1;min-width:90px;display:flex;flex-direction:column;align-items:center;position:relative;text-align:center}
.route .stop::after{content:'';position:absolute;top:18px;left:calc(50% + 18px);right:calc(-50% + 18px);height:2px;background:var(--line);z-index:0}
.route .stop:last-child::after{display:none}
.route .stop .dot{
  width:36px;height:36px;border-radius:50%;
  background:var(--paper);border:2px solid var(--line);
  display:grid;place-items:center;color:var(--ink-3);font-size:14px;
  position:relative;z-index:1;
  transition:all var(--t-normal);
  font-weight:700;font-family:var(--f-display);
}
.route .stop.done .dot{background:var(--mint);border-color:var(--mint);color:#fff;box-shadow:0 4px 10px -2px rgba(16,185,129,0.4)}
.route .stop.done::after{background:var(--mint)}
.route .stop.current .dot{
  background:var(--grad-sun);border-color:var(--sun);color:#fff;
  box-shadow:0 0 0 5px rgba(249,115,22,0.20);
  animation:pulse-sun 2.2s ease-in-out infinite;
}
@keyframes pulse-sun{
  0%,100%{box-shadow:0 0 0 5px rgba(249,115,22,0.22)}
  50%{box-shadow:0 0 0 12px rgba(249,115,22,0.05)}
}
.route .stop .label{margin-top:10px;font-size:11px;color:var(--ink-2);font-weight:600;line-height:1.3;max-width:96px}
.route .stop.done .label,.route .stop.current .label{color:var(--ink)}
.route .stop .date{font-size:10px;color:var(--ink-3);margin-top:3px}

/* === Stats grid === */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:24px}
.stat{
  background:var(--paper);
  padding:20px 22px;
  border-radius:var(--r-lg);
  border:1px solid var(--line-2);
  box-shadow:var(--sh-sm);
  transition:transform var(--t-fast),box-shadow var(--t-fast);
  position:relative;overflow:hidden;
}
.stat:hover{transform:translateY(-3px);box-shadow:var(--sh-md)}
.stat .stat-label{
  font-size:11px;color:var(--ink-2);
  text-transform:uppercase;letter-spacing:0.7px;
  font-weight:700;margin-bottom:8px;font-family:var(--f-display);
}
.stat .stat-value{
  font-size:30px;font-weight:800;font-family:var(--f-display);
  color:var(--ink);line-height:1;letter-spacing:-0.025em;
}
.stat .stat-sub{font-size:12px;color:var(--ink-3);margin-top:6px}
.stat-accent{border-left:4px solid var(--sun)}
.stat-ocean{border-left:4px solid var(--ocean)}
.stat-mint{border-left:4px solid var(--mint)}

/* === Tables === */
table.if-table{background:var(--paper);width:100%;border-radius:var(--r-md);border-collapse:collapse;overflow:hidden;box-shadow:var(--sh-sm);border:1px solid var(--line-2)}
table.if-table th{
  text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:0.7px;
  padding:14px 16px;background:var(--bg-2);color:var(--ink-2);
  font-weight:700;font-family:var(--f-display);
}
table.if-table td{padding:14px 16px;border-top:1px solid var(--line-2);font-size:14px;vertical-align:middle}
table.if-table tr.clickable{cursor:pointer;transition:background var(--t-fast)}
table.if-table tr.clickable:hover td{background:var(--ocean-soft)}
table.if-table .oid{font-family:var(--f-mono);font-weight:500;color:var(--ocean);font-size:13px}

/* === Page head === */
.page-head{padding:32px 0 28px;border-bottom:1px solid var(--line-2);margin-bottom:28px}
.page-head h1{font-size:40px;margin-bottom:10px;letter-spacing:-0.028em}
.page-head .sub{color:var(--ink-2);font-size:16px}

/* === Container === */
.if-container{max-width:1200px;margin:0 auto;padding:24px 28px}
.if-container-narrow{max-width:720px;margin:0 auto;padding:24px 20px}

/* === Store logo strip === */
.stores-strip{
  display:flex;flex-wrap:wrap;gap:10px;justify-content:center;align-items:center;
  padding:18px;margin:20px 0;
}
.store-chip{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 14px;border-radius:var(--r-full);
  background:var(--paper);border:1px solid var(--line);
  font-size:13px;font-weight:600;color:var(--ink);
  transition:all var(--t-fast);cursor:default;
}
.store-chip:hover{border-color:var(--ocean-3);transform:translateY(-1px);box-shadow:var(--sh-sm)}
.store-chip .dot{width:8px;height:8px;border-radius:50%;background:var(--mint)}

/* === Feature row === */
.feature-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px;margin:32px 0}
.feature{
  background:var(--paper);padding:24px;
  border-radius:var(--r-lg);border:1px solid var(--line-2);
  box-shadow:var(--sh-sm);
  transition:transform var(--t-normal),box-shadow var(--t-normal);
}
.feature:hover{transform:translateY(-3px);box-shadow:var(--sh-lg)}
.feature-icon{
  width:48px;height:48px;border-radius:14px;
  display:grid;place-items:center;
  background:var(--ocean-soft);color:var(--ocean);
  margin-bottom:16px;
}
.feature-icon .icon{width:24px;height:24px}
.feature h3{font-size:18px;margin-bottom:6px}
.feature p{font-size:14px;color:var(--ink-2);line-height:1.55}
.feature.feature-sun .feature-icon{background:var(--sun-soft);color:var(--sun-2)}
.feature.feature-mint .feature-icon{background:var(--mint-soft);color:var(--mint-2)}

/* === Utility === */
.flex{display:flex}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}
.gap-1{gap:4px}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.gap-6{gap:24px}.gap-8{gap:32px}
.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}
.justify-between{justify-content:space-between}.justify-center{justify-content:center}
.text-center{text-align:center}
.text-muted{color:var(--ink-2)}.text-faint{color:var(--ink-3)}
.text-ocean{color:var(--ocean)}.text-sun{color:var(--sun-2)}.text-mint{color:var(--mint-2)}
.text-mono{font-family:var(--f-mono)}.text-sm{font-size:13px}.text-xs{font-size:11px}
.text-lg{font-size:17px}.text-xl{font-size:20px}
.font-display{font-family:var(--f-display)}
.font-bold{font-weight:700}.font-semibold{font-weight:600}
.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.mt-6{margin-top:24px}.mt-8{margin-top:32px}
.mb-2{margin-bottom:8px}.mb-3{margin-bottom:12px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.mb-8{margin-bottom:32px}
.hidden{display:none}
.rounded-full{border-radius:var(--r-full)}
.shadow-sm{box-shadow:var(--sh-sm)}.shadow-md{box-shadow:var(--sh-md)}.shadow-lg{box-shadow:var(--sh-lg)}

/* === Mobile responsive === */
@media(max-width:640px){
  h1{font-size:28px}h2{font-size:22px}
  .page-head h1{font-size:30px}
  .if-container,.if-container-narrow{padding:16px}
  .if-nav{padding:12px 16px}
  .stats{grid-template-columns:1fr 1fr;gap:10px}
  .stat .stat-value{font-size:24px}
  .route{padding:20px 4px}
  .route .stop{min-width:72px}
  .route .stop .label{font-size:10px;max-width:72px}
  table.if-table{font-size:12px}
  table.if-table th,table.if-table td{padding:10px 8px}
  .btn{padding:11px 18px}
  .hero-band{padding:36px 20px;border-radius:var(--r-xl)}
}

/* === Skeleton loading === */
.skeleton{background:linear-gradient(90deg,var(--bg-2) 0%,var(--bg) 50%,var(--bg-2) 100%);background-size:200% 100%;animation:shimmer 1.6s linear infinite;border-radius:var(--r-sm)}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* === Reduced motion (a11y) === */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:0.01ms !important;animation-iteration-count:1 !important;transition-duration:0.01ms !important;scroll-behavior:auto !important}
  .cargo-loader .plane{animation:none;transform:translate(135px,5px)}
  .route .stop.current .dot{animation:none}
  .skeleton{animation:none;background:var(--bg-2)}
}

/* === Print (for invoice/print-to-PDF) === */
@media print{
  .if-nav,.btn,.wa-floating,.actions{display:none !important}
  body{background:#fff}
  .card{box-shadow:none;border:1px solid #ddd;break-inside:avoid}
  a{color:#000;text-decoration:none}
}
