/* ============================================================
   BG Planner — section components
   ============================================================ */

/* ---------- AWARD GALLERY (รูปงาน/รางวัล — careers) ---------- */
.careward{display:grid;gap:clamp(14px,1.8vw,22px);max-width:960px;margin:0 auto}
.careward a{border-radius:18px;overflow:hidden;box-shadow:0 10px 34px rgba(35,33,31,.14);display:block}
.careward img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .45s ease}
.careward a:hover img{transform:scale(1.045)}
.careward-wide img{aspect-ratio:3/2}
.careward-row{display:grid;grid-template-columns:1fr 1fr;gap:clamp(14px,1.8vw,22px)}
.careward-row img{aspect-ratio:3/4}
@media(max-width:560px){.careward-row{grid-template-columns:1fr}}

/* ---------- VIDEO CLIPS (วิทยากร — careers) ---------- */
.vclip-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:clamp(14px,1.6vw,22px)}
.vclip{flex:0 1 300px;max-width:320px;position:relative;aspect-ratio:9/16;border-radius:20px;overflow:hidden;
   background:#1a1413 center/cover no-repeat;box-shadow:0 10px 36px rgba(35,33,31,.16);cursor:pointer}
.vclip video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;background:#000}
.vclip::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.05),rgba(0,0,0,.35));transition:opacity .25s;pointer-events:none}
.vclip.playing::after{opacity:0}
.vclip-play{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:58px;height:58px;border:none;border-radius:50%;
   background:rgba(255,255,255,.92);color:var(--ruby);display:grid;place-items:center;cursor:pointer;transition:transform .2s,background .2s;z-index:2}
