/* ============================================================
   topstudy.com — design v2.1 — HOMEPAGE-ONLY components.
   Loaded only on the homepage (index.hbs), AFTER index.css.
   All selectors scoped under `.ts` (homepage <main class="ts">)
   so they win over legacy index.css and never leak to other pages.
   Tokens/buttons/chrome live in ts-design.css (site-wide).
   ============================================================ */

/* Reset the legacy `main{display:grid;height:560px}` rule from index.css —
   our homepage <main class="ts"> must be a normal flow container. */
.ts{display:block;width:100%;height:auto;grid-template-rows:none;font-family:var(--ts-body);color:var(--ts-text);line-height:1.55;font-size:var(--fs-m)}
.ts h1,.ts h2,.ts h3,.ts h4{font-family:var(--ts-display);color:var(--navy);line-height:1.12;letter-spacing:-.01em}
.ts a{color:inherit;text-decoration:none}
.ts img{display:block;max-width:100%}
.ts .wrap{max-width:1180px;margin-inline:auto;padding-inline:var(--s-5)}

/* ============ Hero v3.1 — full-bleed image, light ============ */
.ts .hero{position:relative;background:linear-gradient(180deg,var(--hero-top),var(--hero-bot));overflow:visible}
.ts .hero-bg{position:absolute;inset:0;overflow:hidden}
.ts .hero-bg img{width:100%;height:100%;object-fit:cover;display:block}
.ts .hero-scrim{position:absolute;inset:0;pointer-events:none;background:
  linear-gradient(94deg,rgba(255,255,255,0) 20%,rgba(255,255,255,.5) 42%,rgba(255,255,255,.55) 76%,rgba(255,255,255,.25) 100%),
  linear-gradient(180deg,rgba(255,255,255,.3) 0%,transparent 30%)}
