
    :root{
      --primary:#B40902;
      --primary-dark:#8a0700;
      --primary-deep:#5c0400;
      --primary-soft:rgba(180,9,2,.08);
      --line:rgba(16,24,40,.10);
      --ink:#101828;
      --ink-mid:#475467;
      --ink-soft:#667085;
      --white:#fff;
      --snow:#fffafa;
      --mint:#ecfdf3;
      --mint-line:#abefc6;
      --mint-text:#067647;
      --amber:#fff7e8;
      --amber-line:#f6d7a7;
      --amber-text:#8a5a00;
      --font-head:'Playfair Display', serif;
      --font-body:'Nunito', sans-serif;
      --co-wrap:1260px;
      --r12:12px;
      --r16:16px;
      --r20:20px;
      --r24:24px;
      --ease:cubic-bezier(.4,0,.2,1);
    }

    *{box-sizing:border-box}
    body{
      margin:0;
      font-family:var(--font-body);
      color:var(--ink);
      background:
        radial-gradient(circle at top left, rgba(180,9,2,.05), transparent 24%),
        linear-gradient(180deg,#fffdfd 0%,#f7f3f3 48%,#f3eeee 100%);
    }
    a{text-decoration:none;color:inherit}
    button,input,select,textarea{font:inherit}

    .rh-mainbar .rh-wrap{
      gap:10px;
    }

    .rh-nav{
      gap:0;
      margin-left:10px;
    }

    .rh-nav-link{
      padding:10px 9px;
      font-size:12.5px;
    }

    .rh-right{
      gap:8px;
    }

    .rh-search-desktop{
      width:250px;
    }

    .rh-search-submit{
      padding:0 12px;
    }

    .rh-login{
      padding:10px 14px;
    }

    .co-shell{
      width:min(var(--co-wrap), calc(100% - 22px));
      margin:0 auto;
      padding:14px 0 24px;
    }

    .co-breadcrumb{
      display:flex;
      align-items:center;
      flex-wrap:wrap;
      gap:7px;
      margin:0 0 10px;
      font-size:11.5px;
      font-weight:800;
      color:var(--ink-soft);
    }
    .co-breadcrumb a{color:var(--primary)}
    .co-breadcrumb i{font-size:10px;color:#c7ccd4}

    .co-hero{
      border-radius:var(--r24);
      padding:16px 18px;
      background:
        radial-gradient(circle at top left, rgba(180,9,2,.08), transparent 28%),
        linear-gradient(180deg, rgba(255,255,255,.98), rgba(255,248,247,.96));
      color:var(--ink);
      box-shadow:0 12px 26px rgba(16,24,40,.05);
      border:1px solid rgba(180,9,2,.10);
      margin-bottom:12px;
    }

    .co-hero-grid{
      display:grid;
      grid-template-columns:minmax(0,1fr) 300px;
      gap:14px;
      align-items:center;
    }

    .co-kicker{
      display:inline-flex;
      align-items:center;
      gap:7px;
      margin-bottom:10px;
      padding:8px 12px;
      border-radius:999px;
      background:#fff;
      border:1px solid rgba(180,9,2,.14);
      color:var(--primary);
      font-size:10px;
      font-weight:900;
      letter-spacing:.12em;
      text-transform:uppercase;
      box-shadow:0 8px 18px rgba(180,9,2,.05);
    }

    .co-hero h1{
      margin:0 0 8px;
      font-family:var(--font-body);
      font-size:clamp(1.3rem,2.6vw,2rem);
      line-height:1.15;
      letter-spacing:-.02em;
      font-weight:900;
    }

    .co-hero p{
      margin:0;
      max-width:640px;
      font-size:12.6px;
      line-height:1.65;
      color:var(--ink-mid);
      font-weight:700;
    }

    .co-steps{
      display:flex;
      flex-wrap:wrap;
      gap:6px;
      margin-top:14px;
    }

    .co-step-chip{
      display:inline-flex;
      align-items:center;
      gap:6px;
      padding:7px 10px;
      border-radius:999px;
      background:#fff;
      border:1px solid rgba(16,24,40,.08);
      font-size:10px;
      font-weight:800;
      color:var(--ink);
    }

    .co-trip-box{
      padding:14px;
      border-radius:20px;
      background:linear-gradient(180deg,#fff,#fff7f6);
      border:1px solid rgba(180,9,2,.12);
      box-shadow:0 10px 20px rgba(180,9,2,.05);
    }

    .co-trip-label{
      font-size:10px;
      font-weight:900;
      letter-spacing:.12em;
      text-transform:uppercase;
      color:var(--primary);
      margin-bottom:8px;
    }

    .co-top-stat{
      display:flex;
      align-items:flex-start;
      justify-content:space-between;
      gap:8px;
      padding:10px 0;
      border-top:1px solid rgba(180,9,2,.10);
    }

    .co-top-stat:first-of-type{
      border-top:none;
      padding-top:0;
    }

    .co-top-key{
      display:block;
      font-size:9.5px;
      letter-spacing:.12em;
      text-transform:uppercase;
      color:var(--ink-soft);
      font-weight:900;
      margin-bottom:4px;
    }

    .co-top-value{
      display:block;
      font-size:13px;
      line-height:1.4;
      color:var(--ink);
      font-weight:800;
    }

    .co-price-pill{
      flex-shrink:0;
      padding:7px 11px;
      border-radius:999px;
      background:var(--primary-soft);
      color:var(--primary);
      font-size:11px;
      font-weight:900;
    }

    .co-mobile-total{
      display:none;
      margin-bottom:10px;
      padding:10px 12px;
      border-radius:16px;
      border:1px solid rgba(16,24,40,.08);
      background:rgba(255,255,255,.96);
      box-shadow:0 8px 20px rgba(16,24,40,.05);
      align-items:center;
      justify-content:space-between;
      gap:10px;
    }

    .co-mobile-total-label{
      display:block;
      font-size:9px;
      letter-spacing:.12em;
      text-transform:uppercase;
      color:var(--ink-soft);
      font-weight:900;
      margin-bottom:4px;
    }

    .co-mobile-total strong{
      display:block;
      font-size:18px;
      line-height:1;
      color:var(--primary);
      font-weight:900;
    }

    .co-mobile-total button{
      border:none;
      border-radius:12px;
      background:var(--primary-soft);
      color:var(--primary);
      padding:10px 12px;
      font-size:11px;
      font-weight:900;
      white-space:nowrap;
      cursor:pointer;
    }

    .co-layout{
      display:grid;
      grid-template-columns:minmax(0,1fr) 345px;
      gap:10px;
      align-items:start;
    }

    .co-left{
      display:grid;
      gap:8px;
    }

    .co-card{
      border-radius:22px;
      border:1px solid var(--line);
      background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(255,250,250,.96));
      box-shadow:0 10px 24px rgba(16,24,40,.05);
      overflow:hidden;
    }

    .co-card-head{
      width:100%;
      border:none;
      background:transparent;
      display:flex;
      align-items:center;
      justify-content:space-between;
      gap:12px;
      padding:11px 12px;
      text-align:left;
      cursor:pointer;
    }

    .co-card-title{
      margin:0 0 3px;
      font-size:15px;
      line-height:1.1;
      font-weight:900;
      color:var(--ink);
    }

    .co-card-sub{
      margin:0;
      color:var(--ink-mid);
      font-size:11px;
      line-height:1.45;
      font-weight:600;
    }

    .co-head-right{
      display:flex;
      align-items:center;
      gap:8px;
      flex-shrink:0;
    }

    .co-head-index{
      font-size:10px;
      font-weight:900;
      letter-spacing:.12em;
      text-transform:uppercase;
      color:var(--ink-soft);
    }

    .co-head-icon{
      width:28px;
      height:28px;
      border-radius:10px;
      display:flex;
      align-items:center;
      justify-content:center;
      background:linear-gradient(180deg,#fff,#fff2f1);
      border:1px solid rgba(180,9,2,.18);
      color:var(--primary);
      font-size:11px;
    }

    .co-head-arrow{
      width:24px;
      height:24px;
      border-radius:9px;
      display:flex;
      align-items:center;
      justify-content:center;
      background:var(--primary-soft);
      color:var(--primary);
      font-size:10px;
      transition:transform .2s ease, background .2s ease, color .2s ease;
    }

    .co-card.is-open .co-head-arrow{
      transform:rotate(180deg);
      background:var(--primary);
      color:#fff;
    }

    .co-body{
      display:none;
      padding:0 12px 12px;
    }

    .co-card.is-open .co-body{display:block}

    .co-grid-2,
    .co-grid-3{
      display:grid;
      gap:10px;
    }

    .co-grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
    .co-grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}

    .co-field{
      display:flex;
      flex-direction:column;
      gap:6px;
    }
    .co-field-full{grid-column:1/-1}

    .co-label{
      font-size:11px;
      font-weight:900;
      letter-spacing:.04em;
      text-transform:uppercase;
      color:var(--ink-mid);
    }

    .co-input,
    .co-select,
    .co-textarea{
      width:100%;
      border:1.5px solid rgba(16,24,40,.10);
      border-radius:12px;
      background:var(--snow);
      color:var(--ink);
      padding:9px 11px;
      font-size:12px;
      font-weight:700;
      outline:none;
      transition:border-color .2s ease, box-shadow .2s ease, background .2s ease;
    }

    .co-input:focus,
    .co-select:focus,
    .co-textarea:focus{
      border-color:rgba(180,9,2,.32);
      background:#fff;
      box-shadow:0 0 0 4px rgba(180,9,2,.06);
    }

    .co-select{
      appearance:none;
      background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 16 16' fill='%23475467'%3E%3Cpath d='M4.47 6.97a.75.75 0 0 1 1.06 0L8 9.44l2.47-2.47a.75.75 0 0 1 1.06 1.06l-3 3a.75.75 0 0 1-1.06 0l-3-3a.75.75 0 0 1 0-1.06Z'/%3E%3C/svg%3E");
      background-repeat:no-repeat;
      background-position:right 12px center;
      padding-right:38px;
    }

    .co-textarea{
      min-height:72px;
      resize:vertical;
      line-height:1.55;
    }

    .co-pills{
      display:flex;
      flex-wrap:wrap;
      gap:8px;
    }

    .co-pill{
      border:1.5px solid rgba(16,24,40,.10);
      background:#fff;
      color:var(--ink-mid);
      border-radius:999px;
      padding:7px 10px;
      font-size:11px;
      font-weight:900;
      cursor:pointer;
      transition:.2s ease;
    }

    .co-pill.active,
    .co-pill:hover{
      border-color:rgba(180,9,2,.24);
      background:var(--primary-soft);
      color:var(--primary);
    }

    .co-counter{
      border:1px solid var(--line);
      border-radius:12px;
      background:#fff;
      padding:10px;
    }

    .co-counter-top{
      margin-bottom:9px;
    }

    .co-counter-title{
      font-size:11.5px;
      font-weight:800;
      color:var(--ink);
    }

    .co-counter-note{
      font-size:10px;
      color:var(--ink-soft);
      font-weight:700;
    }

    .co-counter-controls{
      display:flex;
      align-items:center;
      justify-content:space-between;
      gap:8px;
    }

    .co-counter-btn{
      width:28px;
      height:28px;
      border:none;
      border-radius:9px;
      background:var(--primary-soft);
      color:var(--primary);
      font-size:12px;
      font-weight:900;
      cursor:pointer;
    }

    .co-counter-value{
      min-width:20px;
      text-align:center;
      font-size:16px;
      font-weight:900;
      color:var(--ink);
    }

    .co-note,
    .co-alert{
      border-radius:12px;
      padding:10px 11px;
      display:flex;
      align-items:flex-start;
      gap:10px;
      font-size:11.2px;
      line-height:1.55;
      font-weight:700;
      margin-bottom:10px;
    }

    .co-note{
      background:var(--mint);
      border:1px solid var(--mint-line);
      color:var(--mint-text);
    }

    .co-alert{
      background:var(--amber);
      border:1px solid var(--amber-line);
      color:var(--amber-text);
    }

    .co-gear-grid{
      display:grid;
      grid-template-columns:repeat(3,minmax(0,1fr));
      gap:8px;
    }

    .co-gear{
      border:1px solid rgba(16,24,40,.08);
      border-radius:16px;
      background:#fff;
      overflow:hidden;
    }

    .co-gear-photo{
      position:relative;
      height:88px;
      overflow:hidden;
      background:#ddd;
    }

    .co-gear-photo img{
      width:100%;
      height:100%;
      object-fit:cover;
      display:block;
    }

    .co-gear-badge{
      position:absolute;
      left:10px;
      top:10px;
      padding:6px 8px;
      border-radius:999px;
      background:rgba(255,255,255,.92);
      color:var(--primary);
      font-size:9.8px;
      font-weight:900;
    }

    .co-gear-body{
      padding:10px;
    }

    .co-gear-top{
      display:flex;
      align-items:flex-start;
      justify-content:space-between;
      gap:8px;
      margin-bottom:8px;
    }

    .co-gear-name{
      margin:0 0 3px;
      font-size:13px;
      line-height:1.2;
      font-weight:900;
      color:var(--ink);
    }

    .co-gear-copy{
      margin:0;
      color:var(--ink-mid);
      font-size:10.6px;
      line-height:1.45;
      font-weight:600;
    }

    .co-gear-price{
      color:var(--primary);
      font-size:12px;
      font-weight:900;
      white-space:nowrap;
    }

    .co-gear-bottom{
      display:flex;
      align-items:center;
      justify-content:space-between;
      gap:8px;
    }

    .co-gear-size{min-width:92px}

    .co-qty{
      display:flex;
      align-items:center;
      gap:6px;
    }

    .co-qty-btn{
      width:24px;
      height:24px;
      border:none;
      border-radius:8px;
      background:var(--primary-soft);
      color:var(--primary);
      font-size:11px;
      font-weight:900;
      cursor:pointer;
    }

    .co-qty-value{
      min-width:18px;
      text-align:center;
      font-size:13px;
      font-weight:900;
      color:var(--ink);
    }

    .co-payment-split{
      display:grid;
      grid-template-columns:repeat(2,minmax(0,1fr));
      gap:10px;
      margin:10px 0 0;
    }

    .co-payment-box{
      border:1px solid rgba(16,24,40,.08);
      border-radius:14px;
      background:#fff;
      padding:10px 11px;
    }

    .co-payment-box span{
      display:block;
      font-size:9.8px;
      letter-spacing:.1em;
      text-transform:uppercase;
      color:var(--ink-soft);
      font-weight:900;
      margin-bottom:4px;
    }

    .co-payment-box strong{
      display:block;
      font-size:15px;
      line-height:1.1;
      color:var(--ink);
      font-weight:900;
    }

    .co-payment-box small{
      display:block;
      margin-top:4px;
      color:var(--ink-mid);
      font-size:10.4px;
      line-height:1.4;
      font-weight:700;
    }

    .co-plan-toggle{
      display:flex;
      gap:8px;
      margin-top:10px;
    }

    .co-plan-btn{
      flex:1;
      border:1.5px solid rgba(16,24,40,.10);
      border-radius:12px;
      background:#fff;
      padding:10px 11px;
      text-align:left;
      cursor:pointer;
      transition:.2s ease;
    }

    .co-plan-btn.active,
    .co-plan-btn:hover{
      border-color:rgba(180,9,2,.24);
      background:linear-gradient(180deg,#fff,#fff7f6);
      box-shadow:0 10px 18px rgba(180,9,2,.05);
    }

    .co-plan-btn strong{
      display:block;
      color:var(--ink);
      font-size:11px;
      line-height:1.35;
      font-weight:900;
      margin-bottom:3px;
    }

    .co-plan-btn span{
      display:block;
      color:var(--ink-soft);
      font-size:10.1px;
      line-height:1.45;
      font-weight:700;
    }

    .co-summary{
      position:sticky;
      top:96px;
      display:grid;
      gap:8px;
    }

    .co-summary-card{
      border-radius:20px;
      border:1px solid rgba(16,24,40,.08);
      background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(255,250,250,.96));
      box-shadow:0 12px 28px rgba(16,24,40,.06);
      overflow:hidden;
    }

    .co-summary-head{
      padding:12px 12px 10px;
      border-bottom:1px solid rgba(16,24,40,.06);
    }

    .co-summary-kicker{
      display:inline-flex;
      align-items:center;
      gap:6px;
      margin-bottom:7px;
      padding:6px 9px;
      border-radius:999px;
      background:var(--primary-soft);
      color:var(--primary);
      font-size:9.8px;
      font-weight:900;
      letter-spacing:.12em;
      text-transform:uppercase;
    }

    .co-summary-title{
      margin:0 0 4px;
      font-size:17px;
      line-height:1.05;
      font-weight:900;
      color:var(--ink);
    }

    .co-summary-copy{
      margin:0;
      color:var(--ink-mid);
      font-size:11px;
      line-height:1.45;
      font-weight:600;
    }

    .co-summary-body{
      padding:12px;
    }

    .co-list{
      display:grid;
      gap:7px;
    }

    .co-row{
      display:flex;
      align-items:flex-start;
      justify-content:space-between;
      gap:10px;
      font-size:11.5px;
      line-height:1.45;
      color:var(--ink-mid);
      font-weight:700;
    }

    .co-row strong{color:var(--ink)}
    .co-row-price{color:var(--ink);font-weight:900;white-space:nowrap}

    .co-divider{
      height:1px;
      background:rgba(16,24,40,.08);
      margin:11px 0;
    }

    .co-empty{
      font-size:11.5px;
      line-height:1.5;
      color:var(--ink-soft);
      font-weight:700;
      padding:9px 10px;
      border-radius:10px;
      background:var(--snow);
      border:1px dashed rgba(16,24,40,.12);
    }

    .co-payment-status{
      margin-top:9px;
      padding:9px 10px;
      border-radius:10px;
      background:var(--primary-soft);
      color:var(--primary);
      font-size:10.8px;
      line-height:1.5;
      font-weight:800;
    }

    .co-total-label{
      display:block;
      font-size:10.5px;
      letter-spacing:.12em;
      text-transform:uppercase;
      color:var(--ink-soft);
      font-weight:900;
      margin-bottom:4px;
    }

    .co-total strong{
      display:block;
      font-size:21px;
      line-height:1;
      font-weight:900;
      color:var(--primary);
    }

    .co-total small{
      display:block;
      margin-top:6px;
      color:var(--ink-soft);
      font-size:10.8px;
      line-height:1.45;
      font-weight:700;
    }

    .co-cta{
      width:100%;
      margin-top:13px;
      border:none;
      border-radius:15px;
      padding:12px 13px;
      background:linear-gradient(135deg,var(--primary),var(--primary-dark));
      color:#fff;
      font-size:12.5px;
      font-weight:900;
      display:flex;
      align-items:center;
      justify-content:center;
      gap:9px;
      cursor:pointer;
      box-shadow:0 12px 24px rgba(180,9,2,.18);
    }

    .co-step-actions{
      display:flex;
      justify-content:flex-end;
      gap:8px;
      margin-top:10px;
    }

    .co-step-next{
      border:none;
      border-radius:12px;
      background:var(--primary-soft);
      color:var(--primary);
      padding:9px 12px;
      font-size:11px;
      font-weight:900;
      display:inline-flex;
      align-items:center;
      gap:7px;
      cursor:pointer;
    }

    .co-coupon-box{
      display:grid;
      grid-template-columns:minmax(0,1fr) auto;
      gap:8px;
      align-items:center;
    }

    .co-coupon-apply{
      border:none;
      border-radius:12px;
      background:var(--primary-soft);
      color:var(--primary);
      padding:9px 12px;
      font-size:11px;
      font-weight:700;
      cursor:pointer;
      white-space:nowrap;
    }

    .co-coupon-message{
      margin-top:7px;
      color:var(--ink-soft);
      font-size:10.8px;
      line-height:1.45;
      font-weight:500;
    }

    .co-shell .co-kicker,
    .co-shell .co-trip-label,
    .co-shell .co-step-chip,
    .co-shell .co-head-index,
    .co-shell .co-label,
    .co-shell .co-summary-kicker,
    .co-shell .co-total-label{
      font-weight:700;
    }

    .co-shell .co-hero h1,
    .co-shell .co-card-title,
    .co-shell .co-summary-title,
    .co-shell .co-total strong{
      font-weight:700;
      letter-spacing:0;
    }

    .co-shell .co-hero p,
    .co-shell .co-top-value,
    .co-shell .co-card-sub,
    .co-shell .co-input,
    .co-shell .co-select,
    .co-shell .co-textarea,
    .co-shell .co-counter-note,
    .co-shell .co-note,
    .co-shell .co-alert,
    .co-shell .co-row,
    .co-shell .co-empty,
    .co-shell .co-total small,
    .co-shell .co-payment-status{
      font-weight:500;
    }

    .co-shell .co-price-pill,
    .co-shell .co-pill,
    .co-shell .co-counter-title,
    .co-shell .co-counter-btn,
    .co-shell .co-counter-value,
    .co-shell .co-gear-name,
    .co-shell .co-gear-price,
    .co-shell .co-qty-btn,
    .co-shell .co-qty-value,
    .co-shell .co-payment-box strong,
    .co-shell .co-plan-btn strong,
    .co-shell .co-row strong,
    .co-shell .co-row-price,
    .co-shell .co-cta,
    .co-shell .co-step-next{
      font-weight:700;
    }

    @media (max-width: 1080px){
      .co-layout{grid-template-columns:1fr}
      .co-summary{position:static}
      .co-hero-grid{grid-template-columns:1fr}
    }

    @media (max-width: 820px){
      .co-grid-2,
      .co-payment-split{grid-template-columns:1fr}
      .co-gear-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
      .co-grid-3{grid-template-columns:repeat(2,minmax(0,1fr))}
    }

    @media (max-width: 640px){
      .co-shell{width:min(var(--co-wrap), calc(100% - 14px)); padding:12px 0 20px}
      .co-hero{padding:14px}
      .co-hero h1{font-size:1.18rem}
      .co-hero p{font-size:11.4px}
      .co-flow-chip,.co-step-chip{font-size:10px}
      .co-mobile-total{display:flex}
      .co-card-head{padding:12px}
      .co-body{padding:0 12px 12px}
      .co-summary-head{padding:12px 12px 10px}
      .co-summary-body{padding:12px}
      .co-hero-grid{gap:12px}
      .co-steps{gap:7px}
      .co-step-chip{padding:7px 9px}
      .co-counter{padding:9px 10px}
      .co-counter-controls{justify-content:flex-start; gap:14px}
      .co-counter-value{min-width:26px}
      .co-gear-grid{grid-template-columns:1fr}
      .co-gear{
        display:grid;
        grid-template-columns:86px minmax(0,1fr);
        align-items:stretch;
      }
      .co-gear-photo{
        height:auto;
        min-height:100%;
      }
      .co-gear-badge{
        left:6px;
        top:6px;
        padding:4px 6px;
        font-size:8.8px;
      }
      .co-gear-body{
        padding:9px;
      }
      .co-gear-top{
        margin-bottom:6px;
      }
      .co-gear-name{
        font-size:12px;
      }
      .co-gear-copy{
        font-size:10px;
      }
      .co-gear-bottom{
        flex-direction:column;
        align-items:stretch;
        gap:6px;
      }
      .co-gear-size{
        min-width:0;
      }
      .co-card-title{font-size:14px}
      .co-summary-title{font-size:16px}
      .co-summary-copy{font-size:10.5px}
      .co-coupon-box{grid-template-columns:1fr}
    }
  
