/* ==========================================================================
   Travelotopos — static copy — shared stylesheet
   Brand: navy #000a48 on white. Fonts: Rubik / Ubuntu / Lora.
   ========================================================================== */

:root{
  --navy:#000a48; --navy-700:#0b1a6b; --ink:#1c1f2a; --muted:#5b6072;
  --bg:#ffffff; --bg-alt:#f6f8fc; --bg-alt2:#eef2fb; --line:#e5e8f0;
  --accent:#0693e3; --accent-2:#00d084; --magenta:#980f6b;
  --maxw:1180px; --radius:12px; --shadow:0 12px 34px rgba(0,10,72,.08);
  --shadow-sm:0 4px 14px rgba(0,10,72,.06);
  --sans:'Rubik','Ubuntu',Arial,Helvetica,sans-serif; --serif:'Lora',Georgia,serif;
}

/* base ------------------------------------------------------------------ */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--sans);color:var(--ink);background:var(--bg);
  line-height:1.65;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:var(--navy);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4,h5{font-family:var(--sans);color:var(--navy);line-height:1.18;margin:0 0 .5em;font-weight:700}
h1{font-size:clamp(2rem,4.4vw,3.4rem);letter-spacing:-.5px}
h2{font-size:clamp(1.7rem,3.2vw,2.5rem);letter-spacing:-.4px}
h3{font-size:clamp(1.2rem,2vw,1.5rem)}
p{margin:0 0 1rem}
ul,ol{margin:0 0 1rem}