.ts .hero .wrap{position:relative;z-index:2;padding-bottom:52px}
.ts .hero-body{max-width:620px;margin-left:min(26vw,330px);padding:clamp(40px,4vw + 20px,76px) 0 0}
.ts .hero h1{font-size:var(--fs-h1);font-weight:800;line-height:1.04;color:var(--navy)}
.ts .hero h1 .here{font-family:var(--ts-script);font-weight:700;color:var(--pink);font-size:var(--fs-script);position:relative;display:inline-block;padding:0 6px;line-height:1}
.ts .hero h1 .here::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:12px;background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='12' viewBox='0 0 160 12'><path d='M3 7 C45 2 120 2 157 7' stroke='%23ff3d8d' stroke-width='3.4' fill='none' stroke-linecap='round'/></svg>") no-repeat center/contain}
.ts .hero p.lead{color:var(--navy);font-size:var(--fs-l);font-weight:600;margin-top:10px;max-width:440px}
.ts .gcard{position:absolute;top:clamp(40px,4vw + 20px,72px);right:var(--s-5);background:#fff;border-radius:var(--r-l);box-shadow:var(--shadow-3);padding:14px 20px;text-align:center;width:146px;z-index:4}
.ts .gcard .g{width:38px;height:38px;margin:0 auto 6px}
.ts .gcard .grate{display:flex;align-items:center;justify-content:center;gap:8px;font-family:var(--ts-display);font-weight:700;color:var(--navy);font-size:18px}
.ts .gcard .stars{color:var(--ts-gold);font-size:14px;letter-spacing:1px}
.ts .gcard .glabel{font-size:var(--fs-xs);color:var(--ts-muted);margin-top:4px}

/* ============ Search bar ============ */
.ts .searchbar{background:#fff;border-radius:var(--r-l);box-shadow:var(--shadow-3);display:grid;grid-template-columns:1fr 1fr 1fr 1fr auto;align-items:stretch;position:relative;z-index:5;margin:42px 0 0;transition:box-shadow var(--t-med)}
.ts .searchbar:focus-within{box-shadow:var(--shadow-3),0 0 0 3px var(--pink-ring)}
.ts .sfield{display:flex;align-items:center;gap:12px;padding:16px 18px;border-right:1px solid var(--ts-line);position:relative;cursor:pointer;border-radius:var(--r-m);transition:background var(--t-fast)}
.ts .sfield:hover{background:#fafbfe}
.ts .sfield:last-of-type{border-right:none}
.ts .sicon{width:26px;height:26px;color:var(--pink);flex:none}
.ts .sfield .scol{display:flex;flex-direction:column;min-width:0}
.ts .slabel{font-family:var(--ts-display);font-weight:600;font-size:var(--fs-xs);color:var(--navy)}
.ts .sval{display:flex;align-items:center;gap:6px;font-size:var(--fs-s);color:#46527a;font-weight:600;margin-top:2px}
.ts .sval [data-val]{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:130px}
.ts .sval .ch{width:14px;height:14px;color:#9aa6c4;transition:transform var(--t-med);flex:none}
.ts .sfield.open .sval .ch{transform:rotate(180deg)}
.ts .sbtn{margin:10px;padding:0 26px;background:var(--pink);color:#fff;border-radius:var(--r-m);font-family:var(--ts-display);font-weight:600;font-size:16px;display:flex;align-items:center;gap:10px;justify-content:center;transition:background var(--t-fast),transform var(--t-fast);box-shadow:var(--shadow-pink)}
.ts .sbtn:hover{background:var(--pink-hover);transform:translateY(-1px)}
.ts .sbtn:active{background:var(--pink-active);transform:translateY(0) scale(.99)}
.ts .sbtn svg{width:19px;height:19px}
.ts .dropdown{position:absolute;top:calc(100% + 8px);left:8px;right:8px;background:#fff;border-radius:var(--r-m);box-shadow:var(--shadow-3);border:1px solid var(--ts-line);padding:6px;display:none;z-index:30;max-height:260px;overflow:auto}
.ts .sfield.open .dropdown{display:block;animation:ts-pop .18s var(--ease-spring)}
@keyframes ts-pop{from{opacity:0;transform:translateY(-6px) scale(.98)}to{opacity:1;transform:none}}
.ts .dopt{padding:10px 12px;border-radius:var(--r-s);font-size:var(--fs-s);color:#3c476e;font-weight:500;transition:background var(--t-fast);cursor:pointer}
.ts .dopt:hover{background:var(--pink-soft)}
.ts .dopt.sel{background:var(--pink-soft);color:var(--pink);font-weight:700}

/* ============ Trust badges ============ */
.ts .trust{padding:48px 0 0}
.ts .trust-card{background:#fff;border:1px solid #eef1f7;border-radius:var(--r-l);box-shadow:var(--shadow-2);display:grid;grid-template-columns:repeat(5,1fr)}
.ts .tcell{padding:30px 22px;text-align:center;border-right:1px solid var(--ts-line)}
.ts .tcell:last-child{border-right:none}
.ts .tcell .ico{width:46px;height:46px;margin:0 auto 14px;color:var(--pink)}
.ts .tcell h4{font-size:16px;font-weight:700;color:var(--navy);margin-bottom:8px;line-height:1.25}
.ts .tcell p{font-size:var(--fs-s);color:var(--ts-muted);line-height:1.5}
.ts .tcell.greview .g{width:46px;height:46px;margin:0 auto 12px}
.ts .tcell.greview .grate{display:flex;align-items:center;justify-content:center;gap:8px;font-family:var(--ts-display);font-weight:700;font-size:20px;color:var(--navy);margin-bottom:4px}
.ts .tcell.greview .stars{color:var(--ts-gold);font-size:15px;letter-spacing:1px}
.ts .tcell.greview .gtitle{font-size:15px;font-weight:700;color:var(--navy);margin-bottom:10px}

/* ============ Section heading ============ */
.ts .sec{padding:62px 0 0}
.ts .sec-head{display:flex;align-items:center;justify-content:center;position:relative;margin-bottom:34px}
.ts .sec-head h2{font-size:var(--fs-h2);font-weight:700;text-align:center}
.ts .viewall{position:absolute;right:0;color:var(--pink);font-family:var(--ts-display);font-weight:600;font-size:15px;display:flex;align-items:center;gap:8px;transition:gap var(--t-fast)}
.ts .viewall:hover{gap:12px}
.ts .viewall svg{width:17px;height:17px}

/* ============ Destinations v2 — immersive cards ============ */
.ts .dest-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.ts .dest{position:relative;height:300px;border-radius:var(--r-xl);overflow:hidden;cursor:pointer;box-shadow:var(--shadow-1);transition:transform var(--t-med),box-shadow var(--t-med);background:var(--navy);display:block}
.ts .dest:hover{transform:translateY(-6px);box-shadow:var(--shadow-3)}
.ts .dest .dest-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s var(--ease-out)}
.ts .dest:hover .dest-img{transform:scale(1.06)}
.ts .dest .grad{position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,24,52,0) 38%,rgba(10,24,52,.82) 100%);pointer-events:none;z-index:2}
.ts .dest .info{position:absolute;left:0;right:0;bottom:0;z-index:3;padding:20px 22px;display:flex;align-items:flex-end;justify-content:space-between;gap:12px}
.ts .dest .info h3{font-size:clamp(20px,1.2rem + .5vw,24px);font-weight:700;color:#fff;margin-bottom:3px}
.ts .dest .info .lang{font-size:var(--fs-s);color:#d4ddf0;font-weight:600}
.ts .dest .go{width:42px;height:42px;border-radius:50%;background:var(--pink);color:#fff;display:flex;align-items:center;justify-content:center;flex:none;opacity:0;transform:translateY(10px);transition:opacity var(--t-med),transform var(--t-med),background var(--t-fast)}
.ts .dest .go svg{width:18px;height:18px}
.ts .dest:hover .go{opacity:1;transform:none}

/* ============ How it works v2 ============ */
.ts .how{margin-top:70px;padding-block:66px 60px;background:linear-gradient(180deg,#fff 0%,#edf5fc 14%,#edf5fc 86%,#fff 100%)}
.ts .how .how-head{text-align:center;margin-bottom:44px;display:flex;flex-direction:column;align-items:center;gap:14px}
.ts .how h2{font-size:var(--fs-h2);font-weight:700}
.ts .how .how-sub{color:var(--ts-muted);font-size:var(--fs-m);max-width:520px}
.ts .steps{display:grid;grid-template-columns:1fr 1fr 1fr;gap:22px;max-width:1020px;margin:0 auto}
.ts .step{position:relative;text-align:left;background:#fff;border:1px solid #e8eef7;border-radius:var(--r-xl);padding:30px 26px 28px;box-shadow:var(--shadow-1);transition:transform var(--t-med),box-shadow var(--t-med)}
.ts .step:hover{transform:translateY(-6px);box-shadow:var(--shadow-3)}
.ts .step .badge{margin:0 0 18px;display:flex;align-items:center;justify-content:space-between}
.ts .step .num{color:color-mix(in oklch, var(--pink) 30%, white);font-family:var(--ts-display);font-weight:800;font-size:46px;line-height:1}
.ts .step .circ{width:62px;height:62px;border-radius:var(--r-l);background:var(--pink-soft);display:flex;align-items:center;justify-content:center;transition:transform var(--t-med)}
.ts .step:hover .circ{transform:scale(1.08) rotate(-4deg)}
.ts .step .circ svg{width:30px;height:30px;color:var(--pink)}
.ts .step h3{font-size:var(--fs-h3);font-weight:700;margin-bottom:8px}
.ts .step p{font-size:var(--fs-s);color:var(--ts-muted);line-height:1.55}
.ts .how-cta{display:flex;flex-direction:column;align-items:center;margin-top:42px}
.ts .how-assure{display:flex;gap:34px;margin-top:20px;flex-wrap:wrap;justify-content:center}
.ts .how-assure span{display:flex;align-items:center;gap:9px;font-size:var(--fs-s);color:var(--navy);font-weight:600}
.ts .how-assure span svg{width:18px;height:18px;color:var(--pink)}

/* ============ Stats band ============ */
.ts .stats{background:var(--navy-deep);color:#fff;position:relative;overflow:hidden}
.ts .stats::before{content:"";position:absolute;inset:0;background:radial-gradient(480px 220px at 12% 0%,rgba(255,6,111,.16),transparent 70%),radial-gradient(480px 220px at 88% 100%,rgba(26,115,232,.14),transparent 70%);pointer-events:none}
.ts .stats .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;padding-block:44px;position:relative}
.ts .stat{text-align:center}
.ts .stat .sv{font-family:var(--ts-display);font-weight:800;font-size:clamp(28px,1.8rem + 1.4vw,40px);color:#fff;line-height:1;font-variant-numeric:tabular-nums}
.ts .stat .sv em{font-style:normal;color:var(--pink-bright)}
.ts .stat .sl{font-size:var(--fs-s);color:#aebbdd;margin-top:8px;font-weight:600}

/* ============ Book With Confidence (pink reassurance band) ============ */
.ts .bwc{padding:62px 0 0}
.ts .bwc-band{background:var(--pink-soft);border:1px solid color-mix(in oklch, var(--pink) 16%, white);border-radius:var(--r-xl);padding:clamp(28px,3vw,40px) clamp(20px,3vw,40px)}
.ts .bwc h2{text-align:center;color:var(--pink);font-size:var(--fs-h2);font-weight:700;margin-bottom:30px}
.ts .bwc-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:24px 18px}
.ts .bwc-item{display:flex;align-items:flex-start;gap:13px}
.ts .bwc-item .bic{width:46px;height:46px;border-radius:50%;border:1.5px solid var(--pink);background:#fff;display:flex;align-items:center;justify-content:center;flex:none;box-shadow:var(--shadow-1)}
.ts .bwc-item .bic svg{width:22px;height:22px;color:var(--pink)}
.ts .bwc-item h3{font-size:15px;font-weight:700;color:var(--navy);margin-bottom:4px;line-height:1.2}
.ts .bwc-item p{font-size:var(--fs-s);color:var(--ts-muted);line-height:1.45}

/* ============ Partners / accreditations ============ */
.ts .partners{padding:58px 0 0}
.ts .partners .ph-head{display:flex;align-items:center;justify-content:center;gap:18px;margin-bottom:30px}
.ts .partners .ph-head .ln{height:1px;flex:1;max-width:120px;background:linear-gradient(90deg,transparent,#cfd6e6)}
.ts .partners h2{font-size:clamp(21px,1.3rem + .6vw,26px);font-weight:700;text-align:center}
.ts .plogos{display:flex;flex-wrap:wrap;gap:14px;justify-content:center}
.ts .plogo{border:1px solid #e9edf5;border-radius:var(--r-m);width:268px;min-height:68px;display:flex;align-items:center;gap:12px;padding:12px 16px;text-align:left;transition:box-shadow var(--t-med),border-color var(--t-med),transform var(--t-med);background:#fff}
.ts .plogo:hover{box-shadow:var(--shadow-2);border-color:#dde3f0;transform:translateY(-2px)}
.ts .plogo .pico{width:34px;height:34px;flex:none;border-radius:7px;object-fit:contain}
.ts .plg-name{font-family:var(--ts-display);font-weight:700;font-size:var(--fs-s);color:#2c3a63;line-height:1.15}
.ts .plg-sub{font-weight:600;font-size:10px;color:#8a93ad;letter-spacing:.4px;margin-top:3px;text-transform:uppercase}

/* ============ SEO + FAQ ============ */
.ts .seo{padding:66px 0 0}
.ts .seo-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:start}
.ts .seo-col h2{font-size:clamp(21px,1.3rem + .6vw,26px);font-weight:700;margin-bottom:16px}
.ts .seo-col h3{font-size:17px;font-weight:700;margin:22px 0 10px}
.ts .seo-col p{font-size:var(--fs-s);color:var(--ts-muted);line-height:1.75;margin-bottom:12px}
.ts .seo-col a{color:var(--pink);font-weight:600}
.ts .seo-col a:hover{text-decoration:underline}
.ts .faq-col h2{font-size:clamp(21px,1.3rem + .6vw,26px);font-weight:700;margin-bottom:10px}
.ts .faq{border-bottom:1px solid var(--ts-line)}
.ts .faq summary{list-style:none;display:flex;align-items:center;justify-content:space-between;gap:16px;cursor:pointer;padding:17px 2px;font-family:var(--ts-display);font-weight:600;font-size:15px;color:var(--navy);transition:color var(--t-fast)}
.ts .faq summary::-webkit-details-marker{display:none}
.ts .faq summary:hover{color:var(--pink)}
.ts .faq summary .fx{width:26px;height:26px;flex:none;border-radius:50%;background:var(--pink-soft);color:var(--pink);display:flex;align-items:center;justify-content:center;transition:transform var(--t-med),background var(--t-fast)}
.ts .faq summary .fx svg{width:13px;height:13px}
.ts .faq[open] summary{color:var(--pink)}
.ts .faq[open] summary .fx{transform:rotate(45deg);background:var(--pink);color:#fff}
.ts .faq .fa{padding:0 36px 18px 2px;font-size:var(--fs-s);color:var(--ts-muted);line-height:1.7}
.ts .seo-links{display:flex;flex-wrap:wrap;align-items:center;gap:8px 10px;margin-top:20px;padding-top:18px;border-top:1px solid var(--ts-line)}
.ts .seo-links .seo-links-label{font-family:var(--ts-display);font-weight:700;font-size:var(--fs-xs);color:var(--navy);margin-right:2px}
.ts .seo-links a{font-size:var(--fs-s);font-weight:600;color:var(--pink);padding:4px 11px;border:1px solid var(--ts-line);border-radius:var(--r-full);transition:background var(--t-fast),border-color var(--t-fast)}
.ts .seo-links a:hover{background:var(--pink-soft);border-color:transparent}

/* ============ Responsive — 1100 / 860 / 600 ============ */
@media(max-width:1100px){
  .ts .trust-card{grid-template-columns:repeat(3,1fr)}
  .ts .tcell{border-bottom:1px solid var(--ts-line)}
  .ts .bwc-grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:860px){
  .ts .hero-body{margin-left:0;padding-top:18px}
  .ts .gcard{position:static;width:auto;display:inline-flex;align-items:center;gap:14px;text-align:left;margin:30px 0 0;padding:10px 16px}
  .ts .gcard .g{margin:0}
  .ts .searchbar{grid-template-columns:1fr 1fr;margin-top:30px}
  .ts .sfield{border-bottom:1px solid var(--ts-line)}
  .ts .sfield:nth-child(even){border-right:none}
  .ts .sbtn{grid-column:1/-1}
  .ts .dest-grid{grid-template-columns:1fr 1fr}
  .ts .steps{grid-template-columns:1fr;gap:18px}
  .ts .seo-grid{grid-template-columns:1fr;gap:36px}
  .ts .stats .wrap{grid-template-columns:1fr 1fr;gap:28px;padding-block:34px}
  .ts .bwc-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:600px){
  .ts .hero h1{line-height:1.06}
  .ts .hero p.lead{margin-top:14px}
  .ts .hero-body{padding-top:14px}
  .ts .searchbar{grid-template-columns:1fr}
  .ts .sfield{border-right:none}
  .ts .trust{padding-top:40px}
  .ts .trust-card{grid-template-columns:1fr 1fr}
  .ts .tcell{padding:20px 14px}
  .ts .tcell:last-child{grid-column:1/-1;border-bottom:none}
  .ts .tcell h4{font-size:14px}
  .ts .tcell p{font-size:12.5px}
  .ts .dest-grid{display:flex;gap:14px;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:14px;margin-inline:-16px;padding-inline:16px;scrollbar-width:none}
  .ts .dest-grid::-webkit-scrollbar{display:none}
  .ts .dest{flex:0 0 250px;scroll-snap-align:start;height:280px}
  .ts .sec-head{flex-direction:column;gap:10px}
  .ts .viewall{position:static}
  .ts .bwc-grid{grid-template-columns:1fr}
  .ts .bwc-band{padding:24px 18px}
  .ts .plogo{width:100%}
  .ts .seo{padding-top:54px}
}

/* ============ RTL (Arabic) ============ */
html[dir='rtl'] .ts .hero-body{margin-left:0;margin-right:min(26vw,330px)}
html[dir='rtl'] .ts .gcard{right:auto;left:var(--s-5)}
html[dir='rtl'] .ts .hero h1 .here::after{transform:scaleX(-1)}
html[dir='rtl'] .ts .hero-scrim{background:
  linear-gradient(266deg,rgba(255,255,255,0) 20%,rgba(255,255,255,.5) 42%,rgba(255,255,255,.55) 76%,rgba(255,255,255,.25) 100%),
  linear-gradient(180deg,rgba(255,255,255,.3) 0%,transparent 30%)}
html[dir='rtl'] .ts .viewall{right:auto;left:0}
html[dir='rtl'] .ts .step{text-align:right}
@media(max-width:860px){html[dir='rtl'] .ts .hero-body{margin-right:0}html[dir='rtl'] .ts .gcard{left:auto}}
