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

.crp-wrap {
  --bg:#0d0f18;--surf:#12151f;--card:#181c2a;--border:#222638;
  --accent:#4f6ef7;--accent2:#7c5ce6;--green:#00d4aa;--amber:#f7a94f;--red:#f75555;
  --text:#dde1f5;--muted:#6b7299;
  --font:'Plus Jakarta Sans',sans-serif;--mono:'JetBrains Mono',monospace;
  --r:13px;
}

.crp-wrap{font-family:var(--font);background:var(--bg);color:var(--text);border-radius:22px;max-width:920px;margin:2.5rem auto;overflow:hidden;border:1px solid var(--border);box-shadow:0 12px 60px rgba(0,0,0,.6);position:relative;}
.crp-wrap::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent),var(--accent2),var(--green));}

/* Header */
.crp-header{display:flex;align-items:center;gap:1rem;padding:1.75rem 2rem 1.5rem;background:var(--surf);border-bottom:1px solid var(--border);}
.crp-header-icon{width:50px;height:50px;flex-shrink:0;border-radius:14px;background:linear-gradient(135deg,var(--accent),var(--accent2));display:flex;align-items:center;justify-content:center;box-shadow:0 4px 18px rgba(79,110,247,.35);}
.crp-header-icon svg{width:25px;height:25px;color:#fff;}
.crp-title{font-size:1.3rem;font-weight:800;margin:0 0 3px;letter-spacing:-.03em;}
.crp-sub{font-size:.78rem;color:var(--muted);margin:0;}

/* Form */
.crp-form{padding:1.8rem 2rem;}

/* Route Grid */
.crp-route-grid{display:grid;grid-template-columns:1fr 56px 1fr;align-items:stretch;margin-bottom:1.6rem;border-radius:var(--r);overflow:hidden;border:1.5px solid var(--border);}
.crp-zone-block{background:var(--card);padding:1.1rem 1.15rem;transition:background .2s;}
.crp-zone-block:focus-within{background:#1c2138;}
.crp-zone-block--origin{border-right:none;}
.crp-zone-block--dest{border-left:none;}
.crp-zone-label{display:flex;align-items:center;gap:.4rem;font-size:.63rem;font-weight:800;letter-spacing:.11em;text-transform:uppercase;color:var(--muted);margin-bottom:.55rem;}
.crp-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;}
.crp-dot--from{background:var(--green);box-shadow:0 0 8px rgba(0,212,170,.5);}
.crp-dot--to{background:var(--accent);box-shadow:0 0 8px rgba(79,110,247,.5);}
.crp-zone-block select{width:100%;background:transparent;border:none;outline:none;color:var(--text);font-family:var(--font);font-size:.95rem;font-weight:700;cursor:pointer;-webkit-appearance:none;appearance:none;}
.crp-zone-block select option,.crp-zone-block select optgroup{background:#1a1e30;}
.crp-zone-hint{font-size:.7rem;color:var(--muted);margin-top:.35rem;min-height:1rem;}

.crp-route-arrow{background:var(--card);border-left:1.5px solid var(--border);border-right:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--muted);}
.crp-route-arrow svg{width:22px;height:22px;}

/* Package section */
.crp-pkg-section{margin-top:.25rem;}
.crp-section-label{display:flex;align-items:center;gap:.4rem;font-size:.67rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:.8rem;}
.crp-pkg-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:.8rem;}
.crp-field{display:flex;flex-direction:column;gap:.3rem;}
.crp-field label{font-size:.66rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);}
.crp-req{color:var(--amber);}
.crp-field input{background:var(--card);border:1.5px solid var(--border);border-radius:9px;color:var(--text);font-family:var(--font);font-size:.9rem;padding:.6rem .8rem;outline:none;transition:border-color .2s,box-shadow .2s;}
.crp-field input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(79,110,247,.12);}
.crp-field input::placeholder{color:#2a2f48;}

.crp-vol-note{display:flex;align-items:flex-start;gap:.5rem;font-size:.72rem;color:var(--muted);background:rgba(79,110,247,.05);border:1px solid rgba(79,110,247,.14);border-radius:8px;padding:.6rem .85rem;margin-top:.9rem;line-height:1.55;}
.crp-vol-note svg{color:var(--accent);flex-shrink:0;margin-top:1px;}

/* Button */
.crp-btn{width:100%;margin-top:1.4rem;padding:.9rem;background:linear-gradient(130deg,var(--accent),var(--accent2));color:#fff;font-family:var(--font);font-size:.95rem;font-weight:800;border:none;border-radius:11px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;letter-spacing:.01em;transition:transform .15s,box-shadow .15s,opacity .15s;box-shadow:0 4px 22px rgba(79,110,247,.38);}
.crp-btn:hover{transform:translateY(-1px);box-shadow:0 7px 28px rgba(79,110,247,.5);}
.crp-btn:active{transform:none;}
.crp-btn:disabled{opacity:.6;cursor:not-allowed;transform:none;}
.crp-btn-idle,.crp-btn-loading{display:flex;align-items:center;gap:.5rem;}
.crp-spin{animation:crp-spin .7s linear infinite;}
@keyframes crp-spin{to{transform:rotate(360deg);}}

/* Error */
.crp-error{margin:0 2rem 1.5rem;background:rgba(247,85,85,.07);border:1px solid rgba(247,85,85,.22);color:#faa;border-radius:10px;padding:.8rem 1rem;font-size:.84rem;display:flex;align-items:center;gap:.5rem;animation:crp-up .2s ease;}

/* Results */
.crp-results{padding:0 2rem 2rem;animation:crp-up .3s ease;}
@keyframes crp-up{from{opacity:0;transform:translateY(10px);}to{opacity:1;transform:translateY(0);}}

.crp-results-hdr{display:flex;align-items:flex-start;justify-content:space-between;padding:.8rem 0 1rem;border-top:1px solid var(--border);}
.crp-results-title{font-size:.88rem;font-weight:800;margin-bottom:.3rem;}
.crp-route-line{font-size:.8rem;color:var(--muted);display:flex;align-items:center;gap:.4rem;}
.crp-wt-pill{font-family:var(--mono);font-size:.67rem;color:var(--muted);background:var(--card);border:1px solid var(--border);border-radius:6px;padding:.25rem .7rem;white-space:nowrap;flex-shrink:0;}

/* Cards */
.crp-cards{display:flex;flex-direction:column;gap:.75rem;}
.crp-card{background:var(--card);border:1.5px solid var(--border);border-radius:16px;padding:1.15rem 1.3rem;display:grid;grid-template-columns:1fr auto;gap:.4rem 1.2rem;align-items:center;animation:crp-up .3s ease both;transition:border-color .2s,transform .15s;}
.crp-card:hover{border-color:var(--accent);transform:translateX(4px);}
.crp-card:nth-child(1){animation-delay:.04s}.crp-card:nth-child(2){animation-delay:.08s}.crp-card:nth-child(3){animation-delay:.12s}.crp-card:nth-child(4){animation-delay:.16s}

.crp-svc-row{display:flex;align-items:center;gap:.55rem;margin-bottom:.3rem;}
.crp-svc-name{font-size:.97rem;font-weight:700;}
.crp-badge{font-size:.6rem;font-weight:800;padding:.14rem .52rem;border-radius:20px;text-transform:uppercase;letter-spacing:.08em;}
.crp-badge--air  {background:rgba(79,110,247,.14);color:var(--accent);}
.crp-badge--sea  {background:rgba(79,178,247,.14);color:#4fb2f7;}
.crp-badge--fast {background:rgba(247,169,79,.14); color:var(--amber);}
.crp-badge--doc  {background:rgba(0,212,170,.12);  color:var(--green);}
.crp-badge--truck{background:rgba(160,160,200,.12);color:#a0a0c8;}

.crp-transit{font-size:.76rem;color:var(--muted);display:flex;align-items:center;gap:.35rem;margin:.25rem 0;}
.crp-breakdown{font-family:var(--mono);font-size:.66rem;color:var(--muted);}
.crp-card-note{font-size:.69rem;color:var(--muted);margin-top:.25rem;font-style:italic;}
.crp-best{font-size:.65rem;color:var(--green);font-weight:700;margin-top:.2rem;}

.crp-price-col{text-align:right;}
.crp-price-lbl{font-size:.62rem;text-transform:uppercase;letter-spacing:.09em;color:var(--muted);}
.crp-price{font-family:var(--mono);font-size:1.6rem;font-weight:700;letter-spacing:-.03em;color:var(--text);margin:.2rem 0 .1rem;line-height:1;}
.crp-incl{font-size:.64rem;color:var(--muted);}

.crp-disclaimer{font-size:.69rem;color:var(--muted);text-align:center;margin-top:1.2rem;line-height:1.65;border-top:1px solid var(--border);padding-top:1rem;}

/* Responsive */
@media(max-width:640px){
  .crp-form,.crp-results{padding-left:1.1rem;padding-right:1.1rem;}
  .crp-header{padding:1.2rem 1.1rem;flex-wrap:wrap;}
  .crp-route-grid{grid-template-columns:1fr 38px 1fr;}
  .crp-pkg-grid{grid-template-columns:1fr 1fr;}
  .crp-card{grid-template-columns:1fr;}
  .crp-price-col{text-align:left;}
}