.vclip:hover .vclip-play{transform:translate(-50%,-50%) scale(1.08);background:#fff}
.vclip-play svg{width:26px;height:26px;margin-left:3px}
.vclip.playing .vclip-play{display:none}
@media(max-width:560px){.vclip{flex:1 1 46%;max-width:48%}.vclip-play{width:50px;height:50px}}

/* ---------- RECRUIT BAND (ร่วมทีมกับเรา → careers) ---------- */
.recruit-band{position:relative;overflow:hidden;background:linear-gradient(135deg,var(--forest) 0%,#24604a 100%)}
.recruit-band::after{content:"";position:absolute;width:440px;height:440px;right:-110px;top:-170px;border-radius:50%;
   background:radial-gradient(closest-side,rgba(208,232,220,.20),transparent 70%);pointer-events:none}
.recruit-inner{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:clamp(28px,4vw,48px);padding:clamp(40px,5vw,62px) 0;flex-wrap:wrap}
.recruit-copy{flex:1;min-width:280px}
.recruit-copy .eyebrow{color:var(--mint)}
.recruit-copy h2{color:#fff;font-size:clamp(1.5rem,2.8vw,2.1rem);margin:8px 0 12px;line-height:1.25}
.recruit-copy p{color:rgba(255,255,255,.88);line-height:1.7;max-width:640px;margin:0;font-size:.98rem}
.recruit-btn{flex:none}
@media(max-width:640px){.recruit-inner{flex-direction:column;align-items:flex-start}.recruit-btn{width:100%;justify-content:center}}

/* ---------- HERO ---------- */
.hero{position:relative;overflow:hidden;background:
   radial-gradient(rgba(255,255,255,.06) 1.2px, transparent 1.2px) 0 0/24px 24px,
   radial-gradient(42% 55% at 8% 14%, rgba(208,232,220,.22), transparent 60%),
   radial-gradient(48% 60% at 99% 6%, rgba(255,201,158,.20), transparent 60%),
   radial-gradient(60% 70% at 50% 120%, rgba(255,120,140,.18), transparent 60%),
   linear-gradient(145deg,var(--ruby) 0%, var(--ruby-700) 58%, var(--ruby-900) 100%)}
.hero::before{content:"";position:absolute;inset:0;pointer-events:none;z-index:0;background:
   radial-gradient(58% 80% at 86% -8%, rgba(255,255,255,.22), transparent 58%),
   linear-gradient(180deg, transparent 48%, rgba(110,20,32,.32) 100%)}
/* Aurora overlay — วงแสงสี 3 ดวงลอย+ขยายช้าๆ (animated) */
.hero-aurora{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.hero-aurora .ho{position:absolute;border-radius:50%;filter:blur(64px);mix-blend-mode:screen;will-change:transform,opacity}
.hero-aurora .ho1{width:560px;height:560px;right:-120px;top:-190px;
   background:radial-gradient(closest-side,rgba(208,232,220,.46),transparent 70%);animation:hoDrift1 17s ease-in-out infinite alternate}
.hero-aurora .ho2{width:480px;height:480px;left:-150px;bottom:-210px;
   background:radial-gradient(closest-side,rgba(255,201,158,.36),transparent 70%);animation:hoDrift2 23s ease-in-out infinite alternate}
.hero-aurora .ho3{width:400px;height:400px;left:40%;top:20%;
   background:radial-gradient(closest-side,rgba(255,120,140,.32),transparent 70%);animation:hoDrift3 14s ease-in-out infinite alternate}
@keyframes hoDrift1{0%{transform:translate(0,0) scale(1);opacity:.85}100%{transform:translate(-90px,80px) scale(1.22);opacity:1}}
@keyframes hoDrift2{0%{transform:translate(0,0) scale(1);opacity:.8}100%{transform:translate(90px,-50px) scale(1.18);opacity:1}}
@keyframes hoDrift3{0%{transform:translate(0,0) scale(.92);opacity:.65}100%{transform:translate(50px,40px) scale(1.3);opacity:.95}}
@media (prefers-reduced-motion:reduce){.hero-aurora .ho{animation:none}}

/* ---------- HERO full-screen variant (home2: รูปเต็มจอ + overlay ดำ + center) ---------- */
.hero-full{position:relative;min-height:clamp(440px,68vh,620px);display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden}
.hero-full-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
/* Ken Burns slideshow background */
.hero-kb{position:absolute;inset:0;z-index:0;overflow:hidden}
.hero-kb-slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;will-change:opacity,transform;animation:kenburns 21s infinite}
.hero-kb-slide:nth-child(1){animation-delay:0s}
.hero-kb-slide:nth-child(2){animation-delay:7s}
.hero-kb-slide:nth-child(3){animation-delay:14s}
@keyframes kenburns{
  0%{opacity:0;transform:scale(1) translate(0,0)}
  4%{opacity:1}
  30%{opacity:1}
  36%{opacity:0;transform:scale(1.13) translate(-1.6%,-1.2%)}
  100%{opacity:0;transform:scale(1.13) translate(-1.6%,-1.2%)}
}
@media (prefers-reduced-motion:reduce){.hero-kb-slide{animation:none}.hero-kb-slide:nth-child(1){opacity:1}}
.hero-full::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.5),rgba(0,0,0,.64));z-index:1}
.hero-full-inner{position:relative;z-index:2;max-width:800px;padding:80px 24px;color:#fff}
.hero-full-eyebrow{display:inline-block;font-family:var(--font-head);font-weight:600;font-size:.9rem;letter-spacing:.06em;color:var(--mint);margin-bottom:18px}
.hero-full-inner h1{color:#fff;font-size:clamp(2.2rem,5.2vw,4rem);margin-bottom:20px;text-shadow:0 2px 24px rgba(0,0,0,.3)}
.hero-full-inner h1 .hl{color:var(--mint)}
.hero-full-inner p{color:rgba(255,255,255,.92);font-size:clamp(1rem,1.6vw,1.18rem);max-width:640px;margin:0 auto 34px;text-shadow:0 1px 16px rgba(0,0,0,.25)}
.hero-full-actions{justify-content:center;margin-bottom:0}
.hero-full .btn-outline{border:1.6px solid rgba(255,255,255,.55);color:#fff;background:transparent}
.hero-full .btn-outline:hover{background:rgba(255,255,255,.12);border-color:#fff;color:#fff}
@media(max-width:640px){.hero-full{min-height:clamp(360px,56vh,480px)}.hero-full-inner{padding:54px 20px}}
.hero .wrap{position:relative;z-index:1}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:50px;align-items:center;padding:clamp(76px,9vw,128px) 0 clamp(120px,13vw,184px)}
.hero-badge{display:inline-flex;align-items:center;gap:9px;background:rgba(255,255,255,.16);padding:8px 16px 8px 8px;border-radius:999px;font-size:.86rem;font-weight:600;font-family:var(--font-head);color:#fff;margin-bottom:26px}
.hero-badge b{background:#fff;color:var(--ruby);padding:4px 11px;border-radius:999px;font-size:.78rem;white-space:nowrap}
.hero h1{margin-bottom:18px;color:#fff;font-size:clamp(2.05rem,4.3vw,3.35rem)}
.hero h1 .hl{color:var(--mint);position:relative;white-space:nowrap}
.hero-lead{font-size:1.1rem;color:rgba(255,255,255,.88);max-width:520px;margin-bottom:28px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:30px}
.hero-trust{display:flex;gap:30px;flex-wrap:wrap}
.hero-trust .ht{display:flex;flex-direction:column;gap:2px}
.hero-trust .ht b{font-family:var(--font-head);font-size:1.7rem;color:#fff;font-weight:700;line-height:1}
.hero-trust .ht span{font-size:.84rem;color:rgba(255,255,255,.72)}

.hero-visual{position:relative}
.hero-img{width:100%;aspect-ratio:4/3.6;border-radius:var(--r-xl);box-shadow:var(--shadow-lg)}
/* rotating consult badge (Covar-style signature) */
.spin-badge{position:absolute;left:-32px;bottom:-30px;width:122px;height:122px;border-radius:50%;background:#fff;box-shadow:0 16px 38px rgba(94,8,8,.26);display:flex;align-items:center;justify-content:center;z-index:3}
.spin-badge .spin-badge-text{position:absolute;inset:0;width:100%;height:100%;animation:spin 16s linear infinite}
.spin-badge .spin-badge-text text{font-family:var(--font-head);font-size:10.5px;font-weight:600;letter-spacing:.02em;fill:var(--ruby)}
.spin-badge .spin-badge-ic{width:42px;height:42px;border-radius:50%;background:var(--ruby);color:#fff;display:flex;align-items:center;justify-content:center}
.spin-badge .spin-badge-ic svg{width:20px;height:20px}
@keyframes spin{to{transform:rotate(360deg)}}
@media (prefers-reduced-motion:reduce){.spin-badge .spin-badge-text{animation:none}}
@media(max-width:600px){.spin-badge{left:auto;right:-6px;bottom:-14px;width:94px;height:94px}}
.hero-float{position:absolute;background:#fff;border-radius:var(--r-md);box-shadow:var(--shadow-md);padding:16px 18px;display:flex;align-items:center;gap:13px}
.hero-float .hf-ic{width:46px;height:46px;border-radius:13px;display:flex;align-items:center;justify-content:center;flex:none}
.hero-float .hf-ic svg{width:24px;height:24px}
.hero-float b{display:block;font-family:var(--font-head);font-size:1.02rem;color:var(--ink);line-height:1.2}
.hero-float span{font-size:.8rem;color:var(--stone)}
.hf-1{top:24px;left:-26px;animation:floaty 5s ease-in-out infinite}
.hf-2{bottom:34px;right:-22px;animation:floaty 6s ease-in-out infinite .8s}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
@media (prefers-reduced-motion:reduce){.hf-1,.hf-2{animation:none}}

/* logo strip */
.logos-strip{background:var(--fog)}
.logos-strip .wrap{display:flex;align-items:center;gap:32px;padding:clamp(36px,5vw,56px) 28px}
.logos-strip .ls-label{font-size:.82rem;color:var(--stone);font-weight:600;font-family:var(--font-head);letter-spacing:.04em;white-space:nowrap;flex:none}
.logos-strip .ls-marquee{flex:1;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
.logos-strip .ls-track{display:flex;gap:54px;width:max-content;animation:logoscroll 24s linear infinite}
.logos-strip .ls-marquee:hover .ls-track{animation-play-state:paused}
.logos-strip .ls-track .lp{display:inline-flex;align-items:center;font-family:var(--font-brand);font-weight:700;font-size:1.15rem;color:var(--stone);opacity:.78;white-space:nowrap}
.logos-strip .ls-track .lp img{height:26px;width:auto;max-width:160px;object-fit:contain;filter:none;opacity:1;transition:.3s var(--ease)}
.logos-strip .ls-track .lp .lp-t{display:none}
.logos-strip .ls-track .lp.noimg img{display:none}
.logos-strip .ls-track .lp.noimg .lp-t{display:inline}
.logos-strip .ls-marquee:hover .lp img{filter:none;opacity:1}
@keyframes logoscroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.logos-strip .ls-track{animation:none}}
@media(max-width:600px){.logos-strip .wrap{flex-direction:column;gap:14px;align-items:stretch}.logos-strip .ls-label{text-align:center}}
/* คุณวุฒิ section — ซ้าย: หัวข้อใหญ่+ดำ + สไลด์โลโก้ · ขวา: รูปรางวัล */
.logos-strip .qa-wrap{display:grid;grid-template-columns:1.45fr .85fr;gap:clamp(28px,4vw,56px);align-items:center;padding:clamp(40px,5vw,64px) 28px}
.logos-strip .qa-left{min-width:0}
.logos-strip .qa-title{font-family:var(--font-head);font-weight:800;color:var(--ink);font-size:clamp(1.5rem,2.9vw,2.15rem);line-height:1.25;letter-spacing:0;margin:0 0 14px;white-space:normal;text-wrap:balance}
.logos-strip .qa-sub{color:var(--ink-soft);font-size:1rem;line-height:1.7;margin:0 0 26px;max-width:520px}
.logos-strip .qa-logos{display:flex;flex-wrap:wrap;gap:14px}
.logos-strip .qa-logos .lp{flex:0 0 auto;display:flex;align-items:center;justify-content:center;background:#fff;border:1px solid #efe9e6;border-radius:14px;padding:0 22px;height:60px;min-width:118px;box-shadow:0 4px 14px rgba(35,33,31,.05);transition:transform .2s ease,box-shadow .2s ease}
.logos-strip .qa-logos .lp:hover{transform:translateY(-2px);box-shadow:0 8px 22px rgba(35,33,31,.1)}
.logos-strip .qa-logos .lp img{height:30px;max-width:130px;width:auto;object-fit:contain;display:block}
.logos-strip .qa-logos .lp .lp-t{display:none;font-family:var(--font-brand);font-weight:700;color:var(--stone)}
.logos-strip .qa-logos .lp.noimg img{display:none}
.logos-strip .qa-logos .lp.noimg .lp-t{display:inline}
.logos-strip .qa-right img{width:100%;max-width:340px;border-radius:18px;box-shadow:0 16px 44px rgba(35,33,31,.16);display:block;margin-left:auto}
@media(max-width:820px){.logos-strip .qa-wrap{grid-template-columns:1fr;text-align:center}.logos-strip .qa-right img{margin:4px auto 0;max-width:320px}.logos-strip .qa-sub{margin-left:auto;margin-right:auto}.logos-strip .qa-logos{justify-content:center}}
@media(max-width:480px){.logos-strip .qa-logos .lp{flex:1 1 42%;min-width:0;padding:0 12px;height:56px}}

/* ---------- PLAN CARDS ---------- */
.plan-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.plan-card{display:flex;flex-direction:column;overflow:hidden;padding:0}
.plan-card .pc-media{position:relative;height:170px}
.plan-card .pc-media .ph{height:100%}
.plan-card .pc-badge{position:absolute;top:14px;left:14px;z-index:2}
.plan-card .pc-fav{position:absolute;top:14px;right:14px;width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.92);display:flex;align-items:center;justify-content:center;color:var(--stone);z-index:2;transition:.2s}
.plan-card .pc-fav:hover{color:var(--ruby);transform:scale(1.1)}
.plan-card .pc-fav svg{width:19px;height:19px}
.plan-card .pc-fav.on{color:var(--ruby)}
.plan-card .pc-body{padding:22px 22px 24px;display:flex;flex-direction:column;flex:1}
.plan-card .pc-cat{font-size:.8rem;font-weight:600;color:var(--forest);font-family:var(--font-head);letter-spacing:.03em;margin-bottom:8px}
.plan-card h3{font-size:1.22rem;margin-bottom:10px}
.plan-card h3 a{color:inherit;transition:.2s var(--ease)}
.plan-card h3 a:hover{color:var(--ruby)}
.pc-media a{display:block;width:100%;height:100%}
.plan-card .pc-desc{font-size:.96rem;color:var(--ink-soft);margin-bottom:18px;flex:1}
.plan-card .pc-feats{display:flex;flex-direction:column;gap:9px;margin-bottom:20px}
.plan-card .pc-feats li{display:flex;gap:9px;align-items:flex-start;font-size:.92rem;color:var(--ink-soft);list-style:none}
.plan-card .pc-feats svg{width:17px;height:17px;color:var(--forest);flex:none;margin-top:3px}
.plan-card .pc-foot{display:flex;align-items:flex-end;justify-content:space-between;padding-top:18px}
.plan-card .pc-price small{display:block;font-size:.76rem;color:var(--stone)}
.plan-card .pc-price b{font-family:var(--font-head);font-size:1.35rem;color:var(--ruby);font-weight:700}
.plan-card .pc-price b span{font-size:.86rem;color:var(--ink-soft);font-weight:500}
.plan-card .pc-link{display:inline-flex;align-items:center;gap:5px;font-family:var(--font-head);font-weight:600;color:#fff;background:var(--forest);font-size:.8rem;padding:6px 13px;border-radius:30px;transition:.25s var(--ease)}
.plan-card .pc-link:hover{background:#255a41;gap:8px}
.plan-card .pc-link svg{width:13px;height:13px}

.toolbar{display:flex;gap:14px;align-items:center;flex-wrap:wrap;margin-bottom:30px}
.searchbox{position:relative;flex:1;min-width:240px}
.searchbox svg{position:absolute;left:15px;top:50%;transform:translateY(-50%);width:17px;height:17px;color:var(--stone)}
.searchbox input{width:100%;padding:8px 18px 8px 40px;border:none;border-radius:999px;font-family:var(--font-body);font-size:.92rem;background:#fff;box-shadow:0 1px 2px rgba(35,33,31,.05), 0 3px 10px rgba(35,33,31,.05);transition:.2s}
.searchbox input:focus{outline:none;box-shadow:0 0 0 4px rgba(178,34,52,.12)}
.filter-chips{display:flex;gap:10px;flex-wrap:wrap}
.empty-state{display:none;text-align:center;padding:60px 20px;color:var(--stone)}
.empty-state svg{width:48px;height:48px;margin:0 auto 14px;opacity:.5}

/* ---------- WHY US ---------- */
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.why-card{padding:30px 26px;text-align:left}
.why-card .wi{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:20px}
.why-card .wi svg{width:28px;height:28px}
.why-card h3{font-size:1.18rem;margin-bottom:10px}
.why-card p{font-size:.96rem;color:var(--ink-soft)}

/* ---------- STEPS ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;counter-reset:s}
.step{position:relative;padding:34px 26px;border-radius:var(--r-lg);background:#fff;box-shadow:0 1px 3px rgba(35,33,31,.04), 0 10px 30px rgba(35,33,31,.07)}
.step::before{counter-increment:s;content:"0" counter(s);font-family:var(--font-brand);font-weight:800;font-size:2.6rem;color:var(--blush);line-height:1;display:block;margin-bottom:16px}
.step h3{font-size:1.12rem;margin-bottom:9px}
.step p{font-size:.93rem;color:var(--ink-soft)}
.steps.on-ruby .step{background:rgba(255,255,255,.06);box-shadow:none}
.steps.on-ruby .step::before{color:rgba(255,255,255,.28)}
.steps.on-ruby .step h3{color:#fff}
.steps.on-ruby .step p{color:rgba(255,255,255,.78)}

/* ---------- CATEGORY TABS ---------- */
.tabbar{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-bottom:40px}
.tabbar .chip{font-size:.98rem;padding:11px 22px}
.tab-pane{display:grid;grid-template-columns:1fr 1fr;gap:46px;align-items:center}
.tab-pane.in{animation:fadeUp .5s var(--ease)}
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.tab-media{border-radius:var(--r-lg);overflow:hidden;height:380px;box-shadow:var(--shadow-md)}
.tab-media .ph{height:100%}
.tab-info .eyebrow{margin-bottom:16px}
.tab-info h3{font-size:1.8rem;margin-bottom:14px}
.tab-info p{color:var(--ink-soft);margin-bottom:22px}
.tab-info ul{list-style:none;display:flex;flex-direction:column;gap:13px;margin-bottom:28px}
.tab-info ul li{display:flex;gap:12px;align-items:flex-start}
.tab-info ul li .ti{width:30px;height:30px;border-radius:9px;background:var(--mint);color:var(--forest);display:flex;align-items:center;justify-content:center;flex:none}
.tab-info ul li svg{width:17px;height:17px}
.tab-info ul li b{font-family:var(--font-head);display:block;font-size:1rem;color:var(--ink)}
.tab-info ul li span{font-size:.92rem;color:var(--ink-soft)}

/* ---------- STATS BAND ---------- */
.stats-band{background:var(--ruby);color:#fff;border-radius:var(--r-xl);padding:clamp(40px,5vw,60px);display:grid;grid-template-columns:repeat(4,1fr);gap:30px;text-align:center;position:relative;overflow:hidden}
.stats-band::before{content:"";position:absolute;inset:0;background:radial-gradient(50% 120% at 100% 0,rgba(255,255,255,.12),transparent 60%)}
.stat{position:relative}
.stat b{font-family:var(--font-brand);font-weight:800;font-size:clamp(2.4rem,4vw,3.4rem);line-height:1;display:block}
.stat span{font-size:.98rem;color:rgba(255,255,255,.82);margin-top:8px;display:block}

/* ---------- REVIEWS ---------- */
.review-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.review{padding:30px 28px;display:flex;flex-direction:column;gap:18px}
.review .stars{display:flex;gap:3px;color:#E8B53A}
.review .stars svg{width:18px;height:18px}
.review p{font-size:1rem;color:var(--ink);flex:1}
.review .rv-who{display:flex;align-items:center;gap:13px;padding-top:16px}
.review .av{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-weight:700;color:#fff;font-size:1.05rem;flex:none}
.review .av svg{width:24px;height:24px}
.review .rv-who b{font-family:var(--font-head);display:block;font-size:1rem}
.review .rv-who span{font-size:.85rem;color:var(--stone)}

/* ---------- ARTICLES ---------- */
.article-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.article{overflow:hidden;padding:0;display:flex;flex-direction:column}
.article .ar-media{height:200px;position:relative}
.article .ar-media .ph{height:100%}
.article .ar-cat{position:absolute;top:14px;left:14px}
.article .ar-body{padding:22px 24px 26px;display:flex;flex-direction:column;flex:1}
.article .ar-meta{font-size:.82rem;color:var(--stone);margin-bottom:10px;display:flex;gap:10px;align-items:center}
.article h3{font-size:1.18rem;margin-bottom:10px;line-height:1.3}
.article p{font-size:.94rem;color:var(--ink-soft);flex:1;margin-bottom:16px}
.article .ar-link{font-family:var(--font-head);font-weight:600;color:var(--ruby);font-size:.94rem;display:inline-flex;gap:6px;align-items:center}
.article:hover .ar-link{gap:10px}
.article .ar-link svg{width:16px;height:16px}

/* ---------- CAREER CTA ---------- */
.career{background:var(--charcoal);color:#fff;border-radius:var(--r-xl);overflow:hidden;display:grid;grid-template-columns:1.1fr .9fr}
.career-text{padding:clamp(40px,5vw,64px)}
.career-text .eyebrow{color:var(--mint)}
.career-text .eyebrow::before{background:var(--mint)}
.career-text h2{color:#fff;margin:16px 0 16px}
.career-text p{color:rgba(255,255,255,.78);margin-bottom:18px}
.career-perks{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:30px}
.career-perks li{display:flex;gap:10px;align-items:center;font-size:.96rem;color:rgba(255,255,255,.9)}
.career-perks svg{width:18px;height:18px;color:var(--mint);flex:none}
.career-media{position:relative;min-height:340px}
.career-media .ph{height:100%;background:linear-gradient(135deg,var(--ruby-700),var(--ruby))}

/* ---------- CONTACT / CONSULT ---------- */
.consult{display:grid;grid-template-columns:1fr 1.05fr;gap:50px;align-items:start}
.consult-info .eyebrow{margin-bottom:16px}
.consult-info h2{margin-bottom:18px}
.consult-info>p{color:var(--ink-soft);margin-bottom:30px;font-size:1.06rem}
.consult-list{display:flex;flex-direction:column;gap:18px}
.consult-list .ci{display:flex;gap:16px;align-items:flex-start}
.consult-list .ci-ic{width:50px;height:50px;border-radius:14px;background:var(--blush);color:var(--ruby);display:flex;align-items:center;justify-content:center;flex:none}
.consult-list .ci-ic svg{width:23px;height:23px}
.consult-list .ci b{font-family:var(--font-head);display:block;font-size:1.05rem;color:var(--ink)}
.consult-list .ci span,.consult-list .ci a{font-size:.96rem;color:var(--ink-soft)}
.consult-list .ci a:hover{color:var(--ruby)}

.form-card{background:#fff;border-radius:var(--r-lg);box-shadow:var(--shadow-md);padding:clamp(28px,4vw,40px)}
.form-card h3{font-size:1.4rem;margin-bottom:6px}
.form-card .fc-sub{color:var(--ink-soft);font-size:.96rem;margin-bottom:24px}
.field{margin-bottom:18px}
.field label{display:block;font-family:var(--font-head);font-weight:500;font-size:.92rem;margin-bottom:7px;color:var(--ink)}
.field label .req{color:var(--ruby)}
.field input,.field select,.field textarea{width:100%;padding:13px 16px;border:none;border-radius:12px;font-family:var(--font-body);font-size:1rem;background:var(--fog);transition:.2s;color:var(--ink)}
.field input:focus,.field select,.field textarea:focus{outline:none;background:#fff;box-shadow:0 0 0 4px rgba(178,34,52,.1)}
.field textarea{resize:vertical;min-height:96px}
.field input.err,.field textarea.err,.field select.err{border-color:var(--ruby);background:#fdf0f1}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-ok{display:none;background:var(--mint);color:var(--forest);border-radius:12px;padding:14px 16px;font-weight:600;font-family:var(--font-head);font-size:.96rem;margin-bottom:18px;align-items:center;gap:10px}
.form-ok.show{display:flex;animation:fadeUp .4s var(--ease)}
.form-ok svg{width:20px;height:20px;flex:none}

/* ---------- CTA BAND ---------- */
.cta-band{position:relative;overflow:hidden;background:linear-gradient(120deg,var(--ruby),var(--ruby-700));color:#fff;border-radius:var(--r-xl);padding:clamp(40px,5.5vw,68px);display:flex;align-items:center;justify-content:space-between;gap:40px;flex-wrap:wrap;box-shadow:var(--shadow-lg)}
.cta-band::before{content:"";position:absolute;inset:0;background:radial-gradient(45% 130% at 100% 0,rgba(255,255,255,.16),transparent 60%);pointer-events:none}
.cta-band::after{content:"";position:absolute;right:-60px;bottom:-90px;width:280px;height:280px;border-radius:50%;background:rgba(255,255,255,.05);pointer-events:none}
.cta-text{position:relative;max-width:560px;flex:1 1 380px}
.cta-text .eyebrow{color:var(--mint);margin-bottom:14px}
.cta-text .eyebrow::before{background:var(--mint)}
.cta-text h2{color:#fff;margin-bottom:14px}
.cta-text p{color:rgba(255,255,255,.86);font-size:1.08rem}
.cta-actions{position:relative;display:flex;flex-direction:column;gap:12px;min-width:260px}
.cta-actions .btn{width:100%}
@media(max-width:780px){.cta-band{flex-direction:column;align-items:stretch}.cta-actions{min-width:0}}

/* ---------- PAGE HERO (subpages) ---------- */
.page-hero{color:#fff;position:relative;overflow:hidden;background:
   radial-gradient(rgba(255,255,255,.06) 1.2px, transparent 1.2px) 0 0/24px 24px,
   radial-gradient(44% 62% at 94% 6%, rgba(208,232,220,.18), transparent 60%),
   linear-gradient(145deg,var(--ruby) 0%, var(--ruby-700) 60%, var(--ruby-900) 100%)}
.page-hero::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;background:
   radial-gradient(55% 85% at 88% -12%, rgba(255,255,255,.18), transparent 55%),
   linear-gradient(180deg, transparent 55%, rgba(110,20,32,.30))}
.page-hero::after{content:"";position:absolute;width:560px;height:560px;right:-160px;top:-190px;border-radius:50%;z-index:0;pointer-events:none;
   background:radial-gradient(closest-side, rgba(208,232,220,.20), transparent 70%);animation:heroDrift 16s ease-in-out infinite alternate}
.page-hero .wrap{position:relative;z-index:2;padding:clamp(44px,5vw,62px) 28px}
.page-hero .crumb{font-size:.9rem;color:rgba(255,255,255,.7);margin-bottom:16px;font-family:var(--font-head)}
.page-hero .crumb a:hover{color:#fff}
.page-hero h1{color:#fff;max-width:760px;font-size:clamp(1.9rem,3.6vw,2.8rem);line-height:1.18}
.page-hero p{color:rgba(255,255,255,.85);max-width:600px;margin-top:18px;font-size:1.12rem}
.page-hero .bar{background:#fff;margin-top:24px}

/* ---------- FAQ ---------- */
.faq-list{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:14px}
.faq{background:#fff;border-radius:var(--r-md);overflow:hidden;transition:.25s;box-shadow:0 1px 3px rgba(35,33,31,.04), 0 8px 22px rgba(35,33,31,.06)}
.faq.open{box-shadow:var(--shadow-md)}
.faq-head{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:22px 26px;cursor:pointer;font-family:var(--font-head);font-weight:600;font-size:1.08rem}
.faq-head .fq-ic{width:30px;height:30px;border-radius:50%;background:var(--fog);display:flex;align-items:center;justify-content:center;flex:none;transition:.3s;color:var(--ruby)}
.faq.open .fq-ic{background:var(--ruby);color:#fff;transform:rotate(45deg)}
.faq-head .fq-ic svg{width:18px;height:18px}
.faq-body{max-height:0;overflow:hidden;transition:max-height .35s var(--ease)}
.faq-body p{padding:0 26px 24px;color:var(--ink-soft)}

@media(max-width:980px){
  .hero-grid,.consult,.career,.tab-pane{grid-template-columns:1fr;gap:40px}
  .plan-grid,.review-grid,.article-grid,.why-grid,.steps,.stats-band{grid-template-columns:1fr 1fr}
  .career-media{min-height:240px}
  .hf-1{left:0}.hf-2{right:0}
}
@media(max-width:600px){
  .plan-grid,.review-grid,.article-grid,.why-grid,.steps,.stats-band,.field-row,.career-perks{grid-template-columns:1fr}
  .hero-trust{gap:20px}
  .hf-1,.hf-2{display:none}
}

/* ---------- PRICING (Covar-style 3-tier, highlighted middle) ---------- */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:54px;align-items:stretch}
.price-card{background:#fff;border-radius:var(--r-lg);box-shadow:0 1px 2px rgba(35,33,31,.04), 0 8px 26px rgba(35,33,31,.07);padding:36px 30px;display:flex;flex-direction:column;text-align:center;position:relative;transition:.3s var(--ease)}
.price-card:hover{transform:translateY(-6px);box-shadow:0 16px 44px rgba(35,33,31,.12)}
.price-card.featured{background:linear-gradient(150deg,var(--ruby),var(--ruby-700));color:#fff;transform:scale(1.045);box-shadow:0 22px 54px rgba(110,20,32,.30)}
.price-card.featured:hover{transform:scale(1.045) translateY(-6px)}
.pt-badge{position:absolute;top:18px;right:18px;background:#fff;color:var(--ruby);font-family:var(--font-head);font-weight:700;font-size:.72rem;letter-spacing:.04em;padding:5px 13px;border-radius:999px}
.pt-name{font-family:var(--font-head);font-weight:600;font-size:1.12rem;color:var(--forest);margin-bottom:14px}
.price-card.featured .pt-name{color:var(--mint)}
.pt-price b{font-family:var(--font-head);font-size:2.7rem;font-weight:700;color:var(--ink);line-height:1}
.price-card.featured .pt-price b{color:#fff}
.pt-price span{font-size:.9rem;color:var(--stone);margin-left:4px}
.price-card.featured .pt-price span{color:rgba(255,255,255,.8)}
.pt-desc{font-size:.95rem;color:var(--ink-soft);margin:14px 0 24px}
.price-card.featured .pt-desc{color:rgba(255,255,255,.85)}
.pt-feats{list-style:none;display:flex;flex-direction:column;gap:12px;margin-bottom:28px;text-align:left;flex:1}
.pt-feats li{display:flex;gap:10px;align-items:flex-start;font-size:.95rem;color:var(--ink-soft)}
.pt-feats svg{width:18px;height:18px;color:var(--forest);flex:none;margin-top:2px}
.price-card.featured .pt-feats li{color:rgba(255,255,255,.92)}
.price-card.featured .pt-feats svg{color:var(--mint)}
.pt-note{text-align:center;margin-top:26px;color:var(--ink-soft);font-size:.9rem}
@media(max-width:880px){.price-grid{grid-template-columns:1fr;max-width:430px;margin-left:auto;margin-right:auto}.price-card.featured{transform:none}.price-card.featured:hover{transform:translateY(-6px)}}

/* ---------- IMAGE PAIR + CHECKLIST (Gensure-style) ---------- */
.ipair{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(40px,5vw,72px);align-items:center}
.ipair-media{position:relative;padding:0 34px 34px 0}
.ipair-media--single{padding:0}
.ipair-media--single .ipair-img1{aspect-ratio:4/3.3}
.ipair-img1{width:100%;aspect-ratio:4/3.7;object-fit:cover;border-radius:var(--r-lg);box-shadow:0 14px 40px rgba(35,33,31,.14)}
.ipair-img2{position:absolute;right:0;bottom:0;width:52%;aspect-ratio:4/3.3;object-fit:cover;border-radius:var(--r-lg);box-shadow:0 0 0 7px #fff,0 18px 40px rgba(35,33,31,.18)}
.ipair-tag{position:absolute;left:-6px;top:22px;background:var(--ruby);color:#fff;border-radius:var(--r-md);padding:14px 20px;box-shadow:var(--shadow-ruby);text-align:center}
.ipair-tag b{font-family:var(--font-brand);font-weight:800;font-size:1.7rem;display:block;line-height:1}
.ipair-tag span{font-size:.76rem;opacity:.9}
.ipair-body .eyebrow{margin-bottom:14px}
.ipair-body h2{margin-bottom:16px}
.ipair-body>p{color:var(--ink-soft);font-size:1.05rem;margin-bottom:8px}
.ipair-list{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:13px;margin:22px 0 30px}
.ipair-list li{display:flex;gap:10px;align-items:flex-start;font-size:.98rem;color:var(--ink)}
.ipair-list svg{width:20px;height:20px;color:var(--forest);flex:none;margin-top:2px}
.ipair-actions{display:flex;gap:14px;flex-wrap:wrap}
@media(max-width:900px){.ipair{grid-template-columns:1fr;gap:48px}.ipair-list{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.ipair-list{grid-template-columns:1fr}}

/* ---------- SERVICE ICON GRID (Gensure-style) ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:54px}
.svc-item{background:#fff;border-radius:var(--r-lg);padding:32px 28px;box-shadow:0 1px 2px rgba(35,33,31,.04), 0 6px 20px rgba(35,33,31,.06);transition:.3s var(--ease)}
.svc-item:hover{box-shadow:0 16px 44px rgba(35,33,31,.12);transform:translateY(-6px)}
.svc-item .svc-ic{width:64px;height:64px;border-radius:50%;background:var(--blush);color:var(--ruby);display:flex;align-items:center;justify-content:center;margin-bottom:18px;transition:.3s var(--ease)}
.svc-item:hover .svc-ic{background:var(--ruby);color:#fff}
.svc-item .svc-ic svg{width:28px;height:28px}
.svc-item h3{font-size:1.18rem;margin-bottom:9px}
.svc-item p{font-size:.95rem;color:var(--ink-soft)}
.svc-item .svc-link{display:inline-flex;align-items:center;gap:6px;margin-top:16px;font-family:var(--font-head);font-weight:600;font-size:.92rem;color:var(--ruby);transition:.2s}
.svc-item:hover .svc-link{gap:10px}
.svc-item .svc-link svg{width:15px;height:15px}
@media(max-width:880px){.svc-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.svc-grid{grid-template-columns:1fr}}

/* ---------- VIDEO / CTA BAND (Gensure-style, deep-ruby) ---------- */
.vband{position:relative;border-radius:var(--r-xl);overflow:hidden;min-height:clamp(320px,42vw,470px);display:flex;align-items:center}
.vband-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.vband::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,0,0,.72),rgba(0,0,0,.42) 58%,rgba(0,0,0,.16))}
.vband-inner{position:relative;z-index:2;color:#fff;padding:clamp(34px,5vw,64px);max-width:580px}
/* full-bleed band: image spans viewport, content stays aligned to the site gutter */
.vband-full{border-radius:0;min-height:clamp(380px,46vw,520px)}
.vband-full > .wrap{width:100%}
.vband-full .vband-inner{padding-left:0;padding-right:0;max-width:560px}
.vband-inner .eyebrow{color:var(--mint);margin-bottom:14px}
.vband-inner .eyebrow::before{background:var(--mint)}
.vband-inner h2{color:#fff;margin-bottom:12px}
.vband-inner p{color:rgba(255,255,255,.86);font-size:1.06rem;margin-bottom:26px}
.vband-play{width:74px;height:74px;border-radius:50%;background:#fff;color:var(--ruby);display:flex;align-items:center;justify-content:center;margin-bottom:26px;box-shadow:0 12px 34px rgba(0,0,0,.32);transition:.25s var(--ease)}
.vband-play:hover{transform:scale(1.08)}
.vband-play::before{content:"";position:absolute;width:74px;height:74px;border-radius:50%;box-shadow:0 0 0 0 rgba(255,255,255,.5);animation:vpulse 2.4s ease-out infinite}
.vband-play svg{width:26px;height:26px;margin-left:4px}
@keyframes vpulse{0%{box-shadow:0 0 0 0 rgba(255,255,255,.45)}100%{box-shadow:0 0 0 26px rgba(255,255,255,0)}}
@media (prefers-reduced-motion:reduce){.vband-play::before{animation:none}}

/* ---------- GALLERY STRIP (Gensure-style) ---------- */
.gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(168px,1fr));gap:14px}
.gallery img{width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:var(--r-md);transition:.35s var(--ease)}
.gallery a{display:block;overflow:hidden;border-radius:var(--r-md)}
.gallery a:hover img{transform:scale(1.05)}

/* ---------- WHY US (image-led, alternated layout) ---------- */
.whyx{display:grid;grid-template-columns:.92fr 1.08fr;gap:clamp(40px,5vw,72px);align-items:center}
.whyx-media{position:relative}
.whyx-media img{width:100%;aspect-ratio:4/4.3;object-fit:cover;border-radius:var(--r-lg);box-shadow:0 16px 46px rgba(35,33,31,.16)}
.whyx-media::before{content:"";position:absolute;left:-22px;bottom:-22px;width:150px;height:150px;border-radius:var(--r-lg);background:var(--blush);z-index:-1}
.whyx-body .eyebrow{margin-bottom:14px}
.whyx-body>h2{margin-bottom:14px}
.whyx-body>p{color:var(--ink-soft);font-size:1.05rem;margin-bottom:30px}
.whyx-list{display:flex;flex-direction:column;gap:22px}
.whyx-item{display:flex;gap:16px;align-items:flex-start}
.whyx-item .wxi{width:54px;height:54px;border-radius:50%;background:var(--blush);color:var(--ruby);display:flex;align-items:center;justify-content:center;flex:none}
.whyx-item:nth-child(even) .wxi{background:var(--mint);color:var(--forest)}
.whyx-item .wxi svg{width:25px;height:25px}
.whyx-item h4{font-family:var(--font-head);font-weight:600;font-size:1.12rem;margin-bottom:4px}
.whyx-item p{font-size:.95rem;color:var(--ink-soft)}
@media(max-width:900px){.whyx{grid-template-columns:1fr;gap:44px}.whyx-media{max-width:480px}}

/* ---------- HERO STATS (card overlapping hero edge) ---------- */
.hero-stats{position:relative;z-index:5;margin-top:-46px;background:#fff;border-radius:var(--r-lg);box-shadow:0 18px 50px rgba(110,20,32,.14);display:grid;grid-template-columns:repeat(4,1fr);gap:10px;padding:26px 18px}
.hero-stats .hs{text-align:center}
.hero-stats .hs b{font-family:var(--font-brand);font-weight:800;font-size:clamp(1.5rem,2.6vw,2.15rem);color:var(--ruby);display:block;line-height:1}
.hero-stats .hs span{font-size:.85rem;color:var(--ink-soft);margin-top:7px;display:block}
@media(max-width:640px){.hero-stats{grid-template-columns:1fr 1fr;gap:18px;margin-top:-34px;padding:24px 16px}}

/* Hero search card (overlaps hero edge, replaces stats) */
.hero-search{position:relative;z-index:5;margin-top:-44px;background:#fff;border-radius:var(--r-lg);box-shadow:0 18px 50px rgba(110,20,32,.14);padding:22px 24px}
.hero-search .hsx{display:flex;gap:12px;align-items:center}
.hero-search .hsx-field{position:relative;flex:1;min-width:0}
.hero-search .hsx-field svg{position:absolute;left:18px;top:50%;transform:translateY(-50%);width:19px;height:19px;color:var(--stone)}
.hero-search .hsx-field input{width:100%;height:54px;padding:0 18px 0 48px;border:none;border-radius:999px;font-family:var(--font-body);font-size:1rem;color:var(--ink);background:var(--fog);transition:.2s}
.hero-search .hsx-field input:focus{outline:none;background:#fff;box-shadow:0 0 0 4px rgba(46,125,87,.15)}
.hero-search .hsx > .btn{flex:none;height:54px;padding:0 30px;font-size:.98rem}
.hero-search .hsx-tags{display:flex;flex-wrap:wrap;gap:9px;align-items:center;margin-top:14px;font-size:.85rem;color:var(--stone)}
.hero-search .hsx-tags a{color:var(--ruby-700);background:var(--blush);padding:4px 13px;border-radius:999px;font-weight:600;transition:.2s}
.hero-search .hsx-tags a:hover{background:var(--ruby);color:#fff}
@media(max-width:640px){.hero-search{margin-top:-32px;padding:18px 16px}.hero-search .hsx{flex-direction:column;align-items:stretch}.hero-search .hsx > .btn{justify-content:center}}

/* ── Trust / credibility cards ── */
.trust-cards{background:var(--fog);padding:clamp(40px,6vw,66px) 0}
.tc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.tc{background:#fff;border-radius:var(--r-lg);padding:26px 22px;box-shadow:0 2px 10px rgba(35,33,31,.04),0 12px 30px rgba(35,33,31,.05);transition:.25s var(--ease)}
.tc:hover{transform:translateY(-4px);box-shadow:0 16px 38px rgba(110,20,32,.1)}
.tc-ic{display:inline-flex;align-items:center;justify-content:center;width:52px;height:52px;border-radius:15px;margin-bottom:15px}
.tc-ic svg{width:26px;height:26px}
.tc-ic--m{background:var(--mint);color:var(--forest)}
.tc-ic--r{background:var(--blush);color:var(--ruby)}
.tc h4{font-size:1.04rem;margin-bottom:6px;color:var(--ink)}
.tc p{font-size:.87rem;color:var(--ink-soft);line-height:1.5}
@media(max-width:860px){.tc-grid{grid-template-columns:1fr 1fr}}
@media(max-width:460px){.tc-grid{grid-template-columns:1fr}}

/* footer legal/credibility */
.foot-legal{display:flex;align-items:flex-start;gap:12px;padding-top:24px;margin-top:22px;border-top:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.6);font-size:.82rem;line-height:1.65}
.foot-legal .fl-shield{width:26px;height:26px;color:var(--mint);flex:none;margin-top:1px}
.foot-legal-links{display:flex;gap:18px;flex-wrap:wrap}
.foot-legal-links a{color:rgba(255,255,255,.7)}
.foot-legal-links a:hover{color:#fff}

/* PDPA consent + secure note */
.pdpa-consent{display:flex;gap:10px;align-items:flex-start;margin:4px 0 16px;font-size:.82rem;color:var(--ink-soft);line-height:1.5;cursor:pointer}
.pdpa-consent input{margin-top:2px;width:16px;height:16px;flex:none;accent-color:var(--ruby)}
.pdpa-consent a{color:var(--ruby);font-weight:600}
.form-secure{display:flex;gap:8px;align-items:center;justify-content:center;margin-top:14px;font-size:.8rem;color:var(--forest);line-height:1.4}
.form-secure svg{width:16px;height:16px;flex:none}

/* ---------- FLOATING CONTACT BUTTON + MENU ---------- */
.fab-wrap{position:fixed;right:24px;bottom:24px;z-index:75;display:flex;flex-direction:column;align-items:flex-end;gap:13px}
.fab-menu{display:flex;flex-direction:column;align-items:flex-end;gap:12px}
.fab-item{position:relative;width:50px;height:50px;border-radius:50%;background:#fff;color:var(--ruby);display:flex;align-items:center;justify-content:center;box-shadow:0 8px 22px rgba(35,33,31,.2);opacity:0;transform:translateY(14px) scale(.8);pointer-events:none;transition:.28s var(--ease)}
.fab-item svg{width:23px;height:23px}
.fab-item.fab-phone{background:var(--ruby);color:#fff}
.fab-item.fab-line{background:var(--forest);color:#fff}
.fab-item::before{content:attr(data-label);position:absolute;right:60px;top:50%;transform:translateY(-50%);background:var(--ink);color:#fff;font-family:var(--font-head);font-size:.82rem;font-weight:600;padding:7px 12px;border-radius:8px;white-space:nowrap;opacity:0;pointer-events:none;transition:.2s var(--ease)}
.fab-item:hover::before{opacity:1}
.fab-wrap.open .fab-item{opacity:1;transform:none;pointer-events:auto}
.fab-wrap.open .fab-item:nth-child(1){transition-delay:.15s}
.fab-wrap.open .fab-item:nth-child(2){transition-delay:.09s}
.fab-wrap.open .fab-item:nth-child(3){transition-delay:.04s}
.fab{position:relative;width:60px;height:60px;border-radius:50%;background:var(--ruby);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 14px 32px rgba(110,20,32,.42);transition:.25s var(--ease);border:none;cursor:pointer}
.fab:hover{background:var(--ruby-700);transform:scale(1.05)}
.fab svg{width:27px;height:27px}
.fab .ic-close{display:none}
.fab-wrap.open .fab{background:var(--ruby-700)}
.fab-wrap.open .fab .ic-chat{display:none}
.fab-wrap.open .fab .ic-close{display:block}
.fab::before{content:"";position:absolute;inset:0;border-radius:50%;box-shadow:0 0 0 0 rgba(178,34,52,.5);animation:fabpulse 2.6s ease-out infinite;pointer-events:none}
.fab-wrap.open .fab::before{animation:none}
@keyframes fabpulse{0%{box-shadow:0 0 0 0 rgba(178,34,52,.45)}100%{box-shadow:0 0 0 20px rgba(178,34,52,0)}}
@media (prefers-reduced-motion:reduce){.fab::before{animation:none}}
@media(max-width:600px){.fab-wrap{right:16px;bottom:16px}.fab{width:54px;height:54px}.fab svg{width:24px;height:24px}.fab-item{width:46px;height:46px}}
