@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(30px) skewX(-1deg)}to{opacity:1;transform:translateY(0) skewX(0)}}@keyframes word-reveal{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes floatBadge{0%,to{transform:translateY(0) rotate(-3deg)}50%{transform:translateY(-18px) rotate(3deg)}}@keyframes badgeScroll{0%{transform:translateX(0)}to{transform:translateX(-50%)}}@keyframes shimmer{0%{background-position:-200%0}to{background-position:200%0}}@keyframes trustChipIn{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@keyframes trustStatColIn{0%{opacity:0;transform:translateY(22px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes trustIconGlow{0%,to{box-shadow:0 8px 28px rgba(0,0,0,.22),0 0 0 1px rgba(255,255,255,.1),inset 0 1px 0 rgba(255,255,255,.14)}50%{box-shadow:0 10px 32px rgba(255,90,31,.18),0 0 24px rgba(240,192,96,.12),inset 0 1px 0 rgba(255,255,255,.18)}}@keyframes statGradientDrift{0%{background-position:0 50%}to{background-position:200% 50%}}@keyframes statLabelBreath{0%,to{opacity:.52;letter-spacing:.14em}50%{opacity:.88;letter-spacing:.18em}}@keyframes trustSlideUp{0%{opacity:.2;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@keyframes arrowBounce{0%,to{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(8px)}}@keyframes gradShift{0%,to{background-position:0 50%}50%{background-position:100% 50%}}@keyframes spinSlow{to{transform:rotate(360deg)}}@keyframes lb-backdrop-in{0%{opacity:0}to{opacity:1}}@keyframes lb-img-in{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@keyframes pulseRing{0%{transform:scale(1);opacity:.6}to{transform:scale(1.5);opacity:0}}@keyframes booking-form-shake{0%,to{transform:translateX(0)}18%{transform:translateX(-7px)}36%{transform:translateX(7px)}54%{transform:translateX(-4px)}72%{transform:translateX(4px)}}@keyframes booking-success-check-pop{0%{transform:scale(0) rotate(-25deg);opacity:0}to{transform:scale(1) rotate(0);opacity:1}}@keyframes hg-ken-burns{0%{transform:scale(1.1)}to{transform:scale(1.03)}}@keyframes fc-spin{to{transform:rotate(360deg)}}@keyframes sc-pulse{0%{box-shadow:0 0 0 0 rgba(255,90,31,.5)}70%{box-shadow:0 0 0 8px transparent}to{box-shadow:0 0 0 0 transparent}}:root{--navy:#0a2540;--navy2:#0c2e4e;--sand:#f0c060;--sand2:#fdf4e3;--sand3:#fff8ec;--bg-light:#ffffff;--fire:#ff5a1f;--fired:#e04a10;--ocean:#0ea5e9;--white:#ffffff;--text:#1a2b3c;--muted:#5b6e82;--glass-10:rgba(255,255,255,0.08);--glass-15:rgba(255,255,255,0.13);--glass-20:rgba(255,255,255,0.20);--glass-b:rgba(10,37,64,0.75);--b-nav:rgba(8,18,34,0.45);--b-light:rgba(10,37,64,0.92);--s-sm:0 2px 12px rgba(10,37,64,0.10);--s-md:0 6px 28px rgba(10,37,64,0.14);--s-lg:0 16px 56px rgba(10,37,64,0.20);--s-xl:0 32px 80px rgba(10,37,64,0.28);--s-fire:0 10px 32px rgba(255,90,31,0.35);--s-sand:0 8px 24px rgba(240,192,96,0.25);--b-glass:1px solid rgba(255,255,255,0.12);--b-sand:1px solid rgba(240,192,96,0.25);--r-sm:10px;--r:16px;--r-lg:24px;--r-pill:999px;--ease:cubic-bezier(0.4,0,0.2,1);--spring:cubic-bezier(0.34,1.56,0.64,1);--ease-out:cubic-bezier(0,0,0.2,1);--t:0.28s var(--ease);--t-slow:0.6s var(--ease);--max:1100px;--fh:'Raleway',sans-serif;--fb:'Inter',-apple-system,sans-serif}*,::after,::before{margin:0;padding:0}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;scrollbar-width:thin;scrollbar-color:var(--fire) var(--navy)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--navy)}::-webkit-scrollbar-thumb{background:var(--fire);border-radius:3px}body{font-family:var(--fb);color:var(--text);line-height:1.7;background:#fff;max-width:100vw;overflow-x:hidden}h1,h2,h3,h4,h5{font-family:var(--fh);font-weight:700;line-height:1.15;letter-spacing:-.025em}a{color:inherit;text-decoration:none}img{display:block}button{cursor:pointer;border:0;background:0 0;font-family:inherit}::selection{background:var(--fire);color:#fff}#nav,#scroll-progress{position:fixed;top:0;left:0}#scroll-progress{z-index:1001;height:2px;width:0;background:linear-gradient(90deg,var(--fire),var(--sand),var(--fire));background-size:200% 100%;animation:shimmer 2s linear infinite;transition:width .1s linear;border-radius:0 2px 2px 0}#nav{right:0;z-index:200;background:rgba(8,18,34,.45);backdrop-filter:blur(0) saturate(100%);-webkit-backdrop-filter:blur(0) saturate(100%);border-bottom:1px solid transparent;transition:background .35s var(--ease),border-color .35s var(--ease),box-shadow .35s var(--ease),backdrop-filter .35s var(--ease),transform .35s var(--ease);will-change:transform,backdrop-filter}#nav.scrolled{background:rgba(8,22,40,.94);backdrop-filter:blur(28px) saturate(200%);-webkit-backdrop-filter:blur(28px) saturate(200%);border-color:rgba(255,255,255,.07);box-shadow:0 4px 32px rgba(0,0,0,.25),0 1px 0 rgba(255,255,255,.05) inset}.nav-inner,.nav-links{display:flex;align-items:center}.nav-inner{max-width:var(--max);margin:0 auto;padding:0 28px;height:72px;gap:16px}.nav-logo img{transition:opacity var(--t)}.nav-logo:hover img{opacity:.85}.nav-links{gap:2px;flex:1;justify-content:center}.nav-link{position:relative;color:rgba(255,255,255,.78);padding:8px 14px;border-radius:var(--r-sm);font-size:13.5px;font-weight:500;transition:color var(--t),background var(--t);white-space:nowrap}.nav-link::after{content:"";position:absolute;bottom:4px;left:14px;right:14px;height:2px;background:linear-gradient(90deg,var(--fire),var(--sand));border-radius:2px;transform:scaleX(0);transform-origin:left;transition:transform .3s var(--spring)}.nav-link:hover{color:#fff;background:rgba(255,255,255,.08)}.nav-link.active{color:#fff}.nav-link.active::after{transform:scaleX(1)}.nav-cta{background:linear-gradient(135deg,var(--fire),var(--fired))!important;color:#fff!important;border-radius:var(--r-pill)!important;font-weight:700!important;font-size:13px!important;padding:9px 20px!important;box-shadow:0 4px 16px rgba(255,90,31,.35)!important;transition:transform .2s var(--spring),box-shadow .2s var(--ease)!important}.nav-cta:hover{box-shadow:var(--s-fire)!important}.nav-cta::after{display:none!important}.nav-right,.nav-wa{display:flex;align-items:center}.nav-right{gap:10px;flex-shrink:0}.nav-wa{gap:7px;padding:9px 16px;border-radius:var(--r-pill);background:rgba(37,211,102,.15);border:1px solid rgba(37,211,102,.25);color:rgba(255,255,255,.9);font-size:13px;font-weight:600;transition:background var(--t),border-color var(--t),transform .2s var(--spring);backdrop-filter:blur(8px)}.nav-wa:hover{background:#25d366;border-color:#25d366;transform:translateY(-1px)}.hero::after,.nav-wa-label{display:none}@media (min-width:1100px){.nav-wa-label{display:inline}}.lang-dd{position:relative}.lang-dd-btn{display:flex;align-items:center;gap:7px;padding:8px 12px;border-radius:var(--r-sm);background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);backdrop-filter:blur(8px);color:#fff;font-size:13px;font-weight:500;transition:background var(--t),border-color var(--t);cursor:pointer;white-space:nowrap}.lang-dd-btn:hover{background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.2)}.lang-dd-btn .chev{width:14px;height:14px;display:inline-flex;flex-shrink:0;transition:transform .25s var(--ease)}.lang-dd.open .lang-dd-btn .chev{transform:rotate(180deg)}.lang-dd-menu{position:absolute;top:calc(100% + 10px);right:0;min-width:165px;padding:6px;background:rgba(8,20,36,.96);backdrop-filter:blur(24px) saturate(200%);-webkit-backdrop-filter:blur(24px) saturate(200%);border:1px solid rgba(255,255,255,.1);border-radius:14px;box-shadow:0 20px 50px rgba(0,0,0,.35),0 1px 0 rgba(255,255,255,.06) inset;z-index:300;opacity:0;pointer-events:none;transform:translateY(10px) scale(.97);transform-origin:top right;transition:opacity .22s var(--ease),transform .22s var(--ease)}.lang-dd.open .lang-dd-menu{opacity:1;pointer-events:auto;transform:translateY(0) scale(1)}.lang-dd-item{display:flex;align-items:center;gap:10px;padding:10px 13px;border-radius:10px;color:rgba(255,255,255,.78);font-size:13.5px;font-weight:500;transition:background var(--t),color var(--t);cursor:pointer;text-decoration:none}.lang-dd-item:hover{background:rgba(255,255,255,.1);color:#fff}.hero,.nav-toggle{align-items:center;justify-content:center}.nav-toggle{width:40px;height:40px;border-radius:10px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.12);display:none;color:#fff;transition:background var(--t)}.nav-toggle:hover{background:rgba(255,255,255,.18)}.hero{position:relative;min-height:100vh;display:flex;overflow:hidden;text-align:center;isolation:isolate}@media (max-width:768px){.hero{min-height:100vh;min-height:100svh;align-items:flex-start;justify-content:center;padding-top:max(88px,env(safe-area-inset-top,0) + 72px);padding-bottom:68px;box-sizing:border-box}}#hero-video{display:block!important}.hero-video-wrap,.hero-video-wrap video{position:absolute;inset:0;transform:translateZ(0);backface-visibility:hidden;-webkit-backface-visibility:hidden}.hero-video-wrap{z-index:0;overflow:hidden}.hero-video-wrap video{width:100%;height:100%;object-fit:cover;filter:contrast(1.1) saturate(1.15) brightness(.92)}.hero-video-wrap::before{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;background:radial-gradient(ellipse at 65% 40%,rgba(255,90,31,.08)0,transparent 45%),linear-gradient(168deg,rgba(6,16,30,.58)0,rgba(6,16,30,.28) 45%,rgba(0,0,0,.62) 100%)}.hero-video-wrap::after{display:none}.hero-content{position:relative;z-index:4;max-width:880px;padding:0 24px;transform:translateZ(0)}.hero-eyebrow{display:inline-flex;align-items:center;gap:10px;padding:8px 20px;border-radius:var(--r-pill);background:rgba(18,32,52,.78);border:1px solid rgba(255,90,31,.35);color:var(--sand);font-size:12px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;margin-bottom:24px;box-shadow:0 0 24px rgba(255,90,31,.15),inset 0 1px 0 rgba(255,255,255,.1)}.hero-h1{font-size:clamp(44px,7.5vw,92px);color:#fff;font-weight:900;letter-spacing:-.045em;line-height:1.03;margin-bottom:22px;text-shadow:0 4px 40px rgba(0,0,0,.25)}.hero-h1 em{font-style:normal;background:linear-gradient(100deg,var(--sand),var(--fire) 50%,var(--sand));background-size:200% 100%;animation:shimmer 3s linear infinite;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;transform:translateZ(0);-webkit-font-smoothing:antialiased}.hero-sub{font-size:clamp(16px,2.2vw,21px);color:rgba(255,255,255,.82);font-weight:300;line-height:1.65;margin-bottom:40px;max-width:660px;margin-left:auto;margin-right:auto}.hero-cta,.hero-trust{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}.hero .btn-glass{backdrop-filter:none;-webkit-backdrop-filter:none;background:rgba(14,32,52,.62);border:1px solid rgba(255,255,255,.22)}.hero .btn-glass:hover{background:rgba(20,42,64,.78)}.hero-trust{gap:14px;margin-top:48px}.trust-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border-radius:var(--r-pill);background:rgba(12,28,48,.72);border:1px solid rgba(255,255,255,.14);color:rgba(255,255,255,.85);font-size:12px;font-weight:500;box-shadow:inset 0 1px 0 rgba(255,255,255,.1);transition:background var(--t),transform .2s var(--spring)}.trust-badge:hover{background:rgba(255,255,255,.14);transform:translateY(-2px)}.stats-bar{background:linear-gradient(160deg,#07192e 0,#0a2540 50%,#071826 100%);overflow:hidden}.stats-bar::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 50% 100%,rgba(255,90,31,.14)0,transparent 60%)}.stats-bar::after{top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,90,31,.5),rgba(240,192,96,.5),transparent)}.btn{display:inline-flex;align-items:center;gap:9px;padding:14px 30px;border-radius:var(--r-pill);font-family:var(--fh);font-weight:700;font-size:14px;letter-spacing:.05em;text-transform:uppercase;transition:transform .2s var(--spring),box-shadow .25s var(--ease);position:relative;overflow:hidden;border:0;cursor:pointer;will-change:transform}.btn::after,.btn::before,.stats-bar::after{content:"";position:absolute}.btn::before{top:0;left:0;right:0;height:45%;background:linear-gradient(to bottom,rgba(255,255,255,.18),transparent);border-radius:inherit;pointer-events:none}.btn::after{inset:0;background:radial-gradient(circle at 50% 50%,rgba(255,255,255,.25)0,transparent 60%);opacity:0;transition:opacity .3s}.btn:hover::after{opacity:1}.btn-fire{background:linear-gradient(135deg,#ff6b35,var(--fire));color:#fff;box-shadow:0 4px 20px rgba(255,90,31,.3)}.btn-fire:hover{box-shadow:var(--s-fire)}.btn-deep{background:linear-gradient(135deg,var(--navy2),#0d3060);color:#fff;box-shadow:var(--s-sm)}.btn-deep:hover{box-shadow:var(--s-md)}.btn-glass{background:rgba(255,255,255,.12);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);color:#fff;border:var(--b-glass);box-shadow:inset 0 1px 0 rgba(255,255,255,.15)}.btn-glass:hover{background:rgba(255,255,255,.2)}.btn-outline{background:0 0;color:var(--fire);border:2px solid var(--fire)}.btn-outline:hover{background:var(--fire);color:#fff}.btn-wa{background:linear-gradient(135deg,#25d366,#1da851);color:#fff;box-shadow:0 4px 16px rgba(37,211,102,.3)}.btn-wa:hover{box-shadow:0 10px 28px rgba(37,211,102,.4)}.btn-sm{padding:9px 20px;font-size:12px}.btn-lg{padding:17px 38px;font-size:15px}.container,.container-sm{margin:0 auto;padding:0 28px}.container{max-width:var(--max)}.container-sm{max-width:800px}.section{padding:100px 0}.sec-dark{background:linear-gradient(160deg,#07192e,var(--navy));color:#fff}.sec-light{background:#f7fafd}.sec-sand{background:linear-gradient(135deg,var(--sand3),#fef8f0)}.sh-feat-ico svg{width:26px;height:26px;color:#fff;flex-shrink:0}.s-label{display:inline-flex;align-items:center;gap:10px;font-size:12px;font-weight:800;letter-spacing:.15em;text-transform:uppercase;color:#c44213;margin-bottom:16px}.s-label::before{content:"";width:22px;height:2px;background:linear-gradient(90deg,var(--fire),var(--sand));border-radius:2px;display:inline-block}.s-title{font-size:clamp(28px,4vw,50px);margin-bottom:18px;line-height:1.12}.s-sub{font-size:17.5px;color:var(--muted);max-width:580px;line-height:1.78}.split{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}#booking-section .split{grid-template-columns:minmax(0,2.15fr) minmax(280px,1fr);align-items:flex-start}.split-img{border-radius:var(--r-lg);overflow:hidden;position:relative}.split-img img{width:100%;height:480px;object-fit:cover;transition:transform var(--t-slow)}.split-img:hover img{transform:scale(1.03)}.split-img::after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,transparent 60%,rgba(255,90,31,.12));pointer-events:none;z-index:1}.split-img::before{content:"NGOR";position:absolute;bottom:18px;right:18px;z-index:2;padding:6px 14px;border-radius:var(--r-pill);background:rgba(8,22,40,.82);backdrop-filter:blur(10px);color:var(--sand);font-size:10px;font-weight:800;letter-spacing:.18em;font-family:var(--fh);border:1px solid rgba(240,192,96,.2)}.grid-2{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:28px}.grid-3{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px}.card{border-radius:var(--r);overflow:hidden;background:#fff;box-shadow:var(--s-sm);transition:box-shadow var(--t-slow);will-change:transform;transform-style:preserve-3d}.card:hover{box-shadow:var(--s-xl)}.card-img{transition:transform .7s var(--ease)}.card:hover .card-img{transform:scale(1.06)}.card-body{padding:24px}.card-h3{font-size:19px;margin-bottom:10px;line-height:1.35}.card-text{font-size:14.5px;color:var(--muted);line-height:1.65}.cat-badge{display:inline-flex;align-items:center;gap:5px;padding:5px 13px;border-radius:var(--r-pill);background:rgba(255,90,31,.1);color:var(--fired);font-size:12px;font-weight:700;letter-spacing:.03em}html.lb-open{overflow:hidden}.gallery-page-section{padding-top:56px;padding-bottom:72px}.gallery-page-intro{text-align:center;max-width:560px;margin:0 auto 36px}.gallery-page-lead{margin:12px 0 0;font-size:16px;line-height:1.75;color:#4b5563}.gallery-masonry{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,220px),1fr));gap:12px;align-items:start}.gallery-masonry--page{grid-template-columns:repeat(auto-fill,minmax(min(100%,200px),1fr))}.gallery-item{display:block;width:100%;padding:0;margin:0;border:0;background:#e8eef4;border-radius:var(--r-sm);overflow:hidden;cursor:zoom-in;position:relative;text-align:left;font:inherit;color:inherit;box-shadow:0 2px 12px rgba(10,37,64,.06);transition:box-shadow .35s var(--ease),transform .35s var(--ease)}.gallery-item:focus-visible{outline:2px solid var(--fire);outline-offset:3px}.gallery-item-inner{display:block;aspect-ratio:4/3;overflow:hidden;background:linear-gradient(145deg,#dfe8f0 0,#e8eef4 100%)}.gallery-item img{width:100%;display:block;object-fit:cover;opacity:1;transition:opacity .4s ease,transform .5s var(--ease)}.gallery-item-inner img{height:100%}.gallery-item>img{aspect-ratio:4/3;height:auto}.gallery-item img.is-loaded,.gallery-item:hover::after{opacity:1}.gallery-item::after{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(transparent 50%,rgba(10,37,64,.5));opacity:0;transition:opacity .3s ease}.gallery-item:hover{box-shadow:0 10px 28px rgba(10,37,64,.12);transform:translateY(-3px)}.gallery-item:hover img.is-loaded{transform:scale(1.05)}@media (prefers-reduced-motion:reduce){.gallery-item{transition:none}.gallery-item:hover,.gallery-item:hover img.is-loaded{transform:none}.gallery-item img{opacity:1;transition:none}}#lb,#lb-close{align-items:center;justify-content:center}#lb{display:none;position:fixed;inset:0;z-index:1000;background:rgba(6,18,32,.88);backdrop-filter:blur(10px) saturate(140%);-webkit-backdrop-filter:blur(10px) saturate(140%);padding:52px 16px 24px;cursor:zoom-out}#lb.open{display:flex;animation:lb-backdrop-in .28s ease-out forwards}#lb img,.faq-item{border-radius:var(--r)}#lb img{max-width:min(92vw,1200px);max-height:86vh;width:auto;height:auto;object-fit:contain;box-shadow:0 24px 64px rgba(0,0,0,.45);cursor:default;animation:lb-img-in .32s ease-out both}#lb-close{position:absolute;top:16px;right:16px;width:46px;height:46px;border-radius:50%;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.22);color:#fff;font-size:22px;line-height:1;display:flex;cursor:pointer;transition:background var(--t),transform .2s ease;z-index:2}#lb-close:hover{background:rgba(255,255,255,.24);transform:scale(1.05)}@media (prefers-reduced-motion:reduce){#lb img,#lb.open{animation:none}}@media (max-width:640px){#lb{backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}}.faq-item{border:1px solid rgba(10,37,64,.1);overflow:hidden;margin-bottom:10px;box-shadow:0 2px 8px rgba(10,37,64,.05);transition:box-shadow var(--t),border-color var(--t)}.faq-item:hover{box-shadow:var(--s-sm);border-color:rgba(10,37,64,.18)}.faq-q{width:100%;text-align:left;padding:20px 26px;display:flex;align-items:center;justify-content:space-between;gap:16px;font-weight:600;font-size:16px;color:var(--navy);background:#fff;transition:background var(--t)}.faq-q:hover{background:#fafbfc}.faq-arrow{color:var(--fire);flex-shrink:0;transition:transform .3s var(--spring)}.faq-item.open .faq-arrow{transform:rotate(180deg)}.faq-a{display:grid;grid-template-rows:0fr;transition:grid-template-rows .45s var(--ease);padding:0 26px;color:var(--muted);line-height:1.78;font-size:15px;background:#fff;box-sizing:border-box;overflow:hidden}.faq-item.open .faq-a{grid-template-rows:1fr;padding-top:8px;padding-bottom:24px}.faq-a>div{min-height:0;overflow:hidden}.faq-item.open .faq-a>div{overflow:visible}.faq-a [itemprop=text]{overflow-wrap:anywhere}.blog-hub-header,.page-header{background-size:cover;color:#fff;text-align:center;position:relative;overflow:hidden}.page-header{padding:150px 28px 90px;background-position:center}.blog-hub-header{background:var(--navy);background-position:center center;min-height:320px;justify-content:flex-end}.blog-hub-header::before{content:"";position:absolute;inset:0;background:linear-gradient(to bottom,rgba(7,25,46,.35)0,rgba(7,25,46,.55) 60%,rgba(7,25,46,.72) 100%);z-index:1}.blog-hub-header .container{position:relative;z-index:2;padding-top:80px}.blog-card,.blog-hub-header{display:flex;flex-direction:column}.blog-card-img-wrap{overflow:hidden;flex-shrink:0}.blog-card-img-wrap .card-img{display:block;transition:transform .5s var(--ease)}.blog-card:hover .blog-card-img-wrap .card-img,.sh2-split-media:hover .sh2-duo-main img{transform:scale(1.04)}.blog-card .card-body{flex:1;display:flex;flex-direction:column;gap:4px}.blog-card .cat-badge{display:inline-block;margin-bottom:4px;cursor:default}.blog-card .card-h3,.blog-card .card-text{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}@media (max-width:900px){.cat-cards-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:580px){.blog-grid,.cat-cards-grid{grid-template-columns:1fr}.blog-hub-header .container{padding:96px 20px 56px!important}}.blog-filter-bar{background:#fff;border-bottom:1px solid #e5e7eb;padding:14px 0;position:sticky;top:64px;z-index:10;box-shadow:0 2px 8px rgba(10,37,64,.05)}.blog-filter-bar .container{display:flex;gap:8px;align-items:center}.cat-filter-btn,.page-header>*{position:relative}.cat-filter-btn.active,.cat-filter-btn[style*=btn-fire]{background:var(--fire)!important;color:#fff!important}.page-header::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 50% 70%,rgba(255,90,31,.1)0,transparent 50%),linear-gradient(rgba(8,22,40,.62),rgba(8,22,40,.88))}.page-header>*{z-index:1}.page-header h1{font-size:clamp(32px,5.5vw,66px);margin-bottom:16px}.page-header p{font-size:18px;opacity:.85;max-width:560px;margin:0 auto}.skip-to-main{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}.skip-to-main:focus{left:16px;top:12px;width:auto;height:auto;padding:10px 16px;z-index:3000;background:var(--navy);color:#fff;border-radius:8px;text-decoration:none;font-weight:600;outline:2px solid var(--fire);overflow:visible}.main-hero{position:relative;min-height:clamp(480px,65vh,680px);background-size:cover;background-position:center top;display:flex;align-items:flex-end;overflow:hidden;padding-top:80px}.main-hero::before{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(7,25,46,.88)0,rgba(7,25,46,.35) 45%,rgba(7,25,46,.12) 100%);pointer-events:none}.main-hero::after{display:none}.main-hero-inner{position:relative;z-index:2;max-width:var(--max);margin:0 auto;width:100%;padding:0 32px 80px;color:#fff}.main-hero-eyebrow{display:flex;align-items:center;gap:10px;font-size:12px;letter-spacing:.15em;text-transform:uppercase;font-weight:700;opacity:.78;margin-bottom:18px}.main-hero-dot{width:6px;height:6px;border-radius:50%;background:var(--fire);flex-shrink:0}.main-hero-h1{font-size:clamp(40px,6.5vw,76px);font-weight:900;font-family:var(--fh);line-height:1;margin:0 0 16px;letter-spacing:-.02em}.main-hero-tagline{font-size:clamp(16px,2vw,20px);font-style:italic;opacity:.86;margin:0 0 32px;line-height:1.5;max-width:520px}.main-hero-actions{display:flex;gap:14px;flex-wrap:wrap;align-items:center}.btn-outline-white{background:0 0;border:1.5px solid rgba(255,255,255,.55);color:#fff;font-size:20px;line-height:1;padding:10px 18px;border-radius:50px;text-decoration:none;transition:background .2s,border-color .2s}.btn-outline-white:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.85)}.btn-navy{background:var(--navy);color:#fff;border:0;border-radius:50px;font-weight:700;font-size:14px;letter-spacing:.05em;text-transform:uppercase;padding:13px 28px;text-decoration:none;display:inline-block;transition:background .2s,transform .18s;width:fit-content}.btn-navy:hover{background:#0d2d52;transform:translateY(-2px)}.btn-md{padding:12px 26px;font-size:13px}.sh-house-gallery{grid-template-columns:repeat(4,1fr)!important;gap:14px!important;align-items:stretch!important;margin-top:0}.sh-house-gallery .gallery-item{height:240px;border-radius:14px}.sh-house-gallery .gallery-item-inner{display:block;height:100%;overflow:hidden;border-radius:14px}.sh-house-gallery .gallery-item-inner img{width:100%;height:100%;object-fit:cover;display:block}@media (max-width:900px){.sh-house-gallery{grid-template-columns:repeat(3,1fr)!important}.sh-house-gallery .gallery-item{height:200px}}@media (max-width:600px){.sh-house-gallery{grid-template-columns:repeat(2,1fr)!important;gap:10px!important}.sh-house-gallery .gallery-item{height:160px}}.sh-feat-card-inner{height:100%;padding:24px 22px 26px;border-radius:16px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);transition:background .3s,transform .3s}.sh-feat-card:hover .sh-feat-card-inner{background:rgba(255,255,255,.1);transform:translateY(-3px)}.sh-feat-ico{width:42px;height:42px;border-radius:12px;background:rgba(255,107,53,.15);border:1px solid rgba(255,107,53,.25);display:flex;align-items:center;justify-content:center;margin-bottom:16px;flex-shrink:0;color:var(--fire)}.sh-feat-ico svg{color:var(--fire)!important}.sh-feat-ico img{filter:brightness(0) saturate(100%) invert(45%) sepia(80%) saturate(600%) hue-rotate(345deg)!important}.sh-feat-title{font-size:16px;font-weight:800;margin:0 0 10px;color:#fff;line-height:1.3}.sh-feat-desc{margin:0;font-size:14px;line-height:1.7;color:rgba(255,255,255,.58)}.ig-grid--editorial{display:flex!important;flex-wrap:nowrap!important;overflow-x:auto!important;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;gap:16px!important;padding-bottom:16px;scrollbar-width:none;border-radius:0!important}.ig-grid--editorial::-webkit-scrollbar{display:none}.ig-grid--editorial .ig-cell{flex:0 0 300px!important;height:380px!important;border-radius:16px!important;scroll-snap-align:start}@media (max-width:720px){.ig-grid--editorial .ig-cell{flex:0 0 240px!important;height:300px!important}}@media (max-width:900px){.main-hero-inner{padding:0 20px 72px}.main-hero-h1{font-size:clamp(36px,8vw,52px)}.main-hero{min-height:68vh;padding-top:72px}}@media (max-width:480px){.main-hero{min-height:clamp(480px,70vh,580px);padding-top:72px}.main-hero-actions .btn-outline-white{display:none}}.article-hero::before{position:absolute;inset:0;pointer-events:none}.sh-gallery-sec{padding-bottom:8px}@media (max-width:640px){.page-header.main-hero{min-height:clamp(460px,58vh,560px);padding:96px 0 72px}}@media (prefers-reduced-motion:reduce){.sh-feat-card:hover .sh-feat-card-inner{transform:none}}.article-hero{position:relative;min-height:clamp(340px,62vh,720px);background-size:cover;background-position:center;display:flex;align-items:flex-end;justify-content:center;overflow:hidden}.article-hero::before{content:"";background:linear-gradient(180deg,rgba(8,22,40,.52)0,rgba(8,22,40,.35) 40%,rgba(8,22,40,.72) 65%,rgba(8,22,40,.94) 100%)}.art-hero-inner{position:relative;z-index:1;width:100%;max-width:760px;margin:0 auto;padding:40px 24px 52px;color:#fff;text-align:center}.island-guide-hero{min-height:clamp(300px,54vh,600px)}.island-guide-hero .island-guide-badge,.island-guides-hub-section .island-guide-badge{background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.32);backdrop-filter:blur(6px)}.island-guide-prose{padding-top:4px}.island-guide-faq{margin-top:40px;max-width:740px;margin-left:auto;margin-right:auto}.island-guides-hub-section .island-guide-card .card-text{font-size:14.5px;line-height:1.65;color:#4b5563;margin-top:8px}.prose{max-width:740px;margin:0 auto}.prose h1{font-size:clamp(26px,4vw,46px);margin-bottom:28px;color:var(--navy)}.prose h2{font-size:clamp(21px,3vw,30px);margin:56px 0 18px;color:var(--navy);padding-bottom:12px;border-bottom:2px solid;border-image:linear-gradient(90deg,var(--fire),var(--sand))1}.prose h3{font-size:clamp(17px,2.5vw,22px);margin:36px 0 12px;color:var(--navy)}.prose h4{font-size:17px;margin:24px 0 10px;color:var(--navy);font-weight:700}article .prose h2[id],article .prose h3[id]{scroll-margin-top:92px}.prose li,.prose p{font-size:17.5px;line-height:1.86;color:#374151;margin-bottom:24px}.prose ol,.prose ul{margin:14px 0 24px 22px}.prose li{font-size:16.5px;line-height:1.72;margin-bottom:10px}.prose li::marker{color:var(--fire)}.prose strong,.vb-content strong,.vblock strong{color:var(--navy);font-weight:700}.prose a{color:var(--fire);border-bottom:1px solid rgba(255,90,31,.25);transition:border-color var(--t)}.prose a:hover{border-color:var(--fire)}.prose blockquote{border-left:4px solid var(--fire);padding:16px 24px;margin:32px 0;background:linear-gradient(135deg,rgba(240,192,96,.14),rgba(240,192,96,.06));border-radius:0 var(--r-sm) var(--r-sm)0;font-style:italic}.vb-fact,.vb-tip{margin:28px 0;border-left:3px solid var(--navy)}.vb-expert,.vb-summary{background:#fff}.vb-checklist,.vb-expert,.vb-summary{margin:28px 0;border-left:3px solid var(--navy)}.vb-tip{border-left-color:var(--fire,#ff6b35)}.vb-expert{border-left-color:var(--sand,#f0c060)}.vb-summary{border-left-color:var(--navy,#0a2540);background:#f0f4f8}.vb-header,.vb-header .vb-ico{display:flex;align-items:center}.vb-header{gap:10px;margin-bottom:10px}.vb-header .vb-ico{width:36px;height:36px;border-radius:8px;justify-content:center;flex-shrink:0;background:rgba(10,37,64,.07)}.vb-tip .vb-header .vb-ico{background:rgba(255,107,53,.1)}.vb-fact .vb-header .vb-ico{background:rgba(61,90,115,.1)}.vb-expert .vb-header .vb-ico{background:rgba(240,192,96,.15)}.vb-summary .vb-header .vb-ico{background:rgba(10,37,64,.1)}.vb-checklist .vb-header .vb-ico{background:rgba(34,197,94,.1)}.vb-header .vb-ico img{width:20px;height:20px;object-fit:contain;display:block}.vb-header .vb-label{font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--navy)}.vb-tip .vb-header .vb-label{color:var(--fire,#ff6b35)}.vb-fact .vb-header .vb-label{color:#1e3a4f}.vb-expert .vb-header .vb-label{color:#92710a}.vb-summary .vb-header .vb-label{color:var(--navy,#0a2540)}.vb-checklist .vb-header .vb-label{color:#16a34a}.vb-content blockquote,.vb-content li,.vb-content p,.vb-content ul{margin:0 0 6px;font-size:15.5px;line-height:1.72;color:#374151}.vb-content p:last-child,.vb-content ul:last-child{margin-bottom:0}.ilink{color:var(--fire,#ff6b35)!important;font-size:.9em;text-decoration:none;border-bottom:1px solid rgba(255,107,53,.35);padding-bottom:1px;transition:border-color .2s}.ilink:hover{border-bottom-color:var(--fire,#ff6b35)}.vblock{display:flex;align-items:flex-start;gap:14px;margin:28px 0;padding:18px 20px;border-radius:var(--r);background:#f8fafc;border:1px solid #e2e8f0;border-left:3px solid var(--navy)}.vb-ico{width:40px;height:40px;border-radius:10px;flex-shrink:0;background:rgba(10,37,64,.07)}.vb-ico img{width:22px;height:22px;object-fit:contain;display:block}.vblock>div:last-of-type{min-width:0;flex:1}.vb-label{display:block;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--navy);margin-bottom:8px;line-height:1.35}.vblock blockquote,.vblock p{margin:0;font-size:15.5px;line-height:1.72;color:#374151}.vb-tip{border-left-color:var(--fire)}.vb-tip .vb-ico{background:rgba(255,90,31,.08)}.article-faq-item.open .faq-a-chevron svg{color:var(--fire)}.vb-fact,.vb-tip{background:#fff}.vb-fact .vb-ico{background:rgba(10,37,64,.07)}.vb-expert{background:#fffdf8;border-left-color:var(--sand)}.vb-expert .vb-ico{background:rgba(240,192,96,.18)}.vb-expert blockquote{font-size:17px;font-style:italic;color:#2a1d06;line-height:1.78;font-family:var(--fh);font-weight:500;margin:0;border:0;padding:0}.vb-summary{background:var(--navy);border-color:rgba(10,37,64,.5);border-left-color:var(--fire)}.vb-summary li strong,.vb-summary strong{color:#fff}.vb-summary li{margin-top:8px}.vb-summary li::before{font-weight:700}.vb-checklist{background:#fff}.vb-checklist .vb-ico{background:rgba(34,197,94,.08)}.vb-checklist li{display:flex!important;margin-top:8px}.vb-checklist li::before{position:static!important;display:inline-flex!important;min-width:20px}.vb-fact ul.block-list li,.vb-tip ul.block-list li{font-size:15px;line-height:1.65;color:#374151;padding-left:18px;position:relative;margin-bottom:8px}.vb-fact ul.block-list li::before{color:var(--navy)}.vblock:has(.vb-header){flex-direction:column;align-items:stretch;gap:0}.vblock:has(.vb-header)>.vb-header{display:flex;align-items:center;gap:12px;margin-bottom:10px}.vblock:has(.vb-header)>.vb-header .vb-label{margin-bottom:0}.vblock:has(.vb-header)>.vb-content{width:100%;min-width:0}.vblock:has(.vb-header) .vb-content>p:first-child{margin-top:0}.vblock:has(.vb-header) .vb-content li,.vblock:has(.vb-header) .vb-content p{font-size:15.5px;line-height:1.72;color:#374151}.vb-summary:has(.vb-header) .vb-content li,.vb-summary:has(.vb-header) .vb-content p{color:rgba(255,255,255,.92)}.pull-quote{display:flex;gap:14px;align-items:flex-start;padding:20px 22px;margin:32px 0;background:#f8fafc;border-radius:var(--r);border:1px solid #e2e8f0;border-left:3px solid var(--sand)}.pull-quote img{opacity:.2;flex-shrink:0}.pull-quote.mini{padding:18px 20px}.pq-txt{font-size:clamp(17px,2.5vw,19px);font-style:italic;line-height:1.72;color:var(--navy);font-family:var(--fh);font-weight:600;margin:0;border:0;padding:0;background:0 0}.persona-bar{display:flex;gap:12px;flex-wrap:wrap;align-items:center;padding:18px 22px;background:#f9fafb;border-radius:var(--r);border:1px solid #e5e7eb;margin-bottom:32px}.art-lang-bar .lbl,.persona-bar-label{font-size:12px;color:#9ca3af;text-transform:uppercase}.persona-bar-label{font-weight:700;letter-spacing:.1em}.persona-chip{display:inline-flex;align-items:center;gap:8px;padding:7px 14px;border-radius:var(--r-pill);font-size:13px;font-weight:600;border:1.5px solid;position:relative;cursor:default}.persona-chip img{width:28px;height:28px;border-radius:50%;object-fit:cover;flex-shrink:0}.persona-chip-tooltip,.persona-chip-tooltip::after{position:absolute;left:50%;transform:translateX(-50%)}.persona-chip-tooltip{bottom:calc(100% + 8px);background:var(--navy);color:#fff;padding:10px 14px;border-radius:10px;font-size:12.5px;line-height:1.5;width:230px;opacity:0;pointer-events:none;transition:opacity .2s;z-index:10;font-weight:400;text-align:center;box-shadow:0 8px 24px rgba(0,0,0,.25)}.persona-chip-tooltip::after{content:"";top:100%;border:6px solid transparent;border-top-color:var(--navy)}.persona-chip:hover .persona-chip-tooltip{opacity:1}.author-card{display:flex;align-items:center;gap:16px;padding:20px 24px;background:#f9fafb;border-radius:var(--r);border:1px solid #e5e7eb;margin:40px 0}.author-avatar{width:62px;height:62px;border-radius:50%;flex-shrink:0}.author-avatar{object-fit:cover;border:3px solid #fff;box-shadow:var(--s-sm)}.author-name{font-weight:700;font-size:15px;color:var(--navy)}.author-role{font-size:12.5px;color:var(--fire);font-weight:600;margin-top:2px}.author-bio-text{font-size:13px;color:var(--muted);margin-top:4px;line-height:1.6}#art-progress{position:fixed;top:72px;left:0;right:0;height:2px;background:rgba(255,90,31,.18);z-index:100}#art-progress-fill{height:100%;width:0;background:linear-gradient(90deg,var(--fire),var(--sand));transition:width .1s linear}.art-lang-bar,.lang-pill{align-items:center;border:1px solid #e5e7eb}.art-lang-bar{display:flex;gap:8px;flex-wrap:wrap;padding:14px 18px;background:#f9fafb;border-radius:var(--r);margin-bottom:36px}.art-lang-bar .lbl{letter-spacing:.08em;margin-right:4px}.lang-pill{display:inline-flex;gap:7px;padding:6px 12px;border-radius:8px;font-size:12.5px;font-weight:600;background:#fff;color:#374151;transition:var(--t)}.lang-pill.active,.lang-pill:hover{background:var(--navy);color:#fff;border-color:var(--navy)}.breadcrumb a{transition:color var(--t)}.breadcrumb span{color:#d1d5db}.art-cta{margin:60px 0;padding:44px;border-radius:var(--r-lg);text-align:center;color:#fff;background:linear-gradient(135deg,var(--navy) 0%,#1a4a7a 100%);position:relative;overflow:hidden;box-shadow:var(--s-lg)}.art-cta::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 50% 100%,rgba(255,90,31,.2)0,transparent 55%)}.prose .art-cta h2{color:#f8fafc;border-image:none;border-bottom:2px solid var(--fire);padding-bottom:14px;margin-top:0;margin-bottom:16px}.prose .art-cta p{color:rgba(248,250,252,.94)!important;opacity:1!important}.prose .art-cta a.btn{border-bottom:none}.prose .art-cta .btn-fire,.prose .art-cta .btn-glass{color:#fff;-webkit-text-fill-color:currentColor}.related-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.share-row{display:flex;align-items:center;gap:12px;margin:40px 0;flex-wrap:wrap}.share-btn,.share-label{font-size:13px;font-weight:600}.share-label{color:#9ca3af;text-transform:uppercase;letter-spacing:.1em}.share-btn{display:inline-flex;align-items:center;gap:7px;padding:9px 18px;border-radius:var(--r-pill);transition:transform .2s var(--spring),box-shadow .2s;cursor:pointer;border:0}.share-btn:hover{transform:translateY(-2px)}.share-wa{background:#25d366;color:#fff;box-shadow:0 4px 14px rgba(37,211,102,.25)}.share-copy{background:#f3f4f6;color:#374151}.copy-success{display:none;color:#22c55e;font-size:13px;font-weight:600}.prose-ul{margin:14px 0 22px 22px}.prose-ul li{font-size:16.5px;line-height:1.72;color:#374151;margin-bottom:9px}.prose-ul li::marker{color:var(--fire)}.ilink{color:var(--fire)!important;font-weight:600;display:inline-flex;align-items:center;gap:4px}.form-card{background:#fff;border-radius:var(--r-lg);padding:44px;box-shadow:var(--s-md)}.form-group{margin-bottom:22px}.form-label{display:block;font-weight:600;font-size:13px;margin-bottom:8px;color:var(--navy)}.form-input,.form-select,.form-textarea{width:100%;padding:13px 18px;border:2px solid #e5e7eb;border-radius:var(--r-sm);font-family:var(--fb);font-size:15px;color:var(--navy);transition:border-color var(--t),box-shadow var(--t);outline:0;background:#fff}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--fire);box-shadow:0 0 0 4px rgba(255,90,31,.1)}.form-textarea{resize:vertical;min-height:88px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}.form-check{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:14px;color:#374151}.form-check input{accent-color:var(--fire);width:17px;height:17px}.cta-band{padding:104px 0;color:#fff;text-align:center;background:#070f1c;position:relative;overflow:hidden}.cta-band::after,.cta-band::before{display:none}.cta-band h2{font-size:clamp(28px,4vw,50px);margin-bottom:16px}.cta-band h2,.cta-band p,.cta-btns{position:relative;z-index:1}.cta-band p{font-size:17px;opacity:.78;max-width:520px;margin:0 auto 44px;line-height:1.75}.cta-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}footer{background:linear-gradient(160deg,#06111e,#08192c);color:#fff;padding:80px 0 36px;border-top:none}.footer-brand{display:flex;flex-direction:column;align-items:flex-start;gap:0;max-width:min(320px,100%)}.footer-brand-mark{display:block;line-height:0;flex-shrink:0;border-radius:14px;padding:6px 8px;margin:-6px -8px 0;transition:background var(--t),box-shadow var(--t),transform .2s var(--spring)}.footer-brand-mark:hover{background:rgba(255,255,255,.06);box-shadow:0 0 0 1px rgba(255,255,255,.08)}.footer-brand-mark:focus-visible{outline:2px solid var(--sand);outline-offset:4px}.footer-brand-logo{height:52px;width:auto;max-width:min(220px,100%);object-fit:contain;object-position:left center;display:block}.footer-brand-text,footer .footer-brand>p{font-size:14px;opacity:.55;line-height:1.8;max-width:280px;margin:18px 0 0}.footer-col h4{font-size:11px;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:var(--sand);margin-bottom:20px}.footer-social{display:flex;gap:10px;flex-wrap:wrap;margin-top:22px;padding-top:22px;width:100%;max-width:300px;box-sizing:border-box;border-top:1px solid rgba(255,255,255,.08)}.footer-bottom,.soc-btn{display:flex;align-items:center}.soc-btn{width:42px;height:42px;border-radius:12px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.09);justify-content:center;color:rgba(255,255,255,.65);transition:background var(--t),color var(--t),transform .2s var(--spring)}.soc-btn:hover{color:#fff;transform:translateY(-3px)}.soc-btn.wa:hover{background:#25d366;border-color:transparent}.soc-btn.ig:hover{background:linear-gradient(135deg,#f09433,#e6683c,#dc2743,#bc1888);border-color:transparent}.soc-btn.tt:hover{background:#010101;border-color:transparent}.footer-bottom{border-top:1px solid rgba(255,255,255,.06);padding-top:28px;justify-content:space-between;flex-wrap:wrap;gap:16px;width:100%;box-sizing:border-box}.footer-bottom p{font-size:13px;color:rgba(255,255,255,.35)}.footer-pp-link{color:rgba(255,255,255,.45);text-decoration:none;transition:color .2s}.footer-pp-link:hover{color:rgba(255,255,255,.9);text-decoration:underline}.prose-body h2,.prose-body h3{font-size:clamp(17px,2.4vw,22px);font-weight:800;color:var(--navy,#0a2540);margin:36px 0 12px}.prose-body h3{font-size:clamp(15px,2vw,18px);font-weight:700;margin:24px 0 8px}.prose-body p{margin:0 0 16px}.prose-body ol,.prose-body ul{padding-left:22px;margin:0 0 16px}.prose-body li{margin-bottom:6px}.prose-body a{color:var(--fire,#ff6b35);text-decoration:underline}.prose-body a:hover{opacity:.8}.reveal{opacity:0;transform:translateY(28px);transition:opacity .65s var(--ease),transform .65s var(--ease)}.reveal.up{opacity:1;transform:none}@media (max-width:768px){.reveal{opacity:1;transform:none;transition:none}}.reading-meta{display:flex;align-items:center;gap:20px;font-size:13px;color:#9ca3af;margin-bottom:28px;flex-wrap:wrap}.reading-meta span{display:flex;align-items:center;gap:5px}.faq-layout{display:grid;grid-template-columns:260px 1fr;gap:56px;align-items:flex-start}.faq-sidebar{position:sticky;top:88px;background:#f9fafb;border-radius:var(--r);padding:22px;border:1px solid #e5e7eb}.faq-section{margin-bottom:52px}.faq-section[id]{scroll-margin-top:100px}@media (max-width:1024px){.faq-layout{grid-template-columns:1fr;gap:32px}.faq-sidebar{position:relative;top:auto}.split{grid-template-columns:1fr;gap:44px}.split-img img{height:340px}}@media (max-width:768px){.nav-links{display:none;flex-direction:column;position:fixed;top:72px;left:0;right:0;padding:16px 20px;gap:4px;background:rgba(8,20,36,.97);backdrop-filter:blur(24px) saturate(200%);-webkit-backdrop-filter:blur(24px) saturate(200%);border-bottom:1px solid rgba(255,255,255,.08);box-shadow:0 16px 40px rgba(0,0,0,.3);z-index:199}.nav-link{border-radius:10px;padding:12px 16px}.nav-links.open,.nav-toggle{display:flex}.hero-h1{font-size:clamp(36px,9vw,56px)}.hero-trust{gap:10px}.gallery-masonry{grid-template-columns:repeat(auto-fill,minmax(min(100%,160px),1fr))}.form-row,.related-grid{grid-template-columns:1fr}.section{padding:72px 0}.form-card{padding:24px}.art-hero-inner{padding:32px 20px 44px}.pull-quote{padding:18px 20px;flex-direction:column;gap:8px}.pull-quote img{display:none}.persona-bar{flex-direction:column;align-items:flex-start}}@media (max-width:480px){.hero-cta{flex-direction:column;align-items:stretch}.btn{justify-content:center}.cta-btns{flex-direction:column;align-items:center}.hero-trust{flex-direction:column;align-items:center}.nav-inner{padding:0 16px}}.reviews-section{background:linear-gradient(160deg,#07192e 0,#07192e 100%);color:#fff;position:relative;overflow:hidden}.reviews-section::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 20% 50%,rgba(255,90,31,.1)0,transparent 50%),radial-gradient(ellipse at 80% 50%,rgba(14,165,233,.08)0,transparent 50%)}.reviews-section::after{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(240,192,96,.4),transparent)}.reviews-header{display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:20px;position:relative;z-index:1}.reviews-rating-badge{display:flex;flex-direction:column;align-items:center;gap:4px;-webkit-backdrop-filter:blur(14px)}.reviews-count{letter-spacing:.05em}.reviews-slider-wrap{position:relative;z-index:1}.review-card{background:rgba(255,255,255,.06);transition:transform .3s var(--spring),box-shadow .3s,background .3s;cursor:default}.review-card:hover{background:rgba(255,255,255,.1)}.rc-head{margin-bottom:16px}.rc-avatar{background-size:cover;background-position:center}.rc-stars{margin-bottom:14px}.rc-verified{margin-top:14px}.rc-verified svg{width:12px;height:12px}.reviews-nav{position:relative;z-index:1}.rev-arrow{transition:background var(--t),color var(--t),transform .2s var(--spring)}.rev-arrow:hover{background:var(--fire);border-color:var(--fire);color:#fff;transform:scale(1.08)}.reviews-cta{align-items:center;position:relative;z-index:1}.google-cta-btn{transition:background var(--t),color var(--t),transform .2s var(--spring);text-decoration:none}@media (max-width:1024px){.review-card{flex:0 0 calc(50% - 10px)}}@media (max-width:640px){.review-card{flex:0 0 calc(100% - 0px)}.reviews-header{flex-direction:column;align-items:flex-start}}.stats-bar{padding:0;background:0 0;position:relative;z-index:2;margin-top:-2px}.trust-stats-block .stats-bar{background:0 0}.article-faq-section{margin:48px 0 0;border-radius:var(--r);overflow:hidden;border:1px solid #e5e7eb;background:#fff;box-shadow:none}.article-faq-item{position:relative}.article-faq-item:last-child{border-bottom:none}.article-faq-q{background:#fff;transition:background .2s,color .2s;font-family:var(--fh);line-height:1.45}.article-faq-q:hover{background:#f8fafc}.article-faq-item.open .article-faq-q{color:var(--navy);background:#fafbfc}.article-faq-q::before{content:attr(data-num);display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;background:var(--fire-light,rgba(255,90,31,0.10));color:var(--fire);border-radius:8px;font-size:12px;font-weight:800;flex-shrink:0;margin-right:4px;margin-top:1px;font-family:var(--fh)}.faq-a-chevron{width:22px;height:22px;border-radius:50%;background:rgba(10,37,64,.07);display:flex;justify-content:center;margin-top:2px}.article-faq-item.open .faq-a-chevron{background:rgba(255,90,31,.12)}.faq-a-chevron svg{color:var(--muted)}.article-faq-answer{transition:grid-template-rows .45s cubic-bezier(.4,0,.2,1);background:#fafbfc;border-top:1px solid #e5e7eb}.article-faq-answer .faq-answer-inner{min-height:0;overflow:hidden;padding:16px 28px 20px 56px}.article-faq-item.open .article-faq-answer .faq-answer-inner{overflow:visible}.article-faq-answer p{color:#4b5563;font-size:15.5px;line-height:1.78;margin:0}.article-faq-item:first-of-type .article-faq-q::after{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--fire);border-radius:0 2px 2px 0;opacity:0;transition:opacity .2s}.article-faq-item.open .article-faq-q::after{opacity:1}@media (max-width:640px){.article-faq-q{padding:16px 20px 16px 16px;font-size:14.5px}.article-faq-answer .faq-answer-inner{padding:14px 20px 18px}}.footer-quotes{background:#06111e;border-top:none;border-bottom:none;padding:48px 0 52px;overflow:hidden;position:relative}.footer-quotes-inner{max-width:1100px;margin:0 auto;padding:0 32px;display:flex;align-items:center;justify-content:center;position:relative;z-index:1}.footer-quotes::before,.fq-icon{display:none}.fq-text-wrap{flex:1;min-width:0;width:100%;position:relative;min-height:140px;display:flex;align-items:center;justify-content:center}.fq-phrase{position:absolute;left:50%;top:50%;width:100%;max-width:1000px;margin:0;padding:0 20px;box-sizing:border-box;text-align:center;font-size:clamp(14px,2.8vw,28px);font-style:normal;font-weight:800;text-transform:uppercase;letter-spacing:.1em;line-height:1.22;font-family:var(--fh,'Raleway',system-ui),system-ui,sans-serif;color:#fff;opacity:0;transform:translate(-50%,calc(-50% + 10px));transition:opacity .65s ease,transform .65s ease;pointer-events:none}.fq-phrase::after,.fq-phrase::before{content:"« ";font-weight:800;letter-spacing:.02em}.fq-phrase::after{content:" »"}.fq-phrase.active{opacity:1;transform:translate(-50%,-50%)}.fq-phrase strong,.fq-phrase b,.fq-phrase em,.fq-phrase i,.fq-phrase u{color:inherit;font-weight:inherit;font-style:inherit;border-bottom:none;text-decoration:none;padding-bottom:0;background:none;box-shadow:none}.fq-dot,.fq-dots{display:none!important}@media (max-width:640px){.footer-quotes{padding:36px 0 40px}.footer-quotes-inner{padding:0 18px}.fq-text-wrap{min-height:120px}.fq-phrase{font-size:clamp(11px,3.6vw,17px);letter-spacing:.08em;line-height:1.3;padding:0 12px;font-weight:800}}.reviews-section{padding:80px 0 0}.reviews-header{margin-bottom:44px}.reviews-track{overflow:hidden;margin:0;border-radius:16px}.reviews-inner{display:flex;gap:16px;padding:4px 2px 16px;transition:transform .55s cubic-bezier(.4,0,.2,1);will-change:transform}.review-card{flex:0 0 calc(33.333% - 11px);min-width:0;background:rgba(255,255,255,.07);backdrop-filter:blur(16px) saturate(160%);-webkit-backdrop-filter:blur(16px) saturate(160%);border:1px solid rgba(255,255,255,.1);border-radius:18px;padding:26px 24px 22px;position:relative;overflow:hidden;box-shadow:0 4px 20px rgba(0,0,0,.15),inset 0 1px 0 rgba(255,255,255,.07);transition:transform .3s,box-shadow .3s,background .3s;display:flex;flex-direction:column;gap:14px}.review-card::before{content:'"';position:absolute;top:10px;right:18px;font-size:64px;line-height:1;font-family:Georgia,serif;color:rgba(255,255,255,.05);pointer-events:none}.review-card:hover{transform:translateY(-4px);background:rgba(255,255,255,.11);box-shadow:0 14px 40px rgba(0,0,0,.25),inset 0 1px 0 rgba(255,255,255,.1)}.rc-avatar,.rc-head{display:flex;align-items:center;flex-shrink:0}.rc-head{gap:11px}.rc-avatar{width:42px;height:42px;border-radius:50%;justify-content:center;font-family:var(--fh);font-weight:800;font-size:16px;color:#fff;border:1.5px solid rgba(255,255,255,.15)}.rc-info{flex:1;min-width:0}.rc-name{font-weight:700;font-size:14.5px;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rc-meta{display:flex;align-items:center;gap:5px;margin-top:2px}.rc-flag{font-size:13px}.rc-country,.rc-date{font-size:12px;color:rgba(255,255,255,.42)}.rc-date{color:rgba(255,255,255,.32);margin-left:auto}.rc-stars{display:flex;gap:2px;flex-shrink:0}.rc-stars span{color:var(--sand);font-size:13px}.rc-text{font-size:14px;line-height:1.7;color:rgba(255,255,255,.76);flex:1;display:-webkit-box;-webkit-line-clamp:5;-webkit-box-orient:vertical;overflow:hidden}.rc-text.expanded{-webkit-line-clamp:unset;cursor:default}.rc-verified{display:inline-flex;align-items:center;gap:4px;font-size:11px;color:rgba(255,255,255,.32);flex-shrink:0}.rc-verified svg{color:#4285f4}.rev-arrow,.reviews-nav{display:flex;align-items:center;justify-content:center}.reviews-nav{gap:12px}.rev-arrow{width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.08);border:1.5px solid rgba(255,255,255,.14);color:rgba(255,255,255,.7);cursor:pointer;transition:background .2s,color .2s,transform .2s,border-color .2s;flex-shrink:0}.rev-arrow:hover:not(:disabled){background:var(--fire);border-color:var(--fire);color:#fff;transform:scale(1.06)}.rev-arrow:disabled{opacity:.28;cursor:not-allowed;pointer-events:none}.rev-arrow svg{width:18px;height:18px}.rev-dots{display:flex;gap:6px;align-items:center}.reviews-nav{display:none!important;height:0!important;margin:0!important;padding:0!important;overflow:hidden!important;visibility:hidden!important;pointer-events:none!important}.reviews-cta{display:flex;justify-content:center;gap:14px;margin-top:32px;flex-wrap:wrap}.google-cta-btn{display:inline-flex;align-items:center;gap:8px;padding:11px 20px;border-radius:var(--r-pill);background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);color:rgba(255,255,255,.78);font-size:13.5px;font-weight:600;transition:background .2s,color .2s,transform .2s}.google-cta-btn:hover{background:rgba(255,255,255,.16);color:#fff;transform:translateY(-1px)}.google-cta-btn svg{width:16px;height:16px;flex-shrink:0}.reviews-rating-badge{padding:16px 20px;border-radius:18px;background:rgba(255,255,255,.07);backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.12);text-align:center;min-width:110px;box-shadow:0 4px 20px rgba(0,0,0,.2),inset 0 1px 0 rgba(255,255,255,.07)}.reviews-score{font-family:var(--fh);font-size:44px;font-weight:900;line-height:1;background:linear-gradient(135deg,var(--sand),#fff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.reviews-stars-header{display:flex;gap:3px;justify-content:center;margin:4px 0 2px}.reviews-stars-header span{font-size:16px;color:var(--sand)}.reviews-count{font-size:12px;opacity:.5}.google-badge{display:flex;align-items:center;justify-content:center;gap:5px;font-size:11px;color:rgba(255,255,255,.45);margin-top:5px}.google-badge svg{width:14px;height:14px}@media (max-width:960px){.review-card{flex:0 0 calc(50% - 8px)}}@media (max-width:600px){.review-card{flex:0 0 calc(100% - 0px)}.reviews-header{flex-direction:column;align-items:flex-start}}*,::after,::before{box-sizing:border-box}iframe,video{max-width:100%}@media (max-width:900px){#booking-section .split{gap:32px!important}.form-card{padding:22px!important}#booking-section .split,.form-row{grid-template-columns:1fr!important}}@media (max-width:768px){.hero-content{padding:0 20px}.hero-trust{flex-direction:column;align-items:center;gap:10px}.trust-badge{font-size:11.5px;padding:7px 14px}.hero-cta{flex-direction:column;align-items:stretch}.hero-cta .btn{width:100%;justify-content:center}.hero-h1{letter-spacing:-.03em}.nav-wa-label{display:none!important}.nav-right{gap:6px}.lang-dd-btn{padding:6px 8px;font-size:12px}}@media (max-width:960px){.reviews-header{flex-direction:column;align-items:flex-start;gap:20px}.reviews-rating-badge{align-self:flex-start}}@media (max-width:600px){.reviews-section{padding:60px 0 0}.reviews-rating-badge{padding:12px 16px}.reviews-score{font-size:36px}.review-card{padding:20px 18px 16px}.rc-text{font-size:13.5px}.rev-dots{display:none}}@media (max-width:640px){.blog-grid{grid-template-columns:1fr!important}}@media (max-width:768px){.art-lang-bar{padding:12px 14px;gap:6px;flex-wrap:wrap}.lang-pill{padding:5px 10px;font-size:12px}.author-card{padding:16px 18px;gap:12px}.author-avatar{width:50px;height:50px}.article-faq-q{padding:16px 18px;font-size:14.5px}.article-faq-answer .faq-answer-inner{padding:14px 18px 18px 44px}.art-cta{padding:28px 20px}.art-cta h2{font-size:20px}.share-row{gap:8px}.share-btn{padding:8px 14px;font-size:12.5px}.pull-quote .pq-txt{font-size:17px}.vblock{padding:16px 18px;gap:12px}.prose h1{font-size:clamp(22px,6vw,36px)}.prose h2{font-size:clamp(18px,5vw,26px)}.prose li,.prose p{font-size:16px}}@media (max-width:640px){.article-faq-section{border-radius:12px}}@media (max-width:1024px){.faq-layout{grid-template-columns:1fr;gap:28px}.faq-sidebar{position:relative;top:auto}}@media (max-width:640px){.footer-bottom{flex-direction:column;align-items:flex-start;gap:12px}}@media (max-width:480px){.footer-quotes-inner{flex-direction:column;gap:8px;padding:0 16px}.fq-icon{display:none}.fq-dots{flex-direction:row}}@media (max-width:640px){.cta-band{padding:64px 0}.cta-band h2{font-size:clamp(22px,6vw,36px)}.cta-btns{flex-direction:column;align-items:center;gap:12px}.cta-btns .btn{width:100%;max-width:320px;justify-content:center}.page-header{padding:120px 20px 60px}.page-header h1{font-size:clamp(26px,7vw,44px)}.page-header p{font-size:16px}}@media (max-width:900px){.split{grid-template-columns:1fr!important;gap:36px!important}.split-img img{height:260px!important}}@media (max-width:640px){.grid-2,.grid-3{grid-template-columns:1fr}}@media (max-width:480px){.container,.container-sm{padding:0 16px}.section{padding:56px 0}}.home-proof-strip{background:linear-gradient(180deg,#e8eef4 0,#f2f5f9 40%,#f8fafc 100%);position:relative;z-index:4;padding:32px 0 36px;border-bottom:1px solid rgba(10,37,64,.07)}.home-proof-eyebrow{font-size:12px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--fire);margin:0 0 18px}.home-proof-grid{display:grid;grid-template-columns:1fr minmax(260px,340px);gap:24px 32px;align-items:stretch;margin-bottom:8px}.home-proof-facts{display:flex;flex-direction:column;gap:14px}.home-proof-fact{display:flex;align-items:flex-start;gap:16px;padding:14px 18px;background:rgba(255,255,255,.72);border:1px solid rgba(10,37,64,.08);border-radius:14px;box-shadow:0 2px 12px rgba(10,37,64,.04)}.home-proof-fact-n{font-family:var(--fh);font-weight:900;font-size:26px;line-height:1;color:var(--navy);min-width:44px;padding-top:2px}.home-proof-fact-body{display:flex;flex-direction:column;gap:4px;min-width:0}.home-proof-fact-t{font-weight:700;font-size:15px;color:var(--navy)}.home-proof-fact-d{font-size:13px;line-height:1.45;color:#64748b}.home-proof-strip.home-proof--visible .home-proof-fact{animation:trustSlideUp .65s cubic-bezier(.22,1,.36,1) backwards}.home-proof-strip.home-proof--visible .home-proof-fact:nth-child(1){animation-delay:.04s}.home-proof-strip.home-proof--visible .home-proof-fact:nth-child(2){animation-delay:.1s}.home-proof-strip.home-proof--visible .home-proof-fact:nth-child(3){animation-delay:.16s}@media (prefers-reduced-motion:reduce){.home-proof-strip.home-proof--visible .home-proof-fact{animation:none!important}}@media (max-width:900px){.home-proof-grid{grid-template-columns:1fr}}@media (max-width:600px){.home-proof-strip{padding:26px 0 30px}.home-proof-fact{padding:12px 14px}.home-proof-fact-n{font-size:22px;min-width:38px}}.gh-ts{background:#fff}.gh-ts-l{color:var(--muted)}@media (max-width:768px){.gh-teaser-inner{grid-template-columns:1fr;gap:32px}.gh-teaser-map-preview{height:220px}.gh-teaser-stats{gap:12px}}.gh-video-card video{width:100%;height:100%;object-fit:cover;display:block}.home-gallery-sec{padding:0;background:var(--bg-light);margin-top:-2px}.hg-inner{max-width:var(--max);margin:0 auto;padding:40px 32px 0;display:grid;grid-template-columns:300px 1fr;gap:56px;align-items:center}.hg-copy{display:flex;flex-direction:column;gap:0}.hg-copy .s-label{margin-bottom:14px}.hg-title{font-size:clamp(22px,2.8vw,34px);font-weight:800;color:var(--navy);line-height:1.18;margin:0 0 28px}.hg-count-wrap{display:flex;align-items:baseline;gap:6px;margin-bottom:32px;font-family:var(--font-head)}.hg-cur-num{font-size:48px;font-weight:800;color:var(--navy);line-height:1;letter-spacing:-.02em}.hg-sep{font-size:18px;color:rgba(10,37,64,.28);font-weight:400;margin:0 2px}.hg-tot-num{font-size:18px;color:rgba(10,37,64,.38);font-weight:600}.hg-cta-link{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:var(--fire);text-decoration:none;transition:gap .22s var(--ease);width:fit-content}.hg-cta-link:hover{gap:13px}.hg-cta-link svg{flex-shrink:0;transition:transform .22s var(--ease)}.hg-cta-link:hover svg{transform:translateX(3px)}.hg-frame-wrap{display:flex;flex-direction:column;gap:18px}.hg-frame{position:relative;width:100%;aspect-ratio:3/2;border-radius:18px;overflow:hidden;background:var(--navy);box-shadow:0 20px 56px rgba(7,25,46,.18),0 4px 16px rgba(7,25,46,.09);will-change:transform}.hg-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;opacity:0;transition:opacity .9s cubic-bezier(.4,0,.2,1);transform:none;user-select:none;-webkit-user-drag:none}.hg-img.hg-active{opacity:1;z-index:1}.hg-frame::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(7,25,46,.3)0,transparent 40%);z-index:2}.hg-frame-bar{position:absolute;bottom:0;left:0;right:0;height:3px;background:rgba(255,255,255,.14);z-index:5;overflow:hidden}.hg-progress-fill{height:100%;background:linear-gradient(90deg,var(--fire),var(--sand));width:0%;transition:width linear}.hg-controls{display:flex;align-items:center;justify-content:space-between;padding:0 4px}.hg-dots{display:flex;gap:7px;flex-wrap:wrap;max-width:75%}.hg-arrows{display:flex;gap:8px}.hg-btn{width:40px;height:40px;border-radius:50%;border:1.5px solid rgba(10,37,64,.14);background:#fff;color:var(--navy);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .2s,background .2s,transform .18s;flex-shrink:0}.hg-btn:hover{border-color:var(--navy);background:var(--navy);color:#fff;transform:scale(1.06)}.hg-btn:active{transform:scale(.94)}.hg-btn svg,.hg-frame::after{pointer-events:none}@media (max-width:900px){.hg-inner{grid-template-columns:1fr;gap:36px;padding:32px 24px 48px}.hg-copy{flex-direction:row;flex-wrap:wrap;align-items:flex-start;gap:20px}.hg-title{font-size:24px;margin-bottom:0;flex:1 1 200px}.hg-count-wrap{display:none}.hg-cta-link{margin-left:auto;align-self:center}.home-gallery-sec{padding:0}}@media (max-width:480px){.hg-inner{padding:24px 16px 40px}.hg-frame{border-radius:12px;aspect-ratio:4/3}.hg-copy{gap:12px}.hg-title{font-size:20px}}.vb-checklist li{padding:0!important}.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){display:block;padding:0;background:0 0;border:0;margin:32px 0}.cat-cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}@media (max-width:900px){.cat-cards-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:540px){.cat-cards-grid{grid-template-columns:1fr}}.cat-card{display:flex;flex-direction:column;gap:10px;background:#fff;border-radius:16px;padding:28px 24px;box-shadow:0 2px 16px rgba(10,37,64,.07);transition:transform .22s ease,box-shadow .22s ease;border-top:4px solid var(--fire)}.cat-card:hover{transform:translateY(-4px);box-shadow:0 8px 28px rgba(10,37,64,.12)}.cat-card-name{font-family:var(--f-head);font-size:18px;font-weight:800;color:var(--navy);margin:0;line-height:1.3}.cat-card-count{font-size:13px;font-weight:700;margin-top:4px}.breadcrumb{display:flex;align-items:center;flex-wrap:wrap;gap:6px;font-size:13px;color:#9ca3af;margin-bottom:20px}.breadcrumb a{color:var(--navy);text-decoration:none;font-weight:500}.breadcrumb a:hover{color:var(--fire);text-decoration:underline}.breadcrumb span[aria-current]{color:#374151;font-weight:600}.breadcrumb span[aria-hidden]{color:#d1d5db}.more-in-cat .related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}@media (max-width:820px){.more-in-cat .related-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:500px){.more-in-cat .related-grid{grid-template-columns:1fr}}.blog-filter-bar{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:2px}.blog-filter-bar::-webkit-scrollbar{display:none}.blog-filter-bar .container{flex-wrap:nowrap;padding-bottom:6px;padding-top:2px}.blog-filter-bar .btn{white-space:nowrap;flex-shrink:0;height:36px;padding:0 16px;display:inline-flex;align-items:center;justify-content:center}.booking-rv-card{background:#fff;border:1px solid rgba(10,37,64,.08);border-radius:16px;padding:24px;box-shadow:0 2px 12px rgba(10,37,64,.06);display:flex;flex-direction:column}.booking-rv-card .rc-head{display:flex;align-items:center;gap:12px;margin-bottom:0}.booking-rv-card .rc-avatar{width:44px;height:44px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-family:var(--fh);font-weight:800;font-size:17px;color:#fff}.booking-rv-card .rc-info{flex:1;min-width:0}.booking-rv-card .rc-name{font-weight:700;font-size:14.5px;color:var(--navy);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.booking-rv-card .rc-meta{display:flex;align-items:center;gap:5px;margin-top:3px}.booking-rv-card .rc-flag{font-size:13px}.booking-rv-card .rc-country{font-size:12px;color:#9ca3af}.booking-rv-card .rc-stars span{color:#e8a317}.booking-rv-card .rc-text{font-size:14px;line-height:1.65;color:#374151;-webkit-line-clamp:unset;overflow:visible;flex:1}.booking-rv-card .rc-verified{border-top:1px solid rgba(10,37,64,.06);padding-top:12px;margin-top:auto}[dir=rtl] body{font-family:"Noto Sans Arabic","Segoe UI",Tahoma,Geneva,Verdana,sans-serif;text-align:right}[dir=rtl] .nav-links{flex-direction:row-reverse}[dir=rtl] .footer-brand-text{text-align:right}[dir=rtl] .footer-social{justify-content:flex-start}[dir=rtl] .vb-checklist::before,[dir=rtl] .vb-expert::before,[dir=rtl] .vb-fact::before,[dir=rtl] .vb-tip::before{left:auto;right:0;border-radius:0 16px 16px 0}[dir=rtl] .vb-checklist,[dir=rtl] .vb-expert,[dir=rtl] .vb-fact,[dir=rtl] .vb-tip{padding-left:32px;padding-right:40px}[dir=rtl] .s-label{letter-spacing:0}[dir=rtl] .breadcrumb{flex-direction:row-reverse}[dir=rtl] .breadcrumb a::after{transform:scaleX(-1)}[dir=rtl] .form-group label{text-align:right}[dir=rtl] .booking-rv-card,[dir=rtl] input,[dir=rtl] select,[dir=rtl] textarea{text-align:right;direction:rtl}[dir=rtl] .rc-head,[dir=rtl] .rc-meta{flex-direction:row-reverse}[dir=rtl] .blog-card,[dir=rtl] .cat-card{text-align:right}[dir=rtl] .lb-controls{flex-direction:row-reverse}.booking-form-alert{margin-bottom:20px;padding:14px 16px;border-radius:12px;background:rgba(255,90,31,.1);border:1px solid rgba(255,90,31,.35);color:#9a3412;font-size:14px;line-height:1.5;font-weight:500}.booking-field-error{color:var(--fire);font-size:12.5px;margin-top:6px;font-weight:500}.form-input.form-invalid,.form-select.form-invalid{border-color:var(--fire)!important;box-shadow:0 0 0 3px rgba(255,90,31,.22)}.booking-success-overlay{position:fixed;inset:0;z-index:10000;background:rgba(6,18,32,.55);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:24px;opacity:0;visibility:hidden;transition:opacity .35s ease,visibility .35s ease}.booking-success-overlay.is-open{opacity:1;visibility:visible}.booking-success-card{background:#fff;border-radius:22px;padding:36px 28px 32px;max-width:420px;width:100%;text-align:center;box-shadow:0 28px 80px rgba(0,0,0,.22);transform:scale(.88) translateY(20px);opacity:0;transition:transform .5s cubic-bezier(.34,1.45,.64,1),opacity .4s ease}.booking-success-overlay.is-open .booking-success-card{transform:scale(1) translateY(0);opacity:1}.booking-success-check{width:76px;height:76px;margin:0 auto 18px;border-radius:50%;background:linear-gradient(145deg,#22c55e,#15803d);color:#fff;font-size:40px;font-weight:800;display:flex;align-items:center;justify-content:center;line-height:1;box-shadow:0 12px 32px rgba(34,197,94,.35);animation:booking-success-check-pop .65s cubic-bezier(.34,1.56,.64,1) .12s both}.booking-success-title{font-family:var(--fh);font-size:clamp(22px,4vw,28px);font-weight:800;color:var(--navy);margin:0 0 12px;line-height:1.2}.booking-success-text{font-size:15.5px;line-height:1.65;color:#374151;margin:0 0 14px}.booking-success-wa-note{font-size:13.5px;line-height:1.55;color:#6b7280;margin:0 0 8px}@media (prefers-reduced-motion:reduce){.booking-success-check{animation:none}.booking-success-card,.booking-success-overlay{transition:none}}@media (max-width:1024px){.faq-layout{display:grid!important;grid-template-columns:1fr!important;gap:28px!important}.faq-sidebar{position:relative!important;top:auto!important;width:100%!important}}@media (max-width:640px){.cat-badge,.hero-eyebrow,.reviews-header .s-label,.s-label,.split-img::before{font-size:12px!important}.footer-col h4,footer h4{font-size:11px;font-weight:800;letter-spacing:.15em;text-transform:uppercase;color:var(--sand,#e8c87a);margin-bottom:18px;opacity:.85}}@media (max-width:768px){.nav-inner{padding:0 12px;height:64px;display:flex;align-items:center}.nav-links{display:none}.nav-toggle{display:flex;order:99}.nav-right{margin-left:auto;display:flex;align-items:center;gap:8px}.nav-logo{flex-shrink:0}.nav-wa-label{display:none}}.hero-eyebrow{position:relative;z-index:1;margin-top:16px}.hero-content{padding-top:80px;padding-bottom:40px}@media (min-width:769px){.hero-content{padding-top:96px;padding-bottom:56px}}.home-proof-strip{margin-top:-2px;padding-top:32px;padding-bottom:32px}@media (max-width:480px){.ig-grid{grid-template-columns:repeat(3,1fr)!important;gap:2px!important}.ig-cell{border-radius:0!important}.ig-cell-overlay-lbl{font-size:9px!important}.ig-section{padding:40px 0 36px!important}.ig-section .container{padding:0 12px}.ig-bar{gap:10px;padding:10px 12px}.ig-follow-btn{font-size:12px;padding:6px 14px}.hero-h1{font-size:clamp(34px,10vw,56px)!important}.hero-sub{font-size:16px!important}.hero-cta{flex-direction:column;align-items:stretch}.hero-cta .btn{width:100%;justify-content:center}.hero-trust{gap:8px}.trust-badge{font-size:11.5px;padding:6px 12px}.container,.container-sm{padding:0 16px}.section{padding:64px 0}.page-header{padding:110px 16px 64px}}@media (max-width:768px){.split{gap:36px!important}#booking-section .split,.split{grid-template-columns:1fr!important}.split-img img{height:280px}.split-img{margin-bottom:0}}@media (max-width:480px){.blog-grid{grid-template-columns:1fr!important;gap:20px}.card-h3{font-size:17px}.cat-badge{font-size:12px!important}.gallery-masonry,.gallery-masonry--page{grid-template-columns:repeat(2,1fr)!important;gap:8px!important}}@media (max-width:640px){.review-card{flex:0 0 calc(100% - 0px)!important}.rc-text{font-size:14px!important}#booking-section .form-card{padding:24px 20px}.faq-a,.faq-q{padding:16px 18px;font-size:15px}.faq-a{padding:0 18px;line-height:1.72}.faq-item.open .faq-a{padding-top:8px;padding-bottom:22px}.faq-sidebar .s-label,.faq-sidebar [style*="11px"],footer .s-label{font-size:12px!important}.faq-sidebar div:first-child{font-size:12px!important}.article-faq-q{padding:16px 20px 16px 22px;font-size:15px}.article-faq-answer .faq-answer-inner{padding:14px 18px 18px 22px}.article-faq-answer p{font-size:15px;line-height:1.72}.art-hero-inner{padding:20px}.art-hero-inner h1{font-size:clamp(24px,7vw,38px)!important}.footer-brand{grid-column:1/-1}}@media (max-width:640px){.island-guide-hero .art-hero-inner h1{font-size:clamp(22px,6.5vw,36px)!important}table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch;max-width:100%}td,th{white-space:nowrap;font-size:13px}}.vb-checklist .vb-label,.vb-expert .vb-label,.vb-fact .vb-label,.vb-header .vb-label,.vb-label,.vb-summary .vb-label,.vb-tip .vb-label{font-size:12px!important}.ig-section{padding:80px 0 72px;background:#fff}.ig-section.sec-light{background:var(--bg-light, #ffffff)}.ig-header-left{display:flex;align-items:center;gap:16px}.ig-avatar-wrap{width:56px;height:56px;border-radius:50%;padding:2.5px;background:linear-gradient(135deg,#f09433 0,#e6683c 25%,#dc2743 50%,#cc2366 75%,#bc1888 100%);flex-shrink:0}.ig-avatar-inner,.ig-avatar-inner img{width:100%;height:100%;border-radius:50%}.ig-avatar-inner{background:#0a2540;display:flex;align-items:center;justify-content:center;overflow:hidden}.ig-avatar-inner img{object-fit:cover}.ig-meta{display:flex;flex-direction:column;gap:3px}.ig-handle{font-size:15px;font-weight:700;color:#0a2540;letter-spacing:-.01em}.ig-sub{font-size:12px;color:#6b7280;font-weight:400}.ig-follow-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 22px;border-radius:50px;font-size:13.5px;font-weight:700;color:#fff;text-decoration:none;background:linear-gradient(135deg,#f09433 0,#e6683c 20%,#dc2743 45%,#cc2366 75%,#bc1888 100%);transition:opacity .2s,transform .2s;white-space:nowrap}.ig-follow-btn:hover{opacity:.88;transform:translateY(-1px)}.ig-follow-btn svg{flex-shrink:0}.ig-intro{text-align:center;margin-bottom:28px}.ig-bar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;margin-bottom:24px;padding:14px 20px;background:rgba(255,255,255,.7);border:1px solid rgba(0,0,0,.06);border-radius:14px;backdrop-filter:blur(6px)}.ig-section.sec-light .ig-bar{background:rgba(255,255,255,.9)}.ig-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;border-radius:12px;overflow:hidden}.ig-cell{position:relative;overflow:hidden;display:block;background:#e8ecf0}.ig-cell::before{content:"";display:block;padding-top:100%}.ig-cell-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .5s cubic-bezier(.2,.8,.2,1);will-change:transform}.ig-cell-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(240,148,51,.78)0,rgba(220,39,67,.72) 50%,rgba(188,24,136,.78) 100%);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;opacity:0;transition:opacity .3s ease;color:#fff}.ig-cell-overlay-lbl{font-size:11.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.ig-cell:hover .ig-cell-img{transform:scale(1.07)}.ig-cell:hover .ig-cell-overlay{opacity:1}.ig-cta{text-align:center;margin-top:28px}.ig-cta-text{font-size:14.5px;color:#6b7280;margin:0;line-height:1.6}.ig-gallery-cta{margin-top:52px;padding:36px 40px;background:linear-gradient(135deg,#0a2540 0,#0f3460 60%,#1a2a5e 100%);border-radius:20px;position:relative;overflow:hidden}.ig-gallery-cta::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 80% 50%,rgba(240,148,51,.15)0,transparent 60%),radial-gradient(ellipse at 20% 50%,rgba(188,24,136,.12)0,transparent 55%);pointer-events:none}.ig-gallery-cta-inner{position:relative;display:flex;align-items:center;gap:24px;flex-wrap:wrap}.ig-gallery-cta-avatar{flex-shrink:0}.ig-gallery-cta-text{flex:1;min-width:180px}.ig-gallery-cta-handle{display:block;font-size:17px;font-weight:800;color:#fff;letter-spacing:-.01em;margin-bottom:4px}.ig-gallery-cta-sub{font-size:14px;color:rgba(255,255,255,.72);margin:0;line-height:1.5}.ig-gallery-cta-btn{flex-shrink:0;font-size:14.5px;padding:12px 28px}@media (max-width:600px){.ig-gallery-cta{padding:28px 20px}.ig-gallery-cta-inner{gap:16px}.ig-gallery-cta-btn{width:100%;justify-content:center}}@media (max-width:767px){.ig-grid{gap:3px}.ig-bar{padding:12px 14px}.ig-section{padding:52px 0 48px}}@media (max-width:480px){.ig-grid{grid-template-columns:repeat(3,1fr);gap:2px}.ig-bar{flex-direction:column;align-items:flex-start}.ig-avatar-wrap{width:44px;height:44px}.ig-handle{font-size:14px}.ig-follow-btn{padding:9px 16px;font-size:12.5px}.ig-cell-overlay-lbl{display:none}}.hg-img.hg-active{animation:hg-ken-burns 3.5s ease-out forwards!important;will-change:transform}.hg-caption{position:absolute;bottom:0;left:0;right:0;padding:32px 22px 20px;background:linear-gradient(to top,rgba(7,25,46,.78)0,transparent 100%);color:rgba(255,255,255,.9);font-size:13px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;z-index:6;pointer-events:none;opacity:0;transform:translateY(8px);transition:opacity .45s ease,transform .45s ease}.hg-caption.hg-cap-visible{opacity:1;transform:translateY(0)}.surf-story-sec{padding:88px 0}.surf-story-split{gap:72px!important;align-items:center!important}.surf-story-text{display:flex;flex-direction:column}.surf-story-p{font-size:17px;color:#374151;line-height:1.88;margin:0 0 18px}.surf-story-h2{margin-bottom:20px!important;line-height:1.18!important}.surf-story-img img{height:520px!important;width:100%!important;object-fit:cover!important;border-radius:var(--r-lg)!important}.surf-story-img::before{display:none!important}@media (max-width:860px){.surf-story-sec{padding:56px 0}.surf-story-split{gap:40px!important}.surf-story-img img{height:280px!important}}.surf-feat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;max-width:920px;margin:0 auto}.surf-feat-card{display:flex;flex-direction:column;align-items:center;text-align:center;padding:32px 18px 28px;border-radius:16px;background:#fff;box-shadow:var(--s-sm);transition:transform .25s var(--ease),box-shadow .25s var(--ease)}.surf-feat-card:hover{transform:translateY(-4px);box-shadow:var(--s-md)}.surf-feat-icon{width:44px;height:44px;margin-bottom:16px;flex-shrink:0}.fc-stat-icon svg,.sc-how-icon svg,.sc-stat-icon svg,.surf-feat-icon svg{width:100%;height:100%}.surf-feat-title{font-family:"Raleway",sans-serif;font-size:14px;font-weight:700;color:var(--navy);line-height:1.35;margin:0}.surf-level-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}@media (max-width:900px){.surf-level-grid{grid-template-columns:1fr;gap:20px}}.forecast-widget{max-width:940px;margin:0 auto}.fc-loading{display:flex;justify-content:center;padding:60px 0}.fc-spinner{width:32px;height:32px;border:2.5px solid rgba(10,37,64,.1);border-top-color:var(--fire);border-radius:50%;animation:fc-spin .75s linear infinite}.fc-now-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--fire);text-align:center;margin-bottom:20px}.fc-current{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-bottom:20px}@media (max-width:700px){.fc-current{grid-template-columns:repeat(3,1fr)}}@media (max-width:400px){.fc-current{grid-template-columns:repeat(2,1fr)}}.fc-stat{background:#fff;border-radius:14px;padding:20px 12px 16px;text-align:center;box-shadow:0 1px 0 rgba(10,37,64,.06),0 4px 16px rgba(10,37,64,.07);border:1px solid rgba(10,37,64,.05);transition:transform .2s var(--ease),box-shadow .2s var(--ease)}.fc-stat:hover{transform:translateY(-3px);box-shadow:0 8px 28px rgba(10,37,64,.12)}.fc-stat-icon{width:28px;height:28px;margin:0 auto 10px;display:flex;align-items:center;justify-content:center}.fc-stat-val{font-family:"Raleway",sans-serif;font-size:24px;font-weight:800;color:var(--navy);line-height:1.1}.fc-stat-unit{font-size:13px;font-weight:500;color:var(--muted);margin-left:1px}.fc-stat-lbl{font-size:10.5px;color:var(--muted);margin-top:5px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;line-height:1.3}.fc-chart-wrap{background:#fff;border-radius:16px;padding:22px 20px 14px;box-shadow:0 1px 0 rgba(10,37,64,.06),0 4px 16px rgba(10,37,64,.07);border:1px solid rgba(10,37,64,.05);overflow-x:auto;margin-bottom:0}.fc-chart-title{font-family:"Raleway",sans-serif;font-size:13px;font-weight:700;color:var(--navy);text-transform:uppercase;letter-spacing:.06em;margin:0 0 18px}.fc-chart{display:flex;gap:8px;min-width:480px}.fc-bar-group{flex:1;display:flex;flex-direction:column;align-items:center;gap:5px}.fc-bar-wrap{width:100%;height:88px;display:flex;align-items:flex-end;justify-content:center}.fc-bar{width:50%;max-width:28px;border-radius:5px 5px 0 0;min-height:5px;transition:height .5s var(--ease);position:relative}.fc-bar-day,.fc-bar-val{font-weight:700;color:var(--navy)}.fc-bar-val{position:absolute;top:-17px;left:50%;transform:translateX(-50%);font-size:10px;white-space:nowrap}.fc-bar-day{font-size:11px}.fc-bar-date{font-size:10px;color:var(--muted)}.fc-credit,.fc-err{text-align:center;color:var(--muted)}.fc-credit{margin-top:14px;font-size:10.5px;opacity:.6}.fc-credit a,.sc-powered a{color:var(--ocean);text-decoration:none}.fc-err{padding:40px 20px;font-size:14px}[dir=rtl] .fc-current{direction:rtl}[dir=rtl] .fc-chart{direction:ltr}.sc-pulse-dot{position:relative;padding-left:18px}.sc-pulse-dot::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:8px;height:8px;border-radius:50%;background:var(--fire);box-shadow:0 0 0 0 rgba(255,90,31,.5);animation:sc-pulse 2s ease-in-out infinite}.sc-now-label{text-align:center;margin-bottom:24px}.sc-stats-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;margin-bottom:20px}@media (max-width:900px){.sc-stats-grid{grid-template-columns:repeat(4,1fr)}}@media (max-width:540px){.sc-stats-grid{grid-template-columns:repeat(2,1fr)}}.sc-stat{background:#fff;border-radius:14px;padding:20px 10px 16px;text-align:center;box-shadow:0 1px 0 rgba(10,37,64,.05),0 4px 16px rgba(10,37,64,.07);border:1px solid rgba(10,37,64,.05);border-top:3px solid rgba(10,37,64,.08);transition:transform .2s var(--ease),box-shadow .2s var(--ease)}.sc-stat:hover{transform:translateY(-3px);box-shadow:0 8px 28px rgba(10,37,64,.12)}.sc-stat-icon{width:26px;height:26px;margin:0 auto 10px;display:flex;align-items:center;justify-content:center}.sc-stat-val{font-family:"Raleway",sans-serif;font-size:clamp(16px,2vw,24px);font-weight:800;color:var(--navy);line-height:1.1;word-break:break-all}.sc-stat-lbl{font-size:10px;color:var(--muted);margin-top:5px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;line-height:1.3}.sc-ctx-text{font-size:15px;line-height:1.75;color:var(--text);max-width:740px;margin:20px auto 0;text-align:center;padding:16px 22px;border-radius:12px;background:rgba(14,165,233,.06);border-left:3px solid var(--ocean)}[dir=rtl] .sc-ctx-text{border-left:none;border-right:3px solid var(--ocean)}.sc-fc-note,.sc-powered{color:var(--muted);text-align:center}.sc-powered{margin-top:14px;font-size:10.5px;opacity:.6}.sc-fc-note{font-size:13.5px;margin-top:8px;max-width:600px;margin-left:auto;margin-right:auto}.sc-forecast-strip{overflow-x:auto;padding-bottom:8px}.sc-fc-row{display:flex;gap:8px;min-width:900px}.sc-fc-card{flex:1;min-width:64px;background:#fff;border-radius:12px;padding:12px 6px;text-align:center;box-shadow:0 2px 10px rgba(10,37,64,.06);border:1.5px solid rgba(10,37,64,.06);border-top:3px solid rgba(10,37,64,.1);transition:transform .18s var(--ease);position:relative}.sc-fc-card:hover{transform:translateY(-2px)}.sc-fc-card.sc-fc-good{border-top-color:var(--ocean)}.sc-fc-card.sc-fc-fair{border-top-color:var(--fire)}.sc-fc-card.sc-fc-small{border-top-color:rgba(10,37,64,.15)}.sc-fc-dim{opacity:.65}.sc-fc-day{font-size:10px;font-weight:700;color:var(--navy);text-transform:uppercase;letter-spacing:.06em}.sc-fc-date{font-size:9.5px;color:var(--muted);margin:2px 0 6px}.sc-fc-bar-wrap{width:100%;height:64px;display:flex;align-items:flex-end;justify-content:center;margin-bottom:5px}.sc-fc-bar{width:45%;max-width:18px;border-radius:4px 4px 0 0;min-height:4px;transition:height .4s var(--ease)}.sc-fc-bar,.sc-fc-good .sc-fc-bar{background:linear-gradient(to top,var(--ocean),#7dd3fc)}.sc-fc-fair .sc-fc-bar{background:linear-gradient(to top,var(--fire),#fdba74)}.sc-fc-small .sc-fc-bar{background:linear-gradient(to top,#64748b,#cbd5e1)}.sc-fc-wh{font-family:"Raleway",sans-serif;font-size:14px;font-weight:800;color:var(--navy)}.sc-fc-wind{font-size:9.5px;color:var(--muted);margin-top:3px}.sc-fc-acc-badge{font-size:8px;color:var(--fire);font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-top:3px;min-height:12px}.sc-err{text-align:center;color:var(--muted);padding:32px 0;font-size:14px}.sc-seas-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:0}@media (max-width:700px){.sc-seas-grid{grid-template-columns:1fr}}.sc-seas-card{border-radius:16px;padding:28px 24px;background:#fff;box-shadow:0 2px 16px rgba(10,37,64,.07);border:1px solid rgba(10,37,64,.05);border-top:4px solid var(--ocean)}.sc-seas-trans{border-top-color:var(--fire)}.sc-seas-sum{border-top-color:rgba(10,37,64,.2)}.sc-seas-badge{display:inline-block;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--ocean);margin-bottom:8px}.sc-seas-trans .sc-seas-badge,.vb-tip strong{color:var(--fire)}.sc-seas-sum .sc-seas-badge{color:var(--muted)}.footer-col a,.sc-seas-months{margin-bottom:12px;line-height:1.4}.sc-seas-months{font-family:"Raleway",sans-serif;font-size:13px;font-weight:700;color:var(--navy)}.sc-how-card p,.sc-seas-card p{font-size:13.5px;color:var(--muted);line-height:1.65;margin:0}.sc-tabs{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-bottom:24px}.sc-how-card h3,.sc-tab{font-family:"Raleway",sans-serif;font-weight:700}.sc-tab{font-size:12.5px;padding:8px 20px;border-radius:var(--r-pill);border:1.5px solid rgba(10,37,64,.15);background:0 0;color:var(--muted);cursor:pointer;transition:all .2s var(--ease)}.sc-tab:hover{border-color:var(--navy);color:var(--navy)}.sc-tab.active{background:var(--navy);color:#fff;border-color:var(--navy)}.sc-chart-wrap{background:#fff;border-radius:16px;padding:24px 20px 16px;box-shadow:0 2px 16px rgba(10,37,64,.07);border:1px solid rgba(10,37,64,.05)}@media (max-width:767px){.sc-tabs{flex-wrap:nowrap;overflow-x:auto;justify-content:flex-start;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:4px}.sc-tabs::-webkit-scrollbar{display:none}.sc-tab{flex-shrink:0;font-size:11.5px;padding:7px 14px}.sc-chart-wrap{padding:12px 8px 8px}}.sc-radar-wrap{max-width:540px;margin:0 auto;background:#fff;border-radius:16px;padding:24px;box-shadow:0 2px 16px rgba(10,37,64,.07);border:1px solid rgba(10,37,64,.05)}.sc-radar-note{text-align:center;margin-top:16px;font-size:12px;color:var(--muted);max-width:600px;margin-left:auto;margin-right:auto;opacity:.75}.sc-how-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}@media (max-width:700px){.sc-how-grid{grid-template-columns:1fr}}.sc-how-card{border-radius:14px;padding:24px 20px;background:var(--sand3,#fff8ec);border:1px solid rgba(10,37,64,.05)}.sc-how-icon{width:28px;height:28px;margin-bottom:14px}.sc-how-card h3{font-size:14px;color:var(--navy);margin-bottom:8px}.sc-how-card p{font-size:13px}.sc-text-block{max-width:820px}[dir=rtl] .sc-stats-grid{direction:rtl}[dir=rtl] .sc-fc-row{direction:ltr}[dir=rtl] .sc-tabs{direction:rtl}[dir=rtl] .sc-ctx-text{text-align:right}[dir=rtl] .sc-how-grid{direction:rtl}.footer-gmb-badge,.footer-gmb-logo{display:inline-flex;align-items:center}.footer-gmb-badge{gap:7px;margin-top:16px;padding:9px 14px;border-radius:40px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.13);color:rgba(255,255,255,.85);font-size:13px;font-weight:500;text-decoration:none;transition:background .25s ease,border-color .25s ease,color .25s ease;backdrop-filter:blur(6px);white-space:nowrap}.footer-gmb-badge:hover{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.22);color:#fff}.footer-gmb-logo{flex-shrink:0}.footer-gmb-stars{color:#fbbc04;font-size:12px;letter-spacing:1px;line-height:1}.footer-gmb-score{font-weight:700;color:#fff;font-size:14px}.footer-gmb-count{color:rgba(255,255,255,.6);font-size:12px}.gallery-filter-bar{display:flex;align-items:center;flex-wrap:wrap;gap:10px;margin-bottom:32px;padding:4px 0}.gallery-filter-label{font-weight:600;color:var(--clr-navy);opacity:.6;white-space:nowrap;text-transform:uppercase;letter-spacing:.06em}.gallery-tag-btns{display:flex;flex-wrap:wrap;gap:8px}.gal-tag{padding:6px 16px;border-radius:20px;border:1.5px solid rgba(7,25,46,.15);background:#fff;color:var(--clr-navy);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.gal-tag:hover{border-color:var(--clr-brand);color:var(--clr-brand)}.gal-tag.active{background:var(--clr-navy);border-color:var(--clr-navy);color:#fff}@media (max-width:900px){.gallery-tag-btns{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;padding-bottom:2px}.gallery-tag-btns::-webkit-scrollbar{display:none}.gal-tag{flex-shrink:0}}.gallery-item.gal-hidden{display:none!important}.gallery-item.gal-visible{display:block}.gallery-item[hidden]{display:none!important}.gallery-count{font-size:13px;color:rgba(7,25,46,.5);margin-left:auto;align-self:center}.footer-col-title{font-size:11px;font-weight:800;letter-spacing:.15em;text-transform:uppercase;color:var(--sand,#e8c87a);opacity:.85}.footer-col-title{margin:0 0 18px;padding-top:12px;display:block}.footer-col a{display:block;font-size:14px;color:rgba(255,255,255,.55);transition:color var(--t),transform .2s var(--spring)}.footer-col a:hover{color:#fff;transform:translateX(4px)}.island-discover-card{cursor:default;box-shadow:0 4px 24px rgba(7,25,46,.06)}.island-discover-card:hover{transform:none!important;box-shadow:0 4px 24px rgba(7,25,46,.06)!important}.island-discover-card:hover .card-img{transform:none!important}@media (max-width:900px){#nav-links.open{display:flex!important;flex-direction:column;position:absolute;top:0;left:0;right:0;height:100vh;height:100svh;background:rgba(6,16,30,.97);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);z-index:1000;padding:80px 28px 40px;gap:4px;overflow-y:auto;animation:fadeSlideUp .22s var(--ease) both}#nav-links.open .nav-link{font-size:20px;font-weight:600;padding:16px 20px;border-radius:14px;border-bottom:1px solid rgba(255,255,255,.07);min-height:56px}#nav-links.open .nav-cta{margin-top:16px;text-align:center;justify-content:center;font-size:16px;padding:16px 32px}.nav-toggle.active{background:rgba(255,255,255,.18)}#nav{z-index:1001;overflow:visible}}.btn,.faq-q,.footer-pp-link,.gallery-item,.lang-dd-btn,.lang-dd-item,.nav-link,.nav-toggle,.nav-wa{min-height:44px}@media (hover:none){.btn:hover{transform:none}.card:hover{box-shadow:var(--s-sm)}.gallery-item:hover{transform:none}}.nav-link{display:flex;align-items:center}@media (hover:none){.btn:hover{transform:none}.card:hover{box-shadow:var(--s-sm)}.gallery-item:hover{transform:none}}@media (max-width:768px){.section{padding:56px 0}.split{grid-template-columns:1fr;gap:32px}.split-img img{height:260px}.main-hero-h1{font-size:clamp(28px,9vw,44px)}.main-hero-tagline{font-size:14px}.main-hero-actions{gap:10px}.cta-band{padding:56px 0}.container{padding:0 18px}.s-title{font-size:clamp(24px,6vw,38px)}}@media (max-width:400px){.main-hero-h1{font-size:28px}.btn-lg{padding:13px 24px;font-size:13px}.nav-inner{padding:0 16px;height:60px}.nav-logo img{height:36px}}.island-discover-card{display:flex;flex-direction:column}.island-discover-card .card-img{height:210px;flex-shrink:0;object-fit:cover;object-position:center;width:100%}.footer-fss-logo-wrap{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:#e8e8e0;border-radius:50%;overflow:hidden;padding:3px}.footer-fss-logo-wrap img{width:38px;height:38px;object-fit:contain;display:block}.footer-fss-text{display:flex;flex-direction:column;gap:2px;min-width:0;overflow:hidden}.footer-fss-title{font-size:11px;font-weight:800;color:#fff;letter-spacing:.04em;text-transform:uppercase;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.footer-fss-sub{font-size:10px;color:var(--sand);opacity:.85;line-height:1.35;white-space:normal}[dir=rtl] .footer-fss-text{text-align:right}@media (max-width:540px){.home-proof-grid{grid-template-columns:1fr!important;gap:16px!important}}.sc-fc-scroll-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin;padding-bottom:4px}@media (max-width:900px){.sc-fc-scroll-wrap{margin:0-4px;padding:0 4px 8px}}@media (max-width:480px){.ig-cell-overlay-lbl{font-size:11px!important}}.gallery-filter-label{font-size:11px!important}img{max-width:100%;height:auto}.card-img{aspect-ratio:16/10;width:100%;object-fit:cover;display:block}@media (max-width:480px){.gal-tag{min-height:36px;padding:6px 12px;font-size:12px}}.btn-ocean{background:var(--navy);color:#fff;border:2px solid var(--navy);transition:background .25s ease,transform .2s var(--spring),box-shadow .25s ease;box-shadow:0 4px 18px rgba(10,37,64,.18)}.btn-ocean:hover{background:#0d2d52;border-color:#0d2d52;color:#fff;transform:translateY(-3px);box-shadow:0 8px 28px rgba(10,37,64,.25)}.btn-ocean svg{transition:transform .25s var(--spring)}.btn-ocean:hover svg{transform:translateX(5px)}@media (max-width:900px){.footer-brand{grid-column:1/-1;max-width:100%}.footer-gmb-badge{white-space:normal}}.footer-top{display:grid;grid-template-columns:1.8fr 2.6fr;gap:40px 56px;margin-bottom:40px;align-items:start}.footer-links-row{display:grid;grid-template-columns:1fr 1.4fr 1fr;gap:0 40px;align-items:start}.footer-accred{display:flex;align-items:center;gap:12px;padding:12px 16px;margin-bottom:32px;border-radius:12px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);max-width:320px}.footer-accred .footer-fss-logo-wrap{width:40px;height:40px;flex-shrink:0}.footer-accred .footer-fss-title{font-size:12.5px;font-weight:700;display:block;color:#fff}.footer-accred .footer-fss-sub{font-size:11px;opacity:.6;display:block;margin-top:2px;color:var(--sand,#c8a96e)}@media (max-width:660px){footer{padding-top:40px;padding-bottom:0}.footer-top{display:block;margin-bottom:0}.footer-brand{padding-bottom:0;margin-bottom:0;max-width:100%}.footer-brand-logo{height:44px}.footer .footer-brand>p,.footer-brand-text{font-size:13.5px;margin-top:12px;line-height:1.65;opacity:.65}.footer-social{margin-top:18px;padding-top:0;border-top:none}.footer-gmb-badge{margin-top:14px;display:inline-flex}.footer-links-row{display:flex;flex-direction:row;gap:0 32px;margin-top:28px;padding-top:28px;border-top:1px solid rgba(255,255,255,.08)}.footer-col{flex:1;min-width:0}.footer-col .footer-col-title,.footer-col h4{font-size:10px;margin-bottom:12px;letter-spacing:.14em}.footer-col a{font-size:13.5px;margin-bottom:10px;display:block;line-height:1.4}.footer-accred{max-width:100%;margin-top:20px;margin-bottom:0;border-radius:10px}.footer-col a:last-child{margin-bottom:0}.footer-bottom{flex-direction:column;align-items:flex-start;text-align:left;gap:0;margin-top:20px;padding-top:18px;padding-bottom:32px;border-top:1px solid rgba(255,255,255,.08)}.footer-bottom p{font-size:12px;opacity:.4;line-height:1.6}}@media (max-width:480px){.vb-checklist,.vb-fact,.vb-tip{padding:20px}.vb-expert{padding:24px 20px 20px}.vb-summary{padding:24px 20px}.vb-expert::before{left:12px}}.gh-video-section{padding:60px 0 0}.gh-video-card{position:relative;width:100%;max-width:400px;margin:0 auto;border-radius:20px;overflow:hidden;box-shadow:0 12px 48px rgba(10,37,64,.22);background:#000;aspect-ratio:9/16}.gh-video-overlay{position:absolute;bottom:0;left:0;right:0;padding:24px 28px;background:linear-gradient(to top,rgba(0,0,0,.72)0,transparent 100%);color:#fff;pointer-events:none}.gh-video-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.15);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.25);border-radius:50px;padding:5px 14px;font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;margin-bottom:10px;color:#fff}.gh-video-title{font-family:var(--fh);font-size:clamp(18px,2.2vw,26px);font-weight:800;color:#fff;margin:0 0 4px;line-height:1.2}.gh-video-sub{font-size:13.5px;color:rgba(255,255,255,.8);margin:0}.gh-video-card::before{content:"";position:absolute;inset:0;opacity:0;transition:opacity .2s}.gh-osm-map{width:100%;height:460px;border:0;display:block;filter:saturate(.85) contrast(1.05)}@media (max-width:768px){.gh-video-card{max-width:100%;border-radius:12px;aspect-ratio:4/3;max-height:55vh}.gh-video-section{padding:40px 0 0}.gh-osm-map{height:320px}}.surf-spots-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:48px}@media (max-width:640px){.surf-spots-grid{grid-template-columns:1fr}}.surf-spot-card{--spot-accent:var(--navy);background:#fff;border-radius:20px;padding:36px 32px 30px;box-shadow:0 2px 16px rgba(7,25,46,.07);border-top:3px solid var(--spot-accent);position:relative;transition:transform .3s ease,box-shadow .3s ease}.surf-spot-card:hover{transform:translateY(-5px);box-shadow:0 12px 40px rgba(7,25,46,.13)}.surf-spot-num{display:block;font-size:3.8rem;font-weight:900;line-height:1;margin-bottom:18px;color:var(--spot-accent);opacity:.13;letter-spacing:-.02em}.surf-spot-name{font-size:1.2rem;font-weight:700;color:var(--navy);margin-bottom:12px;line-height:1.3}.surf-spot-desc{font-size:.97rem;color:var(--text-light);line-height:1.68;margin:0}#ngor-map{border-radius:0}.leaflet-container{background:#e8eaed}@media (max-width:768px){#ngor-map{height:320px}}.gh-teaser{padding:88px 0;position:relative}.gh-teaser-inner{display:grid;grid-template-columns:5fr 6fr;gap:64px;align-items:center}.gh-teaser-info{position:relative;z-index:1}.gh-teaser-map-preview{border-radius:20px;overflow:hidden;position:relative;height:440px;box-shadow:0 20px 50px rgba(10,37,64,.13);background:#e8eaed;border:1px solid rgba(10,37,64,.08)}.gh-teaser-map-preview .leaflet-container{width:100%!important;height:100%!important;background:#e8eaed!important}.gh-teaser-map-preview .leaflet-control-attribution{font-size:10px;background:rgba(255,255,255,.85)!important}#gh-teaser-map{width:100%;height:100%;min-height:440px;z-index:1}.gh-teaser-stats{display:flex;gap:16px;margin:24px 0 32px;flex-wrap:wrap}.gh-ts{display:flex;flex-direction:column;padding:14px 18px;background:#f8fafd;border-radius:12px;border:1px solid rgba(10,37,64,.09);box-shadow:0 2px 10px rgba(10,37,64,.06);min-width:80px}.gh-ts-n{font-family:var(--fh);font-size:22px;font-weight:900;color:var(--fire);line-height:1}.gh-ts-l{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted,#64748b);margin-top:4px;font-weight:600}.map-section{padding:80px 0 0}.map-label-wrap{max-width:var(--max,1280px);margin:0 auto;padding:0 32px 40px}#ngor-map{height:480px;position:relative;z-index:1;overflow:hidden}@media (max-width:900px){.gh-teaser-inner{grid-template-columns:1fr;gap:36px}.gh-teaser-map-preview{height:300px}#gh-teaser-map{min-height:300px}.map-label-wrap{padding:0 20px 28px}#ngor-map{height:320px}}@media (max-width:640px){.gh-teaser{padding:56px 0}.gh-teaser-map-preview{height:240px}#gh-teaser-map{min-height:240px}}.sh2-stats-strip{background:var(--navy);padding:18px 28px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.sh2-stats-strip::-webkit-scrollbar{display:none}.sh2-stat,.sh2-stats-inner{display:flex;align-items:center}.sh2-stats-inner{max-width:1140px;margin:0 auto;justify-content:center;gap:0;flex-wrap:nowrap;min-width:min-content}.sh2-stat{flex-direction:column;gap:2px;padding:6px 32px;text-align:center;flex-shrink:0}.sh2-stat-num{font-size:clamp(16px,2vw,24px);font-weight:900;color:#fff;line-height:1;font-family:var(--fh)}.sh2-stat-lbl{font-size:10px;font-weight:600;color:var(--sand);letter-spacing:.12em;text-transform:uppercase;opacity:.85;white-space:nowrap}.sh2-stat-sep{width:1px;height:36px;background:rgba(255,255,255,.12);flex-shrink:0}.sh2-split-section{display:flex;justify-content:center;background:#fff;overflow:hidden;min-height:500px}.sh2-split-grid{width:100%;max-width:var(--max);display:grid;grid-template-columns:1fr 1fr;gap:0;align-items:stretch}.sh2-split-left .sh2-split-media{order:1}.sh2-split-left .sh2-split-copy,.sh2-split-right .sh2-split-media{order:2}.sh2-split-right .sh2-split-copy{order:1;align-items:flex-end}.sh2-split-copy{display:flex;flex-direction:column;align-items:center;background:0 0;padding:0}.sh2-split-copy-inner{width:100%;padding:72px 48px;display:flex;flex-direction:column;gap:16px}.sh2-split-h2{font-size:clamp(22px,2.6vw,34px);font-weight:900;color:var(--navy);line-height:1.18;margin:0}.sh2-split-lead{font-size:15.5px;font-weight:600;color:#334155;margin:0}.sh2-split-accent{font-size:clamp(17px,1.8vw,22px);font-weight:800;font-style:italic;color:var(--fire);margin:0}.sh2-split-body{font-size:15px;line-height:1.85;color:#475569;margin:0}.sh2-split-media{position:relative;overflow:hidden;background:#fff}.sh2-duo{position:relative;width:100%;height:100%;min-height:480px}.sh2-duo-main,.sh2-duo-over{position:absolute;overflow:hidden}.sh2-duo-main{inset:0}.sh2-duo-main img,.sh2-duo-over img{width:100%;height:100%;object-fit:cover;transition:transform .7s cubic-bezier(.2,.8,.2,1)}.sh2-duo-over{width:48%;border-radius:14px;box-shadow:0 18px 44px rgba(0,0,0,.4);z-index:2;transition:transform .5s cubic-bezier(.2,.8,.2,1),box-shadow .5s;border:4px solid #fff;bottom:36px;right:-14px}.sh2-duo-over--tr{top:36px;bottom:auto;right:-14px}.sh2-duo-over img{aspect-ratio:4/3;display:block}.sh2-img-hover{cursor:zoom-in}.sh2-split-media:hover .sh2-duo-over{transform:translateY(-6px) scale(1.02);box-shadow:0 24px 52px rgba(0,0,0,.52)}.sh2-split-media:hover .sh2-duo-over img{transform:scale(1.03)}.sh2-feats-section{background:var(--navy);padding:72px 0 80px}.sh2-feats-head{text-align:center;margin-bottom:44px}.sh2-feats-h2{font-size:clamp(24px,3vw,40px);font-weight:900;color:#fff;line-height:1.14;margin:8px 0 0;font-family:var(--fh)}.sh2-feats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}.sh2-feats-grid .sh-feat-card-inner{height:100%;padding:24px 20px 26px;border-radius:18px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.09);transition:background .35s var(--ease),transform .35s var(--ease),box-shadow .35s var(--ease);box-shadow:none}.sh2-feats-grid .sh-feat-card:hover .sh-feat-card-inner{background:rgba(255,255,255,.1);transform:translateY(-5px);box-shadow:0 16px 40px rgba(0,0,0,.28)}.sh2-feats-grid .sh-feat-ico{width:42px;height:42px;border-radius:12px;background:rgba(255,90,31,.15);border:1px solid rgba(255,90,31,.28);margin-bottom:16px}.sh2-feats-grid .sh-feat-title{font-size:14.5px;font-weight:800;margin-bottom:8px;color:#fff}.sh2-feats-grid .sh-feat-desc{font-size:13px;color:rgba(255,255,255,.55);line-height:1.72}.sh2-ni-section{background:#fff;padding:72px 0 80px}.sh2-ni-inner{max-width:900px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}.sh2-ni-head{display:flex;flex-direction:column;gap:10px;position:sticky;top:100px}.sh2-ni-h2{font-size:clamp(26px,3vw,42px);font-weight:900;color:var(--navy);line-height:1.1;margin:4px 0 0;font-family:var(--fh)}.sh2-ni-lead{font-size:14px;color:#6b7280;line-height:1.7;margin:0}.sh2-ni-grid{display:flex;flex-direction:column;gap:0}.sh-ni-row{display:flex;align-items:flex-start;gap:16px;padding:18px 0;border-bottom:1px solid #f1f5f9}.sh-ni-row:first-child{border-top:1px solid #f1f5f9}.sh-ni-emoji{font-size:22px;line-height:1;flex-shrink:0;margin-top:2px;width:32px;text-align:center}.sh-ni-text{display:flex;flex-direction:column;gap:3px}.sh-ni-name{font-size:14.5px;font-weight:700;color:var(--navy);display:block}.sh-ni-desc{font-size:13px;color:#6b7280;line-height:1.55}@media (max-width:768px){.sh2-ni-inner{grid-template-columns:1fr;gap:32px}.sh2-ni-head{position:static}.sh2-ni-section{padding:48px 0 56px}}@media (max-width:480px){.sh2-ni-section{padding:36px 0 44px}.sh-ni-row{padding:14px 0;gap:12px}.sh-ni-emoji{font-size:18px;width:26px}.sh-ni-name{font-size:13.5px}}.sh2-meals-section{display:flex;justify-content:center;background:#1a0e05;overflow:hidden;min-height:500px}.sh2-meals-grid{width:100%;max-width:var(--max);display:grid;grid-template-columns:1fr 1fr;gap:0;align-items:stretch}.sh2-meals-media{position:relative;overflow:hidden;min-height:500px;order:1}.sh2-meals-copy{display:flex;flex-direction:column;align-items:flex-start;order:2;background:0 0}.sh2-meals-copy-inner{width:100%;padding:72px 48px;display:flex;flex-direction:column;gap:18px}.sh2-meals-h2{font-size:clamp(22px,2.6vw,36px);font-weight:900;color:#fff;line-height:1.18;margin:0;font-family:var(--fh)}.sh2-meals-p{font-size:15px;line-height:1.88;color:rgba(255,255,255,.65);margin:0}.sh2-meals-section .sh2-duo{min-height:500px}.sh2-meals-section .sh2-duo-over{border-color:#2a1a0a}.sh2-meals-section:hover .sh2-duo-main img{transform:scale(1.04)}.sh2-meals-section:hover .sh2-duo-over{transform:translateY(-6px) scale(1.02);box-shadow:0 28px 52px rgba(0,0,0,.58)}@media (max-width:960px){.sh2-meals-grid,.sh2-split-grid{grid-template-columns:1fr;min-height:auto}.sh2-split-left .sh2-split-media,.sh2-split-right .sh2-split-media{order:1}.sh2-split-left .sh2-split-copy,.sh2-split-right .sh2-split-copy{order:2;align-items:stretch}.sh2-split-copy-inner{padding:48px 32px}.sh2-duo,.sh2-meals-section .sh2-duo{min-height:340px}.sh2-feats-grid{grid-template-columns:repeat(2,1fr);gap:12px}.sh2-stat{padding:6px 18px}.sh2-stat-sep{height:26px}.sh2-meals-media{order:1;min-height:340px}.sh2-meals-copy{order:2;align-items:stretch}.sh2-meals-copy-inner{padding:48px 32px}}@media (max-width:640px){.sh2-stats-strip{padding:10px 0}.sh2-stat{padding:5px 12px}.sh2-stat-num{font-size:15px}.sh2-stat-lbl{font-size:9px}.sh2-stat-sep{height:20px}.sh2-meals-copy-inner,.sh2-split-copy-inner{padding:36px 24px}.sh2-meals-h2,.sh2-split-h2{font-size:clamp(20px,5.5vw,28px)}.sh2-split-accent{font-size:18px}.sh2-feats-section{padding:48px 0 56px}.sh2-feats-grid{grid-template-columns:1fr 1fr;gap:10px}.sh2-feats-grid .sh-feat-card-inner{padding:16px 14px 18px}.sh2-feats-grid .sh-feat-ico{width:36px;height:36px;margin-bottom:12px}.sh2-feats-grid .sh-feat-title{font-size:13px}.sh2-feats-grid .sh-feat-desc{font-size:12px}.sh2-duo,.sh2-meals-section .sh2-duo{min-height:240px}.sh2-duo-over{width:54%;right:-8px;border-width:3px;border-radius:10px}.sh2-duo-over--tr{right:-8px;top:14px}}@media (max-width:390px){.sh2-feats-grid{grid-template-columns:1fr}.sh2-stat-sep{display:none}.sh2-stat{padding:4px 10px}}.vb-ico img{border-radius:6px}.booking-header{padding:max(140px,env(safe-area-inset-top,0) + 120px)0 60px;background:var(--navy);color:#fff;text-align:center;position:relative;overflow:hidden}.booking-header::before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 50%0,rgba(255,90,31,.15)0,transparent 70%);pointer-events:none}.booking-header-inner{position:relative;z-index:2;max-width:800px;margin:0 auto;display:flex;flex-direction:column;align-items:center}.booking-header-eyebrow,.booking-header-trust span{display:inline-flex;align-items:center;background:rgba(255,255,255,.08);border-radius:50px}.booking-header-eyebrow{gap:8px;font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--sand);margin-bottom:24px;padding:6px 16px;border:1px solid rgba(255,255,255,.1)}.booking-header-dot{width:6px;height:6px;border-radius:50%;background:var(--fire)}.booking-header-h1{font-size:clamp(36px,6vw,64px);font-weight:900;line-height:1.05;letter-spacing:-.03em;margin:0 0 20px;font-family:var(--fh)}.booking-header-tagline{font-size:clamp(16px,2vw,20px);color:rgba(255,255,255,.75);margin:0 0 32px;line-height:1.6}.booking-header-trust{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.booking-header-trust span{gap:6px;font-size:13px;font-weight:500;color:rgba(255,255,255,.9);border:1px solid rgba(255,255,255,.12);padding:8px 16px;transition:transform .2s var(--spring),background .2s}.booking-header-trust span:hover{background:rgba(255,255,255,.12);transform:translateY(-2px)}@media (max-width:768px){#scroll-progress{display:none}}.fq-text-wrap:empty{display:none}.footer-quotes:has(.fq-text-wrap:empty){display:none}.home-gallery-sec{background:#fff}#home-surf-forecast,.ig-section,.ig-section.sec-light{background:#f0f4f8!important}#home-tribe,.gh-teaser{background:#fff!important}.blog-hub-header+.section,.blog-hub-header+.section.sec-light,.page-header+.section,.page-header+.section.sec-light{padding-top:64px}.sh2-feats-section:has(+.sh2-split-section){padding-bottom:12px}.sh2-feats-section+.sh2-split-section{margin-top:-1px}.sh2-feats-section+.sh2-split-section .sh2-split-copy-inner{padding-top:8px}@media (max-width:960px){.sh2-feats-section:has(+.sh2-split-section){padding-bottom:8px}.sh2-feats-section+.sh2-split-section .sh2-split-copy-inner{padding-top:6px}}@media (max-width:640px){.sh2-feats-section:has(+.sh2-split-section){padding-bottom:6px}.sh2-feats-section+.sh2-split-section .sh2-split-copy-inner{padding-top:4px}}.sh2-split-section.sh2-split-right{min-height:0}.sh2-split-section.sh2-split-right .sh2-split-grid{align-items:start}.sh2-split-section.sh2-split-right .sh2-split-copy{justify-content:flex-start}.sh2-split-section.sh2-split-right .sh2-split-media{min-height:0}.sh2-split-section.sh2-split-right .sh2-img-hover{min-height:0!important;height:auto!important;aspect-ratio:1/1;border-radius:0!important;overflow:hidden}.sh2-split-section.sh2-split-right .sh2-img-hover img{width:100%!important;height:100%!important;object-fit:cover;display:block}.sh-gallery-sec:has(+.sh2-ni-section) .container>div:last-of-type{margin-top:28px!important;padding-bottom:0!important}.sh-gallery-sec:has(+.sh2-ni-section){padding-bottom:36px}.sh-gallery-sec+.sh2-ni-section{padding-top:32px}@media (max-width:640px){.sh-gallery-sec:has(+.sh2-ni-section){padding-bottom:24px}.sh-gallery-sec+.sh2-ni-section{padding-top:24px}}.reviews-section{padding-bottom:56px!important}@media (max-width:900px){.reviews-section{padding-bottom:48px!important}}@media (max-width:640px){.reviews-section{padding-bottom:40px!important}}.vb-fact,.vb-tip{border:0;border-radius:16px;padding:28px 32px;position:relative;overflow:hidden}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* === MOBILE PERFORMANCE & UX === */
/* Touch targets */
.btn,.nav-link,.lang-dd-btn,.lang-dd-item,.nav-wa,.faq-q,.nav-toggle,.gallery-item,.footer-col a,.footer-pp-link{min-height:44px}.nav-link{display:flex;align-items:center}@media(hover:none){.btn:hover{transform:none}.card:hover{box-shadow:var(--s-sm)}.gallery-item:hover{transform:none}}@media(max-width:768px){.section{padding:56px 0}.split{grid-template-columns:1fr;gap:32px}.split-img img{height:260px}.main-hero-h1{font-size:clamp(28px,9vw,44px)}.main-hero-tagline{font-size:14px}.main-hero-actions{gap:10px}.cta-band{padding:56px 0}.container{padding:0 18px}.s-title{font-size:clamp(24px,6vw,38px)}}@media(max-width:400px){.main-hero-h1{font-size:28px}.btn-lg{padding:13px 24px;font-size:13px}.nav-inner{padding:0 16px;height:60px}.nav-logo img{height:36px}}body{max-width:100vw;overflow-x:hidden}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}.hg-caption,.hg-caption.hg-cap-visible{display:none!important}/* client-2026-05-07 docx Accueil overrides */.gh-teaser .btn.btn-deep,#home-surf-forecast .btn-deep{background:var(--fire,#FF8A3D)!important;border-color:var(--fire,#FF8A3D)!important;color:#fff!important}.sh2-feats-section .sh-feat-ico,.sh2-feats-section .sh-feat-ico span{width:32px!important;height:32px!important}.sh2-feats-section .sh-feat-ico svg{width:24px;height:24px}.hg-caption,.hg-caption.hg-cap-visible{display:none!important}.home-proof-fact{gap:24px!important;align-items:center!important}.home-proof-fact-n{min-width:84px!important;flex:0 0 auto!important;text-align:left;padding-top:0!important}.home-proof-fact-body{flex:1 1 auto!important;min-width:0!important}.home-proof-fact-t,.home-proof-fact-d{overflow-wrap:anywhere;word-wrap:break-word}@media(max-width:600px){.home-proof-fact-n{min-width:64px!important;font-size:22px!important}.home-proof-fact{gap:16px!important}}.nav-logo img{width:44px!important;height:44px!important;max-width:44px!important;object-fit:contain!important}@media(max-width:640px){.nav-logo img{width:40px!important;height:40px!important;max-width:40px!important}}.sh2-feats-section{padding-bottom:64px!important}.sh2-feats-section:has(+.sh2-split-section){padding-bottom:64px!important}@media(max-width:960px){.sh2-feats-section,.sh2-feats-section:has(+.sh2-split-section){padding-bottom:48px!important}}@media(max-width:640px){.sh2-feats-section,.sh2-feats-section:has(+.sh2-split-section){padding-bottom:36px!important}}.footer-links-row--2col{display:grid!important;grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:32px 48px!important}.footer-bottom{display:flex!important;flex-direction:row!important;justify-content:space-between!important;align-items:center!important;gap:24px!important;padding-top:24px!important;margin-top:24px!important;border-top:1px solid rgba(255,255,255,.08)!important}.footer-bottom .footer-copy{margin:0!important;font-size:13px!important;color:rgba(255,255,255,.62)!important;line-height:1.5}.footer-bottom .footer-pp-link{color:rgba(255,255,255,.78)!important;text-decoration:none;border-bottom:1px dashed rgba(255,255,255,.20);padding-bottom:1px}.footer-bottom .footer-pp-link:hover{color:#fff!important;border-bottom-color:rgba(255,255,255,.50)}.footer-bottom .footer-accred{display:inline-flex!important;align-items:center!important;gap:10px!important;padding:8px 14px!important;background:rgba(255,255,255,.04)!important;border:1px solid rgba(240,192,96,.22)!important;border-radius:999px!important;flex-shrink:0!important}.footer-bottom .footer-accred .footer-fss-logo-wrap{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:#fff;flex-shrink:0}.footer-bottom .footer-accred .footer-fss-logo-wrap img{width:22px!important;height:22px!important;display:block}.footer-bottom .footer-accred .footer-fss-text{display:inline-flex;flex-direction:column;line-height:1.15}.footer-bottom .footer-accred .footer-fss-title{font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--sand,#f0c060)}.footer-bottom .footer-accred .footer-fss-sub{font-size:11px;color:rgba(255,255,255,.62);margin-top:1px}.footer-top+.footer-accred{display:none!important}@media(max-width:768px){.footer-links-row--2col{grid-template-columns:1fr!important;gap:24px!important}.footer-bottom{flex-direction:column!important;align-items:flex-start!important;gap:16px!important}.footer-bottom .footer-accred{width:100%;justify-content:center}}@media(max-width:480px){.footer-bottom .footer-copy{font-size:12px!important}.footer-bottom .footer-accred{padding:6px 12px!important;gap:8px!important}.footer-bottom .footer-accred .footer-fss-title,.footer-bottom .footer-accred .footer-fss-sub{font-size:10.5px}}.home-proof-strip .home-proof-grid{grid-template-columns:1fr!important;gap:14px!important}.home-proof-strip .home-proof-facts{max-width:920px;margin:0 auto}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* client-2026-05-08 bug1 footer overflow */footer{overflow-x:hidden}@media(max-width:480px){footer .footer-bottom>*,footer .footer-links-row>*{min-width:0}footer .fc-chart{min-width:0!important;max-width:100%}}/* client-2026-05-08 bug2 booking split mobile */@media(max-width:640px){#booking-section .split{grid-template-columns:1fr!important;gap:24px!important}}/* client-2026-05-08 bug3 surf spots font */.surf-spots-sec .surf-spot-name{font-size:1.25rem;line-height:1.4}.surf-spots-sec .surf-spot-desc{font-size:14px;line-height:1.5}@media(max-width:640px){.surf-spots-sec .surf-spot-name{font-size:1.1rem}.surf-spots-sec .surf-spot-desc{font-size:13px}}/* client-2026-05-08 bug4 island cards aspect */@media(max-width:480px){.island-discover-card .card-img,.island-discover-card picture img{aspect-ratio:3/2!important;height:auto!important}}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip{
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}.vb-tip::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}.vb-tip .vb-header{
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}.vb-tip .vb-label{
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}.vb-tip .vb-ico{
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}.vb-tip p,.vb-tip li{ font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }.vb-tip strong{ color: var(--fire); }/* ── FACT block ───────────────────────────────────────── */
.vb-fact{
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}.vb-fact::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}.vb-fact .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }.vb-fact .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }.vb-fact .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }.vb-fact p,.vb-fact li{ font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert{
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}.vb-expert::before{
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}.vb-expert::after{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}.vb-expert .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }.vb-expert .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }.vb-expert .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }.vb-expert blockquote{ font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary{
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}.vb-summary::before{
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}.vb-summary::after{
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}.vb-summary .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }.vb-summary .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }.vb-summary .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }.vb-summary p{ color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }.vb-summary ul{ margin: 0; padding: 0; list-style: none; }.vb-summary li{
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}.vb-summary li::before{
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}.vb-summary li strong{ color: #fff; }/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist{
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}.vb-checklist::before{
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}.vb-checklist .vb-header{ display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }.vb-checklist .vb-label{ font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }.vb-checklist .vb-ico{ width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }.vb-checklist ul{ list-style: none; margin: 0; padding: 0; }.vb-checklist li{
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}.vb-checklist li::before{
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}/* Shared block structural reset — only for standalone vblock,not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note){ display: block; padding: 0; background: none; border: none; margin: 32px 0; }.vb-ico{ display: flex; align-items: center; justify-content: center; }.vb-ico img{ border-radius: 6px; }.vb-header{ position: relative; z-index: 1; }.vb-content{ position: relative; z-index: 1; }/* List inside blocks */
.vblock ul.block-list{ list-style: none; margin: 0; padding: 0; }.vb-tip ul.block-list li,.vb-fact ul.block-list li{
  padding-left: 18px; position: relative; margin-bottom: 8px;
}.vb-tip ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }.vb-fact ul.block-list li::before{ content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section{ margin-top: 48px; margin-bottom: 8px; }.article-faq-section > h2{
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}.article-faq-item{
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}.article-faq-item:hover{ box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }.article-faq-item.open{ border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }.article-faq-q{
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}.article-faq-q:hover{ background: #fafbfc; }.faq-a-chevron{
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}.article-faq-item.open .faq-a-chevron{ transform: rotate(180deg); }.article-faq-answer{
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}.article-faq-item.open .article-faq-answer{ grid-template-rows: 1fr; }.faq-answer-inner{ min-height: 0; overflow: hidden; padding: 0 24px; }.article-faq-item.open .faq-answer-inner{ padding-bottom: 20px; padding-top: 4px; }.faq-answer-inner p{
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}

/* client-2026-05-29: WhatsApp CTA solid green everywhere incl. blog (btn-glass base is 0.15 alpha) */
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */


.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2 {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
/* ══════════════════════════════════════════════════════
   VISUAL BLOCKS v2 — Premium DA
══════════════════════════════════════════════════════ */

/* ── TIP block ────────────────────────────────────────── */
.vb-tip {
  background: linear-gradient(135deg, #fff8f5, #fff3ee);
  border: none;
  border-left: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(255,90,31,0.08), inset 0 0 0 1.5px rgba(255,90,31,0.18);
}
.vb-tip::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--fire), #ff8c5a);
  border-radius: 16px 0 0 16px;
}
.vb-tip .vb-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vb-tip .vb-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fire);
  margin-bottom: 0;
}
.vb-tip .vb-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(255,90,31,0.12); flex-shrink: 0;
}
.vb-tip p, .vb-tip li { font-size: 15.5px; color: #2d1a0e; line-height: 1.72; }
.vb-tip strong { color: var(--fire); }

/* ── FACT block ───────────────────────────────────────── */
.vb-fact {
  background: linear-gradient(135deg, #f0f8ff, #e8f4ff);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(14,165,233,0.08), inset 0 0 0 1.5px rgba(14,165,233,0.18);
}
.vb-fact::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #0ea5e9, #38bdf8);
  border-radius: 16px 0 0 16px;
}
.vb-fact .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-fact .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #0284c7; margin-bottom: 0; }
.vb-fact .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(14,165,233,0.12); flex-shrink: 0; }
.vb-fact p, .vb-fact li { font-size: 15.5px; color: #0c2a3a; line-height: 1.72; }

/* ── EXPERT / COACH quote ─────────────────────────────── */
.vb-expert {
  background: linear-gradient(135deg, #fffbf0, #fff8e6);
  border: none;
  border-radius: 16px;
  padding: 32px 36px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(240,192,96,0.12), inset 0 0 0 1.5px rgba(240,192,96,0.30);
}
.vb-expert::before {
  content: '"';
  position: absolute; top: -12px; left: 22px;
  font-size: 100px; line-height: 1; font-family: Georgia, serif;
  color: rgba(240,192,96,0.25); pointer-events: none;
  font-weight: 900;
}
.vb-expert::after {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--sand), #e8b840);
  border-radius: 16px 0 0 16px;
}
.vb-expert .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.vb-expert .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #92680a; margin-bottom: 0; }
.vb-expert .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(240,192,96,0.20); flex-shrink: 0; }
.vb-expert blockquote { font-size: 17px; font-style: italic; color: #2a1d06; line-height: 1.78; font-family: var(--fh); font-weight: 500; margin: 0; border: none; padding: 0; }

/* ── SUMMARY / KEY TAKEAWAYS ──────────────────────────── */
.vb-summary {
  background: linear-gradient(135deg, #0a2540 0%, #0d3060 60%, #0a2540 100%);
  border: none;
  border-radius: 20px;
  padding: 32px 36px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,37,64,0.25);
}
.vb-summary::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--fire), var(--sand), var(--fire));
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
}
.vb-summary::after {
  content: '';
  position: absolute; bottom: -30px; right: -20px;
  width: 140px; height: 140px; border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}