/* layout helpers -------------------------------------------------------- */
.container{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.section{padding:78px 0}
.section.tight{padding:48px 0}
.section.alt{background:var(--bg-alt)}
.section.alt2{background:var(--bg-alt2)}
.section.navy{background:var(--navy);color:#dfe3f4}
.section.navy h1,.section.navy h2,.section.navy h3{color:#fff}
.section-head{max-width:760px;margin:0 auto 48px;text-align:center}
.section-head p{color:var(--muted);font-size:1.1rem}
.eyebrow{display:inline-block;text-transform:uppercase;letter-spacing:1.5px;
  font-size:.78rem;font-weight:600;color:var(--accent);margin-bottom:14px}
.lead{font-size:1.2rem;color:var(--muted)}
.muted{color:var(--muted)}
.text-center{text-align:center}
.serif{font-family:var(--serif)}

/* buttons --------------------------------------------------------------- */
.btn{display:inline-block;padding:.85em 1.7em;border-radius:40px;font-weight:600;
  border:2px solid transparent;cursor:pointer;transition:.18s;line-height:1.2;font-size:1rem}
.btn:hover{text-decoration:none;transform:translateY(-1px)}
.btn-primary{background:var(--navy);color:#fff}
.btn-primary:hover{background:var(--navy-700);color:#fff}
.btn-accent{background:var(--accent);color:#fff}
.btn-accent:hover{background:#057bbd;color:#fff}
.btn-ghost{background:transparent;color:var(--navy);border-color:var(--navy)}
.btn-ghost:hover{background:var(--navy);color:#fff}
.btn-white{background:#fff;color:var(--navy)}
.btn-white:hover{background:#eef2fb;color:var(--navy)}
.btn-row{display:flex;gap:14px;flex-wrap:wrap;align-items:center}

/* grids & cards --------------------------------------------------------- */
.grid{display:grid;gap:28px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:30px;box-shadow:var(--shadow-sm)}
.card h3{margin-top:.2em}
.icon-card .ic{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;
  justify-content:center;background:var(--bg-alt2);margin-bottom:18px;font-size:1.6rem}
.icon-card .ic img{width:32px;height:32px}

/* feature rows (alternating media + text) ------------------------------- */
.feature-row{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center;margin:0 0 64px}
.feature-row:last-child{margin-bottom:0}
.feature-row.reverse .media{order:2}
.feature-row .media img{border-radius:var(--radius);box-shadow:var(--shadow)}

/* hero ------------------------------------------------------------------ */
.hero{padding:84px 0;background:linear-gradient(180deg,#eef2fb 0%,#fff 100%)}
.hero-split{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.hero-split .media img{border-radius:var(--radius);box-shadow:var(--shadow)}
.hero h1{margin-bottom:.35em}
.hero .lead{max-width:560px;margin-bottom:1.6em}

/* check lists ----------------------------------------------------------- */
.check-list{list-style:none;margin:0 0 1rem;padding:0;display:grid;gap:12px}
.check-list li{position:relative;padding-left:34px}
.check-list li::before{content:"";position:absolute;left:0;top:2px;width:22px;height:22px;
  border-radius:50%;background:var(--accent-2);
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23fff' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/16px no-repeat;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23fff' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/16px no-repeat;}
.check-list.cols{grid-template-columns:repeat(2,1fr)}

/* stats ----------------------------------------------------------------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:28px;text-align:center}
.stat .num{font-size:clamp(2rem,4vw,3rem);font-weight:800;color:var(--navy);line-height:1}
.section.navy .stat .num{color:#fff}
.stat .label{color:var(--muted);margin-top:8px}
.section.navy .stat .label{color:#aeb6dd}

/* steps ----------------------------------------------------------------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;counter-reset:step}
.step{position:relative;padding-top:8px}
.step .n{width:46px;height:46px;border-radius:50%;background:var(--navy);color:#fff;
  display:flex;align-items:center;justify-content:center;font-weight:700;margin-bottom:16px}

/* logo strip (partners / clients) -------------------------------------- */
.logo-strip{display:flex;flex-wrap:wrap;gap:40px;align-items:center;justify-content:center}
.logo-strip img{max-height:46px;width:auto;opacity:.75;filter:grayscale(1);transition:.2s}
.logo-strip img:hover{opacity:1;filter:none}
.logo-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:28px;align-items:center}
.logo-grid img{max-height:56px;width:auto;margin:0 auto}
.logo-grid--lg{gap:48px 64px}
.logo-grid--lg img{max-height:120px;max-width:92%;width:auto;height:auto;object-fit:contain}

/* testimonials ---------------------------------------------------------- */
.testimonial{background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:30px;box-shadow:var(--shadow-sm)}
.testimonial .quote{font-family:var(--serif);font-size:1.05rem;color:var(--ink)}
.testimonial .who{display:flex;align-items:center;gap:12px;margin-top:18px}
.testimonial .who img{width:46px;height:46px;border-radius:50%}

/* pricing --------------------------------------------------------------- */
.pricing{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;align-items:stretch}
.plan{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius);padding:32px;box-shadow:var(--shadow-sm)}
.plan.featured{border-color:var(--navy);box-shadow:var(--shadow);position:relative}
.plan.featured::after{content:"Popular";position:absolute;top:-13px;left:50%;transform:translateX(-50%);
  background:var(--navy);color:#fff;font-size:.72rem;letter-spacing:1px;text-transform:uppercase;
  padding:5px 14px;border-radius:20px}
.plan .price{font-size:2.4rem;font-weight:800;color:var(--navy);margin:.2em 0}
.plan .price small{font-size:.95rem;font-weight:500;color:var(--muted)}
.plan .check-list{margin-top:18px;flex:1}
.plan .btn{margin-top:22px;text-align:center}

/* cta band -------------------------------------------------------------- */
.cta-band{background:var(--navy);color:#fff;text-align:center;padding:68px 0}
.cta-band h2{color:#fff;margin-bottom:.4em}
.cta-band p{color:#c7cdec;max-width:620px;margin:0 auto 1.5em}

/* contact cards --------------------------------------------------------- */
.office{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow-sm)}
.office h3{margin-bottom:.4em}

/* prose (legal pages) --------------------------------------------------- */
.prose{max-width:820px;margin:0 auto}
.prose h2{font-size:1.5rem;margin-top:1.6em}
.prose h3{font-size:1.2rem;margin-top:1.4em}
.prose p,.prose li{color:#33384a}
.prose ul,.prose ol{padding-left:1.3em}

/* header ---------------------------------------------------------------- */
.site-header{position:sticky;top:0;z-index:60;background:#fff;border-bottom:1px solid var(--line)}
.header-inner{display:flex;align-items:center;gap:26px;min-height:76px}
.brand img{width:178px}
.primary-nav{margin-left:auto}
.primary-nav>ul{display:flex;gap:24px;list-style:none;margin:0;padding:0}
.primary-nav>ul>li>a{color:var(--ink);font-weight:500;padding:10px 0;display:inline-block}
.primary-nav>ul>li>a:hover{color:var(--navy);text-decoration:none}
.has-sub{position:relative}
.has-sub>a::after{content:" \25BE";font-size:.7em;color:var(--muted)}
.sub{position:absolute;top:100%;left:0;min-width:230px;background:#fff;border:1px solid var(--line);
  border-radius:12px;box-shadow:var(--shadow);list-style:none;margin:0;padding:8px;display:none}
.sub li a{display:block;padding:9px 12px;border-radius:8px;color:var(--ink)}
.sub li a:hover{background:var(--bg-alt);text-decoration:none}
.has-sub:hover .sub{display:block}
.header-cta{white-space:nowrap}
.nav-toggle{display:none;font-size:1.7rem;background:none;border:0;cursor:pointer;color:var(--navy);margin-left:auto}

/* footer ---------------------------------------------------------------- */
.site-footer{background:var(--navy);color:#c2c8e8}
.site-footer h2{color:#fff;font-size:1rem;margin-bottom:14px}
.site-footer a{color:#c2c8e8}
.site-footer a:hover{color:#fff}
.footer-grid{display:grid;grid-template-columns:1.5fr repeat(4,1fr);gap:34px;padding:62px 22px}
.footer-brand img{width:170px;margin-bottom:16px;filter:brightness(0) invert(1)}
.footer-brand p{color:#aeb6dd;max-width:280px}
.footer-col ul{list-style:none;margin:0;padding:0;display:grid;gap:9px}
.footer-bottom{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;
  padding:18px 22px;border-top:1px solid rgba(255,255,255,.12);font-size:.9rem;color:#aeb6dd}
.footer-bottom a{color:#cdd2ec}

/* responsive ------------------------------------------------------------ */
@media(max-width:980px){
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:900px){
  .nav-toggle{display:block}
  .primary-nav{position:absolute;top:76px;left:0;right:0;background:#fff;
    border-bottom:1px solid var(--line);display:none;box-shadow:var(--shadow)}
  .primary-nav.open{display:block}
  .primary-nav>ul{flex-direction:column;gap:0;padding:8px 22px}
  .primary-nav>ul>li{border-bottom:1px solid var(--line)}
  .has-sub>a::after{float:right}
  .sub{position:static;display:none;box-shadow:none;border:0;padding:0 0 8px 14px}
  .has-sub.sub-open .sub{display:block}
  .header-cta{display:none}
  .hero-split,.feature-row,.feature-row.reverse{grid-template-columns:1fr;gap:30px}
  .feature-row.reverse .media{order:0}
  .grid-2,.grid-3,.grid-4,.pricing,.steps,.logo-grid{grid-template-columns:1fr}
  .stats{grid-template-columns:repeat(2,1fr)}
  .check-list.cols{grid-template-columns:1fr}
}
@media(max-width:560px){
  .section{padding:54px 0}
  .footer-grid{grid-template-columns:1fr}
  .logo-grid{grid-template-columns:repeat(2,1fr)}
}

/* book-a-demo modal ----------------------------------------------------- */
.demo-modal{position:fixed;inset:0;z-index:1000;visibility:hidden;opacity:0;transition:opacity .2s ease}
.demo-modal.open{visibility:visible;opacity:1}
.demo-modal-overlay{position:absolute;inset:0;background:rgba(0,10,72,.55)}
.demo-modal-dialog{position:relative;max-width:560px;margin:5vh auto;background:#fff;border-radius:14px;
  box-shadow:0 30px 80px rgba(0,10,72,.35);padding:34px 32px;max-height:90vh;overflow:auto}
.demo-modal-dialog h3{margin-top:0;margin-bottom:.3em}
.demo-modal-close{position:absolute;top:10px;right:16px;border:0;background:none;font-size:1.9rem;
  line-height:1;color:var(--muted);cursor:pointer;padding:4px}
.demo-modal-close:hover{color:var(--navy)}
.hs-form-frame{display:block;width:100%;min-height:480px}
.hs-form-frame iframe{width:100%!important;min-height:480px;border:0}
@media(max-width:600px){
  .demo-modal-dialog{margin:0;min-height:100vh;max-height:100vh;border-radius:0;padding:28px 20px}
}

/* ===== API documentation ===== */
.container-narrow{max-width:920px}
.section-head h6,.notes h6,.pricing-ex h6{font-size:.95rem;color:var(--navy);margin:0 0 6px;font-weight:700}

/* Table of contents */
.api-toc{display:grid;grid-template-columns:repeat(5,1fr);gap:26px}
.api-toc-col h5{font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--accent);margin:0 0 10px}
.api-toc-col ul{list-style:none;margin:0;padding:0}
.api-toc-col li{margin:0 0 6px}
.api-toc-col a{color:var(--muted);font-size:.9rem;line-height:1.4}
.api-toc-col a:hover{color:var(--navy)}

/* Endpoint card */
.endpoint{background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:26px 28px;box-shadow:var(--shadow-sm);margin:0 0 22px;scroll-margin-top:90px}
.endpoint:last-child{margin-bottom:0}
.endpoint-head{display:flex;align-items:center;gap:12px;margin-bottom:10px;flex-wrap:wrap}
.endpoint-head h4{margin:0;font-size:1.25rem}
.endpoint-desc{color:var(--muted);margin:0 0 16px}
.method{display:inline-block;font-family:var(--sans);font-size:.72rem;font-weight:700;
  letter-spacing:.05em;padding:4px 10px;border-radius:6px;color:#fff;text-transform:uppercase}
.method-get{background:var(--accent-2)}
.method-post{background:var(--accent)}

.endpoint-url,.endpoint-meta{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;margin:0 0 8px;font-size:.92rem}
.endpoint-url .lbl,.endpoint-meta .lbl{flex:0 0 auto;font-size:.7rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.05em;color:var(--muted);min-width:84px}
code{font-family:'SFMono-Regular',ui-monospace,Menlo,Consolas,monospace;font-size:.88em;
  background:var(--bg-alt2);color:var(--navy);padding:2px 6px;border-radius:5px;
  word-break:break-word}
.endpoint-url code{background:var(--bg-alt);border:1px solid var(--line)}

/* Parameter table */
.table-wrap{overflow-x:auto;margin:14px 0}
table.params{width:100%;border-collapse:collapse;font-size:.9rem}
table.params th,table.params td{text-align:left;padding:9px 12px;border-bottom:1px solid var(--line);vertical-align:top}
table.params thead th{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);
  border-bottom:2px solid var(--line);background:var(--bg-alt)}
table.params td:first-child{font-family:ui-monospace,Menlo,Consolas,monospace;color:var(--navy);font-weight:600;white-space:nowrap}

/* Notes */
.notes{background:var(--bg-alt);border:1px solid var(--line);border-radius:10px;padding:16px 20px;margin:16px 0}
.notes h5{margin:0 0 8px;font-size:.78rem;text-transform:uppercase;letter-spacing:.05em;color:var(--accent)}
.notes ul{margin:0;padding-left:18px}
.notes li{margin:0 0 6px;color:var(--ink);font-size:.92rem;line-height:1.5}
.notes ul.cols-2{columns:2;column-gap:30px}
.notes p{margin:0 0 8px;font-size:.92rem}
.pricing-ex{background:#fff;border:1px solid var(--line);border-radius:10px;padding:16px 18px}
.pricing-ex ul{padding-left:18px;margin:8px 0 0}
.pricing-ex li{font-size:.9rem;margin:0 0 4px}

/* Sample response (collapsible) */
details.sample{margin:14px 0 0;border:1px solid var(--line);border-radius:10px;overflow:hidden}
details.sample summary{cursor:pointer;padding:11px 16px;font-size:.82rem;font-weight:600;color:var(--navy);
  background:var(--bg-alt);list-style:none;user-select:none}
details.sample summary::-webkit-details-marker{display:none}
details.sample summary::before{content:'\25B8';display:inline-block;margin-right:8px;color:var(--accent);transition:transform .15s}
details.sample[open] summary::before{transform:rotate(90deg)}
pre.code{margin:0;padding:18px 20px;background:var(--navy);color:#e7ecff;overflow-x:auto;
  font-family:ui-monospace,Menlo,Consolas,monospace;font-size:.82rem;line-height:1.55}
pre.code code{background:none;color:inherit;padding:0;border:0;font-size:inherit}

/* Dark webhook endpoint */
.endpoint-dark{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.14)}
.endpoint-dark .endpoint-head h4{color:#fff}
.endpoint-dark .endpoint-desc{color:#aeb6dd}
.endpoint-dark .endpoint-meta .lbl{color:#8b93c4}
.endpoint-dark .notes{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.12)}
.endpoint-dark .notes li{color:#dfe3f4}
.endpoint-dark code{background:rgba(255,255,255,.1);color:#e7ecff}

@media(max-width:880px){
  .api-toc{grid-template-columns:repeat(2,1fr)}
  .notes ul.cols-2{columns:1}
}
@media(max-width:560px){
  .api-toc{grid-template-columns:1fr}
  .endpoint{padding:20px}
}