.vb-summary .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.vb-summary .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sand); margin-bottom: 0; }
.vb-summary .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,0.10); flex-shrink: 0; }
.vb-summary p { color: rgba(255,255,255,0.88); font-size: 15.5px; line-height: 1.72; margin: 0; }
.vb-summary ul { margin: 0; padding: 0; list-style: none; }
.vb-summary li {
  color: rgba(255,255,255,0.88); font-size: 15px; line-height: 1.68;
  margin-bottom: 10px; padding-left: 22px; position: relative;
}
.vb-summary li::before {
  content: '→'; position: absolute; left: 0;
  color: var(--sand); font-size: 13px; top: 2px;
}
.vb-summary li strong { color: #fff; }

/* ── CHECKLIST ────────────────────────────────────────── */
.vb-checklist {
  background: linear-gradient(135deg, #f0fff5, #e8fef0);
  border: none;
  border-radius: 16px;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(34,197,94,0.08), inset 0 0 0 1.5px rgba(34,197,94,0.20);
}
.vb-checklist::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, #22c55e, #4ade80);
  border-radius: 16px 0 0 16px;
}
.vb-checklist .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.vb-checklist .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #15803d; margin-bottom: 0; }
.vb-checklist .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(34,197,94,0.12); flex-shrink: 0; }
.vb-checklist ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist .vb-content ul { list-style: none; margin: 0; padding: 0; }
.vb-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 15px; line-height: 1.68; color: #0f2e1a;
  margin-bottom: 10px; padding: 0;
}
.vb-checklist li:last-child { margin-bottom: 0; }
.vb-checklist li::before {
  content: '✓';
  width: 22px; height: 22px; border-radius: 50%;
  background: #22c55e; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}

/* ── NOTE block ───────────────────────────────────────── */
.vb-note {
  background: #f8fafc;
  border: none;
  border-radius: 16px;
  padding: 24px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: inset 0 0 0 1.5px rgba(10,37,64,0.12);
}
.vb-note::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 5px; height: 100%;
  background: linear-gradient(to bottom, var(--navy), #1a4a7a);
  border-radius: 16px 0 0 16px;
}
.vb-note .vb-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.vb-note .vb-label { font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: var(--navy); margin-bottom: 0; }
.vb-note .vb-ico { width: 36px; height: 36px; border-radius: 10px; background: rgba(10,37,64,0.08); flex-shrink: 0; }
.vb-note p, .vb-note li { font-size: 15px; color: #1a2b3c; line-height: 1.70; }

/* Shared block structural reset — only for standalone vblock, not combined with vb-* */
.vblock:not(.vb-tip):not(.vb-fact):not(.vb-expert):not(.vb-summary):not(.vb-checklist):not(.vb-note) { display: block; padding: 0; background: none; border: none; margin: 32px 0; }
.vb-ico { display: flex; align-items: center; justify-content: center; }
.vb-ico img { border-radius: 6px; }
.vb-header { position: relative; z-index: 1; }
.vb-content { position: relative; z-index: 1; }

/* List inside blocks */
.vblock ul.block-list { list-style: none; margin: 0; padding: 0; }
.vb-tip ul.block-list li, .vb-fact ul.block-list li, .vb-note ul.block-list li {
  padding-left: 18px; position: relative; margin-bottom: 8px;
}
.vb-tip ul.block-list li::before { content: '•'; position: absolute; left: 0; color: var(--fire); font-size: 16px; line-height: 1.5; }
.vb-fact ul.block-list li::before { content: '•'; position: absolute; left: 0; color: #0ea5e9; font-size: 16px; line-height: 1.5; }

/* ── Article FAQ (island guide pages) ────────────────────────────── */
.article-faq-section { margin-top: 48px; margin-bottom: 8px; }
.article-faq-section > h2, .article-faq-section .faq-section-title {
  font-size: clamp(18px,2.5vw,24px); font-weight: 800; color: var(--navy);
  margin-bottom: 20px; font-family: var(--fh);
}
.article-faq-item {
  border: 1px solid rgba(10,37,64,0.10);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(10,37,64,0.05);
  transition: box-shadow var(--t), border-color var(--t);
  background: #fff;
}
.article-faq-item:hover { box-shadow: var(--s-sm); border-color: rgba(10,37,64,0.18); }
.article-faq-item.open { border-color: rgba(255,90,31,0.28); box-shadow: 0 4px 16px rgba(255,90,31,0.08); }
.article-faq-q {
  width: 100%; text-align: left; padding: 18px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-weight: 600; font-size: 16px; color: var(--navy); background: transparent;
  border: none; cursor: pointer; font-family: inherit;
  transition: background var(--t);
}
.article-faq-q:hover { background: #fafbfc; }
.faq-a-chevron {
  color: var(--fire); flex-shrink: 0;
  display: inline-flex; align-items: center;
  transition: transform 0.3s var(--spring);
}
.article-faq-item.open .faq-a-chevron { transform: rotate(180deg); }
.article-faq-answer {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s var(--ease);
  background: #fff; overflow: hidden;
}
.article-faq-item.open .article-faq-answer { grid-template-rows: 1fr; }
.faq-answer-inner { min-height: 0; overflow: hidden; padding: 0 24px; }
.article-faq-item.open .faq-answer-inner { padding-bottom: 20px; padding-top: 4px; }
.faq-answer-inner p {
  color: var(--muted); line-height: 1.78; font-size: 15.5px; margin: 0;
}
