/* In Huong Giang Pages CSS */
.cat-header{background:var(--bg-dark);padding:36px 0 28px;color:#fff}
.cat-header-inner{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap}
.cat-title{color:#fff;margin:10px 0 6px;font-size:clamp(1.4rem,4vw,2rem)}
.cat-desc{color:rgba(255,255,255,.65);font-size:.9rem;margin:0}
.cat-count-badge{display:inline-block;padding:4px 14px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);border-radius:100px;font-size:.74rem;font-weight:600;color:rgba(255,255,255,.8);white-space:nowrap;margin-top:4px}
.cat-tabs-bar{background:var(--bg);border-bottom:1px solid var(--border);position:sticky;top:62px;z-index:99}
.cat-tabs-scroll{display:flex;overflow-x:auto;scrollbar-width:none}
.cat-tabs-scroll::-webkit-scrollbar{display:none}
.cat-tab{display:inline-flex;align-items:center;padding:12px 18px;font-size:.82rem;font-weight:600;color:var(--muted);white-space:nowrap;flex-shrink:0;border-bottom:2px solid transparent;transition:color var(--transition),border-color var(--transition);text-decoration:none;min-height:46px}
.cat-tab:hover{color:var(--text)}
.cat-tab.active{color:var(--primary);border-bottom-color:var(--primary)}
.cat-body{padding:36px 0 64px}
.cat-grid-4{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
@media(min-width:640px){.cat-grid-4{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media(min-width:1024px){.cat-grid-4{grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}}
.cat-grid-4>*{min-width:0}
.cat-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column;transition:border-color var(--transition)}
.cat-card:hover{border-color:var(--primary)}
.cat-card-img{display:block;overflow:hidden;aspect-ratio:16/9;background:var(--bg-2);flex-shrink:0}
.cat-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .35s ease}
.cat-card:hover .cat-card-img img{transform:scale(1.04)}
.cat-no-img-sm{width:100%;height:100%;min-height:120px;display:flex;align-items:center;justify-content:center;background:var(--bg-2);color:var(--border)}
.cat-card-body{padding:14px 16px;flex:1;display:flex;flex-direction:column;gap:6px}
.cat-card-body h3{font-size:.9rem;font-weight:700;line-height:1.4;margin:0}
.cat-card-body h3 a{color:var(--text)}
.cat-card-body h3 a:hover{color:var(--primary)}
.cat-card-excerpt{font-size:.78rem;color:var(--muted);line-height:1.6;flex:1;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.cat-card-meta{display:flex;align-items:center;gap:8px;font-size:.7rem;color:var(--muted);margin-top:auto;flex-wrap:wrap}
.cat-meta-dot{opacity:.4}
.cat-card-more{margin-left:auto;display:inline-flex;align-items:center;gap:3px;font-size:.74rem;font-weight:700;color:var(--primary);white-space:nowrap}
.cat-pagination{display:flex;justify-content:center;align-items:center;gap:5px;flex-wrap:wrap;margin-top:40px}
.cat-pagination a,.cat-pagination span{display:flex;align-items:center;justify-content:center;min-width:38px;height:38px;border:1px solid var(--border);border-radius:var(--radius);font-size:.82rem;font-weight:600;color:var(--text-2);transition:all var(--transition);text-decoration:none}
.cat-pagination a:hover{background:var(--primary-light);border-color:var(--primary);color:var(--primary)}
.cat-pagination .current{background:var(--primary);border-color:var(--primary);color:#fff}
.cat-empty{text-align:center;padding:64px 0;display:flex;flex-direction:column;align-items:center;gap:12px}
.news-page-header{background:var(--bg-dark);padding:40px 0 32px;color:#fff}
.news-page-header-inner{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;flex-wrap:wrap}
.news-page-header h1{color:#fff;margin-bottom:8px}
.news-page-header p{color:rgba(255,255,255,.6);font-size:.9rem;margin:0}
.news-eyebrow{font-size:.7rem;font-weight:700;color:var(--primary);text-transform:uppercase;letter-spacing:.1em;margin-bottom:10px;display:block}
.news-cats-bar{background:var(--bg);border-bottom:1px solid var(--border);position:sticky;top:62px;z-index:99}
.news-cats-scroll{display:flex;overflow-x:auto;scrollbar-width:none}
.news-cats-scroll::-webkit-scrollbar{display:none}
.news-cat-tab{display:inline-flex;align-items:center;gap:6px;padding:12px 16px;font-size:.8rem;font-weight:600;color:var(--muted);white-space:nowrap;border-bottom:2px solid transparent;transition:color var(--transition),border-color var(--transition);text-decoration:none;flex-shrink:0}
.news-cat-tab:hover{color:var(--text)}
.news-cat-tab.active{color:var(--primary);border-bottom-color:var(--primary)}
.news-page-body{padding:36px 0 64px}
.news-featured{display:grid;grid-template-columns:1fr;border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:28px}
@media(min-width:768px){.news-featured{grid-template-columns:1.4fr 1fr}}
.news-featured-thumb{display:block;overflow:hidden;aspect-ratio:16/9;background:var(--bg-2)}
@media(min-width:768px){.news-featured-thumb{aspect-ratio:auto;min-height:280px}}
.news-featured-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.news-featured:hover .news-featured-thumb img{transform:scale(1.03)}
.news-featured-placeholder{width:100%;height:100%;min-height:200px;display:flex;align-items:center;justify-content:center;background:var(--bg-2);color:var(--border)}
.news-featured-body{padding:24px 28px;display:flex;flex-direction:column;gap:10px}
.news-featured-body h2{font-size:clamp(1.05rem,2.5vw,1.4rem);line-height:1.3}
.news-featured-body h2 a{color:var(--text)}
.news-featured-body h2 a:hover{color:var(--primary)}
.news-featured-body>p{font-size:.875rem;color:var(--muted);line-height:1.65;flex:1}
.news-featured-meta{display:flex;align-items:center;gap:10px;font-size:.74rem;color:var(--muted);flex-wrap:wrap}
.news-read-btn{margin-left:auto;display:inline-flex;align-items:center;gap:4px;font-size:.78rem;font-weight:700;color:var(--primary)}
.news-grid-main{display:grid;grid-template-columns:1fr;gap:14px}
@media(min-width:580px){.news-grid-main{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.news-grid-main{grid-template-columns:repeat(3,1fr)}}
.news-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column;transition:border-color var(--transition)}
.news-card:hover{border-color:var(--primary)}
.news-card-thumb{display:block;overflow:hidden;aspect-ratio:16/9;background:var(--bg-2);flex-shrink:0}
.news-card-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .35s ease}
.news-card:hover .news-card-thumb img{transform:scale(1.04)}
.news-card-no-thumb{width:100%;height:100%;min-height:130px;display:flex;align-items:center;justify-content:center;background:var(--bg-2);color:var(--border)}
.news-card-body{padding:16px 18px;flex:1;display:flex;flex-direction:column;gap:6px}
.news-card-body h3{font-size:.875rem;font-weight:700;line-height:1.4;margin:0}
.news-card-body h3 a{color:var(--text)}
.news-card-body h3 a:hover{color:var(--primary)}
.news-card-body>p{font-size:.78rem;color:var(--muted);line-height:1.6;flex:1}
.news-card-meta{display:flex;align-items:center;gap:8px;font-size:.7rem;color:var(--muted);margin-top:auto}
.news-empty{text-align:center;padding:64px 0;display:flex;flex-direction:column;align-items:center;gap:12px}
.shop-page-header{background:var(--bg-2);border-bottom:1px solid var(--border);padding:28px 0 22px}
.shop-filter-bar{background:var(--bg);border-bottom:1px solid var(--border);position:sticky;top:62px;z-index:99}
.shop-filter-bar .container{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;min-height:48px}
.shop-filter-tabs{display:flex;overflow-x:auto;scrollbar-width:none;flex:1}
.shop-filter-tabs::-webkit-scrollbar{display:none}
.shop-tab{display:inline-flex;align-items:center;padding:10px 15px;font-size:.8rem;font-weight:600;color:var(--muted);white-space:nowrap;flex-shrink:0;border-bottom:2px solid transparent;transition:color var(--transition),border-color var(--transition);text-decoration:none;min-height:48px}
.shop-tab:hover{color:var(--text)}
.shop-tab.active{color:var(--primary);border-bottom-color:var(--primary)}
.shop-toolbar-right{display:flex;align-items:center;gap:10px;font-size:.78rem;color:var(--muted);flex-shrink:0}
.shop-body{padding:28px 0 64px}
.page-wrap{padding:36px 0 64px}
@media(min-width:768px){.page-wrap{padding:48px 0 80px}}
.page-layout{display:grid;grid-template-columns:1fr;gap:32px;align-items:start;width:100%}
@media(min-width:900px){.page-layout{grid-template-columns:minmax(0,1fr) 280px;gap:40px}}
.page-main{min-width:0}
.page-sidebar{min-width:0;position:sticky;top:80px;align-self:start;display:flex;flex-direction:column;gap:16px}
.page-hero-thumb{width:100%;border-radius:var(--radius-lg);overflow:hidden;margin-bottom:28px}
.page-hero-thumb img{width:100%;height:auto;max-height:460px;object-fit:cover;display:block}
.page-cta-widget{background:linear-gradient(145deg,#0a2463,var(--primary))!important;border-color:var(--primary)!important}
.page-cta-top{text-align:center;margin-bottom:14px}
.page-cta-icon{color:rgba(255,255,255,.2);margin:0 auto 10px}
.page-cta-widget h3{color:#fff;font-size:.9rem;margin-bottom:5px}
.page-cta-widget p{color:rgba(255,255,255,.7);font-size:.8rem;line-height:1.55}
.page-cta-actions{display:flex;flex-direction:column;gap:7px}
.policy-wrap{padding:36px 0 64px}
.policy-layout{display:grid;grid-template-columns:1fr;gap:28px;align-items:start}
@media(min-width:900px){.policy-layout{grid-template-columns:minmax(0,1fr) 240px;gap:36px}}
.policy-main{min-width:0}
.policy-sidebar{min-width:0;position:sticky;top:80px;align-self:start;display:flex;flex-direction:column;gap:14px}
.policy-content h2{font-size:1rem;font-weight:700;margin:1.6rem 0 .5rem;padding-bottom:6px;border-bottom:1px solid var(--border)}
.policy-content h2:first-child{margin-top:0}
.policy-content ul{padding-left:1.3rem;margin-bottom:1rem}
.policy-content ul li{list-style:disc;margin-bottom:.4rem;font-size:.875rem;color:var(--text-2)}
.policy-content p{font-size:.875rem;color:var(--text-2);line-height:1.75}
.about-intro{padding:52px 0}
.about-intro-grid{display:grid;grid-template-columns:1fr;gap:32px}
@media(min-width:900px){.about-intro-grid{grid-template-columns:1fr 1fr;gap:56px;align-items:center}}
.about-intro-img{position:relative}
.about-intro-img img{width:100%;border-radius:var(--radius-lg);aspect-ratio:4/3;object-fit:cover}
.about-intro-badge{position:absolute;bottom:-14px;right:16px;background:var(--primary);color:#fff;padding:12px 18px;border-radius:var(--radius-lg);text-align:center;box-shadow:var(--shadow-md)}
.about-badge-big{display:block;font-size:1.4rem;font-weight:900;line-height:1}
.about-badge-sub{font-size:.68rem;opacity:.85}
.about-intro-content h1{margin-bottom:14px}
.about-intro-content p{color:var(--muted);font-size:.9rem;line-height:1.75}
.about-intro-stats{display:flex;gap:24px;margin:22px 0 26px;padding:18px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.about-intro-stats strong{display:block;font-size:1.5rem;font-weight:800;color:var(--primary)}
.about-intro-stats span{font-size:.72rem;color:var(--muted)}
.about-values{padding:52px 0}
.about-values-grid{display:grid;grid-template-columns:1fr;gap:14px}
@media(min-width:540px){.about-values-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.about-values-grid{grid-template-columns:repeat(3,1fr)}}
.about-value-item{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:22px;display:flex;flex-direction:column;gap:8px;transition:border-color var(--transition)}
.about-value-item:hover{border-color:var(--primary)}
.about-value-icon{width:44px;height:44px;border-radius:10px;background:var(--primary-light);display:flex;align-items:center;justify-content:center;color:var(--primary)}
.about-team{padding:52px 0}
.about-team-grid{display:grid;grid-template-columns:1fr;gap:14px}
@media(min-width:540px){.about-team-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.about-team-grid{grid-template-columns:repeat(3,1fr)}}
.about-team-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:22px;display:flex;gap:14px;align-items:flex-start;transition:border-color var(--transition)}
.about-team-card:hover{border-color:var(--primary)}
.about-team-avatar{width:50px;height:50px;min-width:50px;border-radius:50%;color:#fff;font-size:.9rem;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.about-team-icon-wrap{width:50px;height:50px;min-width:50px;background:var(--primary-light);border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--primary)}
.about-team-card h3{font-size:.9375rem;font-weight:700;margin-bottom:2px}
.about-team-role{font-size:.74rem;color:var(--muted);margin-bottom:10px}
.about-team-phone,.about-team-zalo{display:flex;align-items:center;gap:6px;font-size:.8rem;margin-bottom:5px;transition:color var(--transition)}
.about-team-phone{color:var(--text-2)}
.about-team-phone:hover{color:var(--primary)}
.about-team-zalo{color:#0068ff}
.contact-hero{background:var(--bg-dark);color:#fff;padding:44px 0}
.contact-hero-inner{display:grid;grid-template-columns:1fr;gap:28px}
@media(min-width:900px){.contact-hero-inner{grid-template-columns:1fr 1.2fr;gap:52px;align-items:start}}
.contact-hero-text h1{color:#fff;margin-bottom:12px}
.contact-hero-cards{display:flex;flex-direction:column;gap:10px}
.contact-info-card{display:flex;align-items:center;gap:14px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-lg);padding:15px 16px;text-decoration:none;color:#fff;transition:background var(--transition)}
.contact-info-card:hover{background:rgba(255,255,255,.12)}
.contact-info-icon{width:40px;height:40px;border-radius:8px;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#fff}
.contact-info-card strong{display:block;font-size:.88rem;font-weight:700}
.contact-info-card span{font-size:.74rem;color:rgba(255,255,255,.5)}
.contact-arrow{margin-left:auto;color:rgba(255,255,255,.35)}
.contact-body{padding:44px 0 64px}
.contact-body-grid{display:grid;grid-template-columns:1fr;gap:32px}
@media(min-width:900px){.contact-body-grid{grid-template-columns:1.2fr 1fr;gap:48px}}
.contact-form-wrap h2{margin-bottom:8px}
.contact-hours-card,.contact-address-card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;margin-bottom:14px}
.contact-hours-card h3,.contact-address-card h3{font-size:.875rem;font-weight:700;display:flex;align-items:center;gap:7px;margin-bottom:12px}
.hours-table{width:100%;border-collapse:collapse;font-size:.84rem}
.hours-table td{padding:5px 0;color:var(--text-2)}
.hours-table td:last-child{text-align:right;font-weight:600;color:var(--text)}
.hours-table tr.closed td{color:var(--muted)}
.hours-note{font-size:.72rem;color:var(--muted);margin-top:10px;display:flex;align-items:center;gap:5px}
.contact-map{border-radius:var(--radius);overflow:hidden}
.tc-hero{padding-top:44px!important;padding-bottom:44px!important}
.tc-hero h1{color:#fff;margin-bottom:12px}
.tc-hero-btns{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:36px}
.tc-eyebrow{color:#ffd700!important}
.tc-hero-inner{display:grid;grid-template-columns:1fr;gap:28px}
@media(min-width:900px){.tc-hero-inner{grid-template-columns:1fr 1fr;gap:52px;align-items:center}}
.tc-hero-features{display:flex;flex-direction:column;gap:12px}
.tc-feature-item{display:flex;align-items:flex-start;gap:12px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);border-radius:10px;padding:14px 16px}
.tc-feature-icon{color:#ffd700;flex-shrink:0;margin-top:2px}
.tc-feature-item strong{display:block;color:#fff;font-size:.875rem;margin-bottom:2px}
.tc-feature-item span{font-size:.76rem;color:rgba(255,255,255,.7)}
.tc-services-grid{display:grid;grid-template-columns:1fr;gap:18px}
@media(min-width:640px){.tc-services-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.tc-services-grid{grid-template-columns:repeat(3,1fr)}}
.tc-service-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;display:flex;flex-direction:column;gap:10px;transition:border-color var(--transition)}
.tc-service-card:hover{border-color:var(--primary)}
.tc-service-icon-wrap{width:48px;height:48px;border-radius:10px;background:var(--primary-light);display:flex;align-items:center;justify-content:center;color:var(--primary);transition:background var(--transition),color var(--transition)}
.tc-service-card:hover .tc-service-icon-wrap{background:var(--primary);color:#fff}
.tc-service-features{list-style:none;display:flex;flex-direction:column;gap:5px;padding:10px 0;border-top:1px solid var(--border)}
.tc-service-features li{font-size:.8rem;color:var(--text-2);display:flex;align-items:center;gap:7px}
.tc-service-cta{display:inline-flex;align-items:center;gap:5px;font-size:.8rem;font-weight:700;color:var(--primary);margin-top:auto}
.tc-process{display:flex;flex-direction:column;max-width:680px;margin:0 auto}
.tc-step{display:flex}
.tc-step-left{display:flex;flex-direction:column;align-items:center;flex-shrink:0;width:60px}
.tc-step-num{width:46px;height:46px;border-radius:50%;background:var(--primary);color:#fff;font-size:.78rem;font-weight:800;display:flex;align-items:center;justify-content:center}
.tc-step-line{flex:1;width:2px;background:linear-gradient(var(--primary),var(--primary-light));margin:4px auto;min-height:36px}
.tc-step-right{display:flex;flex-direction:column;gap:5px;padding:8px 0 28px 16px}
.tc-step:last-child .tc-step-right{padding-bottom:0}
.tc-step-icon-wrap{width:38px;height:38px;border-radius:8px;background:var(--primary-light);color:var(--primary);display:flex;align-items:center;justify-content:center;margin-bottom:3px}
.tc-step-right h3{font-size:.9375rem;font-weight:700;color:var(--text);margin:0}
.tc-step-right p{font-size:.82rem;color:var(--muted);line-height:1.6;margin:0}
.tc-commits-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
@media(min-width:768px){.tc-commits-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:1024px){.tc-commits-grid{grid-template-columns:repeat(6,1fr);gap:16px}}
.tc-commit-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px 14px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:8px;transition:border-color var(--transition)}
.tc-commit-card:hover{border-color:var(--primary)}
.tc-commit-icon{width:48px;height:48px;border-radius:10px;background:var(--primary-light);display:flex;align-items:center;justify-content:center;color:var(--primary)}
.tc-contact-section{background:linear-gradient(135deg,#0a2463,var(--primary));padding:52px 0}
.tc-contact-grid{display:grid;grid-template-columns:1fr;gap:36px}
@media(min-width:900px){.tc-contact-grid{grid-template-columns:1fr 1fr;align-items:start}}
.tc-contact-list{display:flex;flex-direction:column;gap:12px}
.tc-contact-item{display:flex;gap:14px;align-items:flex-start;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);border-radius:10px;padding:14px 16px;text-decoration:none;color:#fff;transition:background var(--transition)}
.tc-contact-item:hover{background:rgba(255,255,255,.18)}
.tc-contact-icon{width:40px;height:40px;min-width:40px;border-radius:8px;background:rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}
.tc-contact-right{background:var(--bg);border-radius:var(--radius-lg);padding:28px;box-shadow:0 20px 60px rgba(0,0,0,.2)}
.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:480px){.form-row-2{grid-template-columns:1fr}}
.section-eyebrow{font-size:.7rem;font-weight:700;color:var(--primary);text-transform:uppercase;letter-spacing:.1em;margin-bottom:10px;display:block}
/* ================================================================
   NEWS PAGES — Professional layout
   ================================================================ */

/* Header */
.news-header { background:#0a2463; padding:40px 0 32px; color:#fff; }
.news-header-inner { display:flex; justify-content:space-between; align-items:flex-end; gap:20px; flex-wrap:wrap; margin-top:12px; }
.news-header-title { color:#fff; font-size:clamp(1.5rem,4vw,2.2rem); margin:0; }
.news-header-desc  { color:rgba(255,255,255,.65); font-size:.9rem; margin:6px 0 0; }
.news-search { display:flex; align-self:flex-end; }
.news-search input { width:220px; height:40px; padding:0 14px; border:1px solid rgba(255,255,255,.2); border-right:none; border-radius:var(--radius) 0 0 var(--radius); background:rgba(255,255,255,.1); color:#fff; font-size:.85rem; outline:none; font-family:inherit; }
.news-search input::placeholder { color:rgba(255,255,255,.45); }
.news-search input:focus { border-color:rgba(255,255,255,.5); }
.news-search button { width:40px; height:40px; background:#1565c0; color:#fff; border:none; border-radius:0 var(--radius) var(--radius) 0; cursor:pointer; display:flex; align-items:center; justify-content:center; }
@media(max-width:580px) { .news-search { display:none; } }

/* Category tabs sticky */
.news-cats-sticky { background:var(--bg); border-bottom:1px solid var(--border); position:sticky; top:64px; z-index:99; }
@media(min-width:768px) { .news-cats-sticky { top:72px; } }
.news-cats-scroll { display:flex; overflow-x:auto; gap:0; scrollbar-width:none; -webkit-overflow-scrolling:touch; }
.news-cats-scroll::-webkit-scrollbar { display:none; }
.news-cat-pill { display:inline-flex; align-items:center; gap:7px; padding:11px 18px; font-size:.82rem; font-weight:600; color:var(--muted); white-space:nowrap; flex-shrink:0; border-bottom:2px solid transparent; transition:color var(--transition),border-color var(--transition); text-decoration:none; }
.news-cat-pill:hover { color:var(--text); }
.news-cat-pill.active { color:var(--primary); border-bottom-color:var(--primary); }
.news-cat-pill span { font-size:.65rem; background:var(--bg-2); padding:1px 7px; border-radius:100px; color:var(--muted); }
.news-cat-pill.active span { background:var(--primary-light); color:var(--primary); }

/* Body */
.news-body { padding:36px 0 72px; }

/* Featured card */
.news-featured-card { display:grid; grid-template-columns:1fr; gap:0; border:1px solid var(--border); border-radius:14px; overflow:hidden; margin-bottom:32px; background:var(--bg); transition:border-color var(--transition); }
@media(min-width:768px) { .news-featured-card { grid-template-columns:1.5fr 1fr; } }
.news-featured-card:hover { border-color:var(--primary); }
.nfc-thumb { display:block; overflow:hidden; aspect-ratio:16/9; background:var(--bg-2); position:relative; flex-shrink:0; }
@media(min-width:768px) { .nfc-thumb { aspect-ratio:auto; min-height:300px; } }
.nfc-thumb img { width:100%; height:100%; object-fit:cover; transition:transform .4s ease; display:block; }
.news-featured-card:hover .nfc-thumb img { transform:scale(1.03); }
.nfc-no-thumb { width:100%; height:100%; min-height:220px; display:flex; align-items:center; justify-content:center; background:var(--bg-2); color:var(--primary); opacity:.2; }
.nfc-cat-badge { position:absolute; top:14px; left:14px; background:var(--primary); color:#fff; font-size:.7rem; font-weight:700; padding:4px 12px; border-radius:100px; z-index:1; }
.nfc-body { padding:28px 32px; display:flex; flex-direction:column; gap:12px; }
.nfc-meta { display:flex; align-items:center; gap:8px; font-size:.76rem; color:var(--muted); }
.nfc-dot { opacity:.4; }
.nfc-body h2 { font-size:clamp(1.15rem,2.5vw,1.55rem); line-height:1.3; margin:0; }
.nfc-body h2 a { color:var(--text); }
.nfc-body h2 a:hover { color:var(--primary); }
.nfc-body > p { font-size:.88rem; color:var(--muted); line-height:1.7; flex:1; margin:0; }
.nfc-read-btn { display:inline-flex; align-items:center; gap:5px; font-size:.84rem; font-weight:700; color:var(--primary); margin-top:auto; transition:gap var(--transition); }
.nfc-read-btn:hover { gap:9px; }

/* News grid */
.news-grid { display:grid; grid-template-columns:1fr; gap:20px; }
@media(min-width:540px)  { .news-grid { grid-template-columns:repeat(2,1fr); } }
@media(min-width:1024px) { .news-grid { grid-template-columns:repeat(3,1fr); } }
.news-grid--full { /* category page — no featured */ }

/* News card */
.nc { background:var(--bg); border:1px solid var(--border); border-radius:12px; overflow:hidden; display:flex; flex-direction:column; transition:border-color var(--transition),box-shadow var(--transition),transform var(--transition); }
.nc:hover { border-color:var(--primary); box-shadow:0 4px 20px rgba(21,101,192,.1); transform:translateY(-3px); }
.nc-thumb { display:block; overflow:hidden; aspect-ratio:16/9; background:var(--bg-2); flex-shrink:0; }
.nc-thumb img { width:100%; height:100%; object-fit:cover; transition:transform .35s ease; display:block; }
.nc:hover .nc-thumb img { transform:scale(1.05); }
.nc-no-thumb { width:100%; height:100%; min-height:140px; display:flex; align-items:center; justify-content:center; background:var(--bg-2); color:var(--primary); opacity:.2; }
.nc-body { padding:16px 18px 20px; flex:1; display:flex; flex-direction:column; gap:7px; }
.nc-cat { font-size:.66rem; font-weight:700; color:var(--primary); text-transform:uppercase; letter-spacing:.05em; }
.nc-body h3 { font-size:.9rem; font-weight:700; line-height:1.4; margin:0; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.nc-body h3 a { color:var(--text); }
.nc-body h3 a:hover { color:var(--primary); }
.nc-excerpt { font-size:.78rem; color:var(--muted); line-height:1.6; flex:1; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.nc-meta { display:flex; align-items:center; gap:6px; font-size:.7rem; color:var(--muted); margin-top:auto; }

/* Pagination */
.news-pagination { display:flex; justify-content:center; align-items:center; gap:5px; flex-wrap:wrap; margin-top:44px; }
.news-pagination a, .news-pagination span { display:flex; align-items:center; justify-content:center; min-width:40px; height:40px; padding:0 6px; border:1px solid var(--border); border-radius:var(--radius); font-size:.84rem; font-weight:600; color:var(--text-2); transition:all var(--transition); text-decoration:none; }
.news-pagination a:hover { background:var(--primary-light); border-color:var(--primary); color:var(--primary); }
.news-pagination .current { background:var(--primary); border-color:var(--primary); color:#fff; }
.news-pagination svg { display:block; }
.news-pagination a:first-child svg { transform:rotate(180deg); }
.news-pagination .dots { border:none; color:var(--muted); pointer-events:none; }

/* Empty */
.news-empty { text-align:center; padding:72px 0; display:flex; flex-direction:column; align-items:center; gap:14px; color:var(--muted); }

/* ================================================================
   SINGLE POST — Clean, full-width
   ================================================================ */

/* Progress bar */
#reading-progress { position:fixed; top:0; left:0; height:3px; width:0; background:linear-gradient(90deg,#1565c0,#0288d1); z-index:9999; transition:width .1s linear; pointer-events:none; }

/* Breadcrumb bar */
.sp-bc-bar { background:var(--bg-2); border-bottom:1px solid var(--border); padding:10px 0; }
.sp-bc-inner { display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:8px; }
.sp-bc-time { display:flex; align-items:center; gap:5px; font-size:.74rem; color:var(--muted); white-space:nowrap; }

/* Article wrapper */
.sp-article-wrap { padding:36px 0 72px; }
@media(min-width:768px) { .sp-article-wrap { padding:48px 0 88px; } }

/* 2-column layout */
.sp-article-layout { display:grid; grid-template-columns:1fr; gap:36px; align-items:start; }
@media(min-width:960px) { .sp-article-layout { grid-template-columns:minmax(0,1fr) 300px; gap:48px; } }

.sp-article-main { min-width:0; }
.sp-article-sidebar { min-width:0; display:flex; flex-direction:column; gap:20px; }
@media(min-width:960px) { .sp-article-sidebar { position:sticky; top:90px; } }

/* Article */
.sp-article { min-width:0; }
.sp-cats-row { display:flex; flex-wrap:wrap; gap:6px; margin-bottom:14px; }
.sp-cat-badge { display:inline-block; padding:3px 12px; border-radius:100px; background:var(--primary-light); color:var(--primary); font-size:.68rem; font-weight:700; text-transform:uppercase; letter-spacing:.05em; }

.sp-article-title { font-size:clamp(1.45rem,4vw,2.3rem); line-height:1.25; margin-bottom:18px; color:var(--text); word-break:break-word; }

/* Meta bar */
.sp-meta-bar { display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:12px; padding:14px 0; border-top:1px solid var(--border); border-bottom:1px solid var(--border); margin-bottom:24px; }
.sp-meta-left { display:flex; align-items:center; gap:10px; }
.sp-author-avatar { width:36px !important; height:36px !important; border-radius:50%; object-fit:cover; flex-shrink:0; }
.sp-meta-info { line-height:1.3; }
.sp-author-name { font-size:.85rem; font-weight:700; color:var(--text); display:block; }
.sp-author-name:hover { color:var(--primary); }
.sp-meta-date { display:flex; align-items:center; gap:6px; font-size:.74rem; color:var(--muted); margin-top:2px; }
.sp-meta-updated { color:var(--muted); }
.sp-meta-right { display:flex; align-items:center; gap:8px; }
.sp-share-btn { display:inline-flex; align-items:center; gap:5px; padding:5px 12px; border-radius:100px; font-size:.74rem; font-weight:600; border:1px solid var(--border); color:var(--text-2); transition:all var(--transition); text-decoration:none; }
.sp-share-btn.sp-share-fb { border-color:#1877f2; color:#1877f2; }
.sp-share-btn.sp-share-fb:hover { background:#1877f2; color:#fff; }

/* Hero image */
.sp-hero-img { width:100%; border-radius:14px; overflow:hidden; margin-bottom:28px; line-height:0; }
.sp-hero-img img { width:100%; height:auto; max-height:540px; object-fit:cover; display:block; }
.sp-hero-img figcaption { font-size:.74rem; color:var(--muted); text-align:center; padding:8px 12px; background:var(--bg-2); line-height:1.5; }

/* Content */
.sp-content { font-size:.9375rem; line-height:1.85; color:var(--text-2); overflow:hidden; width:100%; }
.sp-content > * { margin-bottom:1.1rem; }
.sp-content > *:last-child { margin-bottom:0; }
.sp-content h2 { font-size:clamp(1.1rem,3vw,1.4rem); font-weight:700; color:var(--text); margin-top:2rem; margin-bottom:.7rem; padding-bottom:.4rem; border-bottom:2px solid var(--primary-light); }
.sp-content h2:first-child { margin-top:0; }
.sp-content h3 { font-size:1.05rem; font-weight:700; color:var(--text); margin-top:1.6rem; margin-bottom:.5rem; padding-left:10px; border-left:3px solid var(--primary); }
.sp-content h4 { font-size:.9375rem; font-weight:700; margin-top:1.4rem; }
.sp-content p { color:var(--text-2); margin-bottom:1.1rem; }
.sp-content a { color:var(--primary); text-decoration:underline; text-underline-offset:2px; }
.sp-content img { display:block; width:100%; max-width:800px; height:auto !important; margin:1.4rem auto; border-radius:var(--radius); box-sizing:border-box; }
.sp-content figure { margin:1.4rem auto; max-width:800px; }
.sp-content figure img { margin:0 auto; }
.sp-content figcaption { font-size:.72rem; color:var(--muted); text-align:center; padding:6px; }
.sp-content ul, .sp-content ol { padding-left:1.3rem; margin-bottom:1.1rem; }
.sp-content ul { list-style:disc; }
.sp-content ol { list-style:decimal; }
.sp-content li { color:var(--text-2); margin-bottom:.35rem; line-height:1.65; }
.sp-content blockquote { border-left:3px solid var(--primary); background:var(--primary-light); padding:14px 18px; margin:1.4rem 0; border-radius:0 var(--radius) var(--radius) 0; font-style:italic; }
.sp-content blockquote p { color:var(--primary-dark,#0d47a1); margin:0; }
.sp-content table { width:100%; overflow-x:auto; display:block; margin:1.4rem 0; border:1px solid var(--border); border-radius:var(--radius); }
@media(min-width:640px) { .sp-content table { display:table; } }
.sp-content th { background:var(--primary); color:#fff; padding:9px 13px; text-align:left; font-size:.875rem; }
.sp-content td { padding:8px 13px; border-bottom:1px solid var(--border); font-size:.875rem; color:var(--text-2); }
.sp-content tr:last-child td { border-bottom:none; }
.sp-content tr:nth-child(even) td { background:var(--bg-2); }
.sp-content code { background:var(--bg-2); color:var(--primary); padding:1px 5px; border-radius:3px; font-size:.875em; font-family:monospace; }
.sp-content .alignleft  { float:left; margin:0 18px 14px 0; max-width:46%; }
.sp-content .alignright { float:right; margin:0 0 14px 18px; max-width:46%; }
.sp-content .aligncenter { margin-left:auto; margin-right:auto; display:block; }
@media(max-width:640px) { .sp-content .alignleft,.sp-content .alignright { float:none; margin:1rem 0; max-width:100%; } }
.sp-content::after { content:''; display:table; clear:both; }

/* Article footer: tags + share */
.sp-article-footer { margin-top:28px; padding-top:20px; border-top:1px solid var(--border); display:flex; flex-direction:column; gap:14px; }
.sp-tags-row { display:flex; flex-wrap:wrap; align-items:center; gap:7px; }
.sp-tags-row svg { color:var(--muted); flex-shrink:0; }
.sp-tag { padding:4px 12px; border-radius:100px; border:1px solid var(--border); font-size:.74rem; color:var(--muted); transition:all var(--transition); }
.sp-tag:hover { border-color:var(--primary); color:var(--primary); }
.sp-share-row { display:flex; flex-wrap:wrap; align-items:center; gap:8px; }
.sp-share-row > span { font-size:.76rem; color:var(--muted); font-weight:600; }
.sp-share-pill { display:inline-flex; align-items:center; gap:5px; padding:6px 14px; border-radius:100px; font-size:.74rem; font-weight:600; border:1.5px solid var(--border); cursor:pointer; background:var(--bg); color:var(--text-2); text-decoration:none; font-family:inherit; transition:all var(--transition); }
.sp-share-pill-fb   { border-color:#1877f2; color:#1877f2; }
.sp-share-pill-fb:hover   { background:#1877f2; color:#fff; }
.sp-share-pill-zalo { border-color:#0068ff; color:#0068ff; }
.sp-share-pill-zalo:hover { background:#0068ff; color:#fff; }
.sp-share-pill-copy:hover { border-color:var(--primary); color:var(--primary); }

/* Author box */
.sp-author-box { display:flex; gap:16px; align-items:flex-start; background:var(--bg-2); border:1px solid var(--border); border-left:4px solid var(--primary); border-radius:0 12px 12px 0; padding:20px; margin-top:28px; }
.sp-author-img { width:60px !important; height:60px !important; border-radius:50%; object-fit:cover; flex-shrink:0; box-shadow:0 0 0 3px var(--primary-light); }
.sp-author-detail { min-width:0; }
.sp-author-label { font-size:.66rem; color:var(--muted); font-weight:600; text-transform:uppercase; letter-spacing:.05em; display:block; }
.sp-author-name-lg { font-size:.95rem; font-weight:700; color:var(--text); display:block; }
.sp-author-name-lg:hover { color:var(--primary); }
.sp-author-detail > p { font-size:.8rem; color:var(--muted); margin:4px 0 0; line-height:1.6; }

/* Post navigation */
.sp-post-nav { display:grid; grid-template-columns:1fr; gap:10px; margin-top:24px; }
@media(min-width:580px) { .sp-post-nav { grid-template-columns:1fr 1fr; } }
.sp-nav-item { display:flex; flex-direction:column; gap:5px; padding:14px 16px; background:var(--bg-2); border:1px solid var(--border); border-radius:12px; text-decoration:none; transition:border-color var(--transition); min-width:0; }
.sp-nav-item:hover { border-color:var(--primary); }
.sp-nav-next { text-align:right; align-items:flex-end; }
.sp-nav-dir { font-size:.68rem; font-weight:700; color:var(--primary); text-transform:uppercase; letter-spacing:.05em; display:flex; align-items:center; gap:4px; }
.sp-nav-next .sp-nav-dir { flex-direction:row-reverse; }
.sp-nav-title { font-size:.84rem; font-weight:600; color:var(--text); line-height:1.4; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }

/* Related posts */
.sp-related { margin-top:44px; padding-top:32px; border-top:1px solid var(--border); }
.sp-related-title { font-size:1rem; font-weight:800; color:var(--text); margin-bottom:18px; display:flex; align-items:center; gap:10px; }
.sp-related-title::before { content:''; display:inline-block; width:4px; height:18px; background:var(--primary); border-radius:2px; }
.sp-related-grid { display:grid; grid-template-columns:1fr; gap:14px; }
@media(min-width:560px) { .sp-related-grid { grid-template-columns:repeat(2,1fr); } }
@media(min-width:900px) { .sp-related-grid { grid-template-columns:repeat(3,1fr); } }
.sp-rel-card { display:flex; flex-direction:column; background:var(--bg); border:1px solid var(--border); border-radius:10px; overflow:hidden; text-decoration:none; color:inherit; transition:border-color var(--transition); }
.sp-rel-card:hover { border-color:var(--primary); }
.sp-rel-thumb { aspect-ratio:16/9; overflow:hidden; background:var(--bg-2); }
.sp-rel-thumb img { width:100%; height:100%; object-fit:cover; transition:transform .35s ease; display:block; }
.sp-rel-card:hover .sp-rel-thumb img { transform:scale(1.05); }
.sp-rel-no-img { width:100%; height:100%; display:flex; align-items:center; justify-content:center; background:var(--bg-2); color:var(--primary); opacity:.2; }
.sp-rel-body { padding:12px 14px; display:flex; flex-direction:column; gap:4px; }
.sp-rel-body h3 { font-size:.84rem; font-weight:700; color:var(--text); line-height:1.4; margin:0; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.sp-rel-card:hover .sp-rel-body h3 { color:var(--primary); }
.sp-rel-body time { font-size:.68rem; color:var(--muted); }

/* SIDEBAR */
.sp-sidebar-cta { background:linear-gradient(135deg,#0a2463,#1565c0) !important; border-color:#1565c0 !important; text-align:center; }
.sp-cta-icon { margin:0 auto 10px; }
.sp-cta-icon svg { color:rgba(255,255,255,.2); margin:0 auto; }
.sp-sidebar-cta h3 { color:#fff; font-size:.95rem; margin-bottom:6px; }
.sp-sidebar-cta > p { color:rgba(255,255,255,.7); font-size:.8rem; margin-bottom:16px; }
.sp-cta-hours { display:flex; align-items:center; gap:6px; font-size:.72rem; color:rgba(255,255,255,.55); margin-top:12px; padding-top:12px; border-top:1px solid rgba(255,255,255,.15); }

.sp-sidebar-recent { display:flex; flex-direction:column; gap:0; list-style:none; padding:0; margin:0; }
.sp-recent-item { display:flex; align-items:flex-start; gap:10px; padding:9px 0; border-bottom:1px solid var(--border); }
.sp-recent-item:last-child { border-bottom:none; }
.sp-recent-thumb { width:56px; height:56px; border-radius:var(--radius); overflow:hidden; flex-shrink:0; background:var(--bg-2); display:block; }
.sp-recent-thumb img { width:100%; height:100%; object-fit:cover; }
.sp-recent-info { display:flex; flex-direction:column; gap:3px; min-width:0; }
.sp-recent-title { font-size:.8rem; font-weight:600; color:var(--text); line-height:1.4; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.sp-recent-title:hover { color:var(--primary); }
.sp-recent-info time { font-size:.68rem; color:var(--muted); }

/* TOC */
#toc-widget { display:none; background:var(--bg-2); }
.toc-list { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:2px; }
.toc-h3 { padding-left:12px; }
.toc-link { display:block; padding:6px 9px; font-size:.8rem; color:var(--muted); border-radius:5px; border-left:2px solid transparent; transition:all var(--transition); text-decoration:none; line-height:1.4; }
.toc-link:hover { background:var(--bg); color:var(--primary); border-left-color:var(--primary); }
.toc-link.active { background:var(--primary-light); color:var(--primary); border-left-color:var(--primary); font-weight:600; }

/* Mobile optimizations */
@media(max-width:480px) {
  .news-body { padding:24px 0 48px; }
  .nfc-body { padding:20px; }
  .sp-article-wrap { padding:24px 0 52px; }
  .sp-hero-img img { max-height:280px; }
  .sp-post-nav { grid-template-columns:1fr; }
  .sp-related-grid { grid-template-columns:1fr 1fr; }
}
@media(hover:none) {
  .nc:hover,.sp-rel-card:hover { transform:none; box-shadow:none; border-color:var(--border); }
}
/* ── BREADCRUMB BAR overrides ── */
.sp-bc-bar { background:var(--bg-2); border-bottom:1px solid var(--border); padding:10px 0; }
.sp-bc-inner { display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:8px; }
.sp-bc-time { display:flex; align-items:center; gap:5px; font-size:.74rem; color:var(--muted); white-space:nowrap; flex-shrink:0; }
/* Force breadcrumb no background in sp-bc-bar */
.sp-bc-inner nav,
.sp-bc-inner .breadcrumb,
.sp-bc-inner ol.breadcrumb__list {
  background:none !important;
  padding:0 !important;
  border-radius:0 !important;
  display:flex; flex-wrap:wrap; align-items:center; gap:3px 5px;
  font-size:.78rem; color:var(--muted);
}
.sp-bc-inner a { color:var(--muted); }
.sp-bc-inner a:hover { color:var(--primary); }
.sp-bc-inner li { display:inline-flex; align-items:center; gap:5px; list-style:none; font-size:.78rem; }
.sp-bc-inner li::after { content:'>'; color:var(--border-2,#d1d5db); font-size:.7rem; margin-left:2px; }
.sp-bc-inner li:last-child::after { display:none; }
.sp-bc-inner li:last-child a,
.sp-bc-inner li:last-child span { color:var(--text-2); font-weight:600; }

/* Meta bar */
.sp-meta-bar { display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:12px; padding:14px 0; border-top:1px solid var(--border); border-bottom:1px solid var(--border); margin-bottom:24px; }
.sp-meta-left { display:flex; align-items:center; gap:10px; min-width:0; }
.sp-author-avatar { width:36px !important; height:36px !important; border-radius:50%; object-fit:cover; flex-shrink:0; display:block; }
.sp-meta-info { line-height:1.3; min-width:0; }
.sp-author-name { font-size:.85rem; font-weight:700; color:var(--text); display:block; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.sp-author-name:hover { color:var(--primary); }
.sp-meta-date { display:flex; align-items:center; gap:5px; font-size:.74rem; color:var(--muted); margin-top:2px; flex-wrap:wrap; }
.sp-meta-right { display:flex; align-items:center; gap:8px; flex-shrink:0; }

/* Hero image */
.sp-hero-img { width:100%; border-radius:12px; overflow:hidden; margin-bottom:28px; line-height:0; }
.sp-hero-img img { width:100%; height:auto; max-height:540px; object-fit:cover; display:block; }
.sp-hero-img figcaption { font-size:.74rem; color:var(--muted); text-align:center; padding:8px 12px; background:var(--bg-2); line-height:1.5; }

/* Article title */
.sp-article-title { font-size:clamp(1.45rem,4vw,2.2rem); line-height:1.25; margin-bottom:16px; color:var(--text); word-break:break-word; }

/* Article layout */
.sp-article-wrap { padding:32px 0 64px; }
@media(min-width:768px) { .sp-article-wrap { padding:44px 0 80px; } }
.sp-article-layout { display:grid; grid-template-columns:1fr; gap:32px; align-items:start; }
@media(min-width:960px) { .sp-article-layout { grid-template-columns:minmax(0,1fr) 300px; gap:48px; } }
.sp-article-main { min-width:0; }
.sp-article-sidebar { min-width:0; display:flex; flex-direction:column; gap:18px; }
@media(min-width:960px) { .sp-article-sidebar { position:sticky; top:86px; } }
/* ================================================================
   SINGLE POST v2 — Beautiful article layout
   ================================================================ */

/* Progress bar */
#reading-progress { position:fixed; top:0; left:0; height:3px; width:0; background:linear-gradient(90deg,#1565c0,#0288d1); z-index:9999; transition:width .1s linear; pointer-events:none; border-radius:0 3px 3px 0; }

/* Hero image */
.sp2-hero { width:100%; max-height:520px; overflow:hidden; position:relative; }
.sp2-hero img { width:100%; height:100%; object-fit:cover; display:block; max-height:520px; }
.sp2-hero-overlay { position:absolute; bottom:0; left:0; right:0; height:120px; background:linear-gradient(to top, rgba(10,36,99,.5), transparent); }

/* Wrap */
.sp2-wrap { padding:32px 0 72px; }
@media(min-width:768px) { .sp2-wrap { padding:44px 0 88px; } }

/* ── BREADCRUMB ── */
.sp2-breadcrumb {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 4px;
  font-size: .78rem;
  color: var(--muted);
  margin-bottom: 22px;
  padding: 10px 14px;
  background: var(--bg-2);
  border-radius: var(--radius);
  border-left: 3px solid var(--primary);
}
.sp2-breadcrumb a {
  color: var(--text-2);
  font-weight: 500;
  transition: color var(--transition);
  white-space: nowrap;
}
.sp2-breadcrumb a:hover { color: var(--primary); }
.sp2-bc-sep { display:inline-flex; align-items:center; color:var(--border-2,#d1d5db); flex-shrink:0; }
.sp2-bc-sep svg { width:14px; height:14px; }
.sp2-bc-current { color:var(--muted); font-weight:500; }

/* Layout 2 cột */
.sp2-layout { display:grid; grid-template-columns:1fr; gap:32px; align-items:start; }
@media(min-width:960px) { .sp2-layout { grid-template-columns:minmax(0,1fr) 300px; gap:48px; } }
.sp2-main   { min-width:0; }
.sp2-sidebar { min-width:0; display:flex; flex-direction:column; gap:18px; }
@media(min-width:960px) { .sp2-sidebar { position:sticky; top:86px; } }

/* Article */
.sp2-article { min-width:0; }
.sp2-cats { display:flex; flex-wrap:wrap; gap:6px; margin-bottom:12px; }
.sp2-cat-tag { display:inline-block; padding:3px 12px; border-radius:100px; background:var(--primary-light); color:var(--primary); font-size:.68rem; font-weight:700; text-transform:uppercase; letter-spacing:.05em; transition:background var(--transition); }
.sp2-cat-tag:hover { background:var(--primary); color:#fff; }

/* Title */
.sp2-title { font-size:clamp(1.5rem,4vw,2.3rem); line-height:1.22; margin-bottom:18px; color:var(--text); word-break:break-word; font-weight:800; letter-spacing:-.02em; }

/* Meta */
.sp2-meta { display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:12px; padding:14px 0; border-top:1px solid var(--border); border-bottom:1px solid var(--border); margin-bottom:28px; }
.sp2-meta-author { display:flex; align-items:center; gap:10px; min-width:0; }
.sp2-avatar { width:40px !important; height:40px !important; border-radius:50%; object-fit:cover; flex-shrink:0; border:2px solid var(--primary-light); display:block; }
.sp2-meta-text { line-height:1.3; min-width:0; }
.sp2-meta-name { font-size:.875rem; font-weight:700; color:var(--text); display:block; }
.sp2-meta-name:hover { color:var(--primary); }
.sp2-meta-row { display:flex; align-items:center; gap:6px; font-size:.73rem; color:var(--muted); margin-top:3px; flex-wrap:wrap; }
.sp2-meta-row time { display:flex; align-items:center; gap:4px; }
.sp2-meta-row svg { width:13px; height:13px; flex-shrink:0; }
.sp2-meta-sep { opacity:.4; }
.sp2-meta-upd { font-style:italic; }
.sp2-meta-share { flex-shrink:0; }
.sp2-share-pill { display:inline-flex; align-items:center; gap:5px; padding:6px 14px; border-radius:100px; font-size:.76rem; font-weight:600; border:1.5px solid currentColor; cursor:pointer; background:transparent; font-family:inherit; transition:all var(--transition); text-decoration:none; }
.sp2-share-fb   { color:#1877f2; border-color:#1877f2; }
.sp2-share-fb:hover   { background:#1877f2; color:#fff; }
.sp2-share-zalo { color:#0068ff; border-color:#0068ff; }
.sp2-share-zalo:hover { background:#0068ff; color:#fff; }
.sp2-share-copy { color:var(--muted); border-color:var(--border-2); }
.sp2-share-copy:hover { border-color:var(--primary); color:var(--primary); }

/* Content */
.sp2-content { font-size:.9375rem; line-height:1.85; color:var(--text-2); overflow:hidden; width:100%; }
.sp2-content > * { margin-bottom:1.1rem; }
.sp2-content > *:last-child { margin-bottom:0; }
.sp2-content h2 { font-size:clamp(1.1rem,3vw,1.4rem); font-weight:800; color:var(--text); margin-top:2.2rem; margin-bottom:.75rem; padding-bottom:.4rem; border-bottom:2px solid var(--primary-light); letter-spacing:-.01em; }
.sp2-content h2:first-child { margin-top:0; }
.sp2-content h3 { font-size:1.05rem; font-weight:700; color:var(--text); margin-top:1.8rem; margin-bottom:.5rem; padding-left:12px; border-left:3px solid var(--primary); }
.sp2-content h4 { font-size:.9375rem; font-weight:700; margin-top:1.4rem; }
.sp2-content p { color:var(--text-2); margin-bottom:1.1rem; }
.sp2-content a { color:var(--primary); text-decoration:underline; text-underline-offset:2px; }
.sp2-content img { display:block; width:100%; max-width:800px; height:auto !important; margin:1.6rem auto; border-radius:var(--radius-lg); box-sizing:border-box; box-shadow:0 4px 16px rgba(0,0,0,.08); }
.sp2-content figure { margin:1.6rem auto; max-width:800px; width:100%; }
.sp2-content figure img { margin:0 auto; box-shadow:none; }
.sp2-content figcaption { font-size:.74rem; color:var(--muted); text-align:center; padding:8px 12px; background:var(--bg-2); border-radius:0 0 var(--radius) var(--radius); font-style:italic; }
.sp2-content ul,.sp2-content ol { padding-left:1.4rem; margin-bottom:1.1rem; }
.sp2-content ul { list-style:disc; }
.sp2-content ol { list-style:decimal; }
.sp2-content li { color:var(--text-2); margin-bottom:.4rem; line-height:1.7; }
.sp2-content blockquote { border-left:3px solid var(--primary); background:var(--primary-light); padding:16px 20px; margin:1.6rem 0; border-radius:0 var(--radius-lg) var(--radius-lg) 0; font-style:italic; }
.sp2-content blockquote p { color:#0d47a1; margin:0; font-size:.95rem; }
.sp2-content table { width:100%; overflow-x:auto; display:block; margin:1.6rem 0; border:1px solid var(--border); border-radius:var(--radius); }
@media(min-width:640px) { .sp2-content table { display:table; } }
.sp2-content th { background:var(--primary); color:#fff; padding:10px 14px; text-align:left; font-size:.875rem; }
.sp2-content td { padding:9px 14px; border-bottom:1px solid var(--border); font-size:.875rem; color:var(--text-2); }
.sp2-content tr:last-child td { border-bottom:none; }
.sp2-content tr:nth-child(even) td { background:var(--bg-2); }
.sp2-content code { background:var(--bg-2); color:var(--primary); padding:2px 6px; border-radius:4px; font-size:.875em; font-family:monospace; }
.sp2-content .alignleft  { float:left; margin:0 18px 14px 0; max-width:46%; }
.sp2-content .alignright { float:right; margin:0 0 14px 18px; max-width:46%; }
.sp2-content .aligncenter { margin-left:auto; margin-right:auto; display:block; }
@media(max-width:640px) { .sp2-content .alignleft,.sp2-content .alignright { float:none; margin:1rem 0; max-width:100%; } }
.sp2-content::after { content:''; display:table; clear:both; }

/* Footer tags + share */
.sp2-footer { margin-top:28px; padding-top:20px; border-top:1px solid var(--border); display:flex; flex-direction:column; gap:14px; }
.sp2-tags { display:flex; flex-wrap:wrap; align-items:center; gap:7px; }
.sp2-tags svg { color:var(--muted); width:15px; height:15px; flex-shrink:0; }
.sp2-tag { padding:4px 12px; border-radius:100px; border:1px solid var(--border); font-size:.74rem; color:var(--muted); transition:all var(--transition); }
.sp2-tag:hover { border-color:var(--primary); color:var(--primary); background:var(--primary-light); }
.sp2-share-row { display:flex; flex-wrap:wrap; align-items:center; gap:8px; }
.sp2-share-row > span { font-size:.78rem; color:var(--muted); font-weight:600; }

/* Author box */
.sp2-author-box { display:flex; gap:18px; align-items:flex-start; background:var(--bg-2); border:1px solid var(--border); border-left:4px solid var(--primary); border-radius:0 var(--radius-lg) var(--radius-lg) 0; padding:22px; margin-top:30px; }
.sp2-author-img { width:68px !important; height:68px !important; border-radius:50%; object-fit:cover; flex-shrink:0; box-shadow:0 0 0 3px var(--bg), 0 0 0 5px var(--primary-light); }
.sp2-author-info { min-width:0; }
.sp2-author-label { font-size:.66rem; color:var(--muted); font-weight:700; text-transform:uppercase; letter-spacing:.07em; display:block; margin-bottom:3px; }
.sp2-author-name { font-size:1rem; font-weight:800; color:var(--text); display:block; margin-bottom:6px; }
.sp2-author-name:hover { color:var(--primary); }
.sp2-author-info > p { font-size:.82rem; color:var(--muted); margin:0; line-height:1.65; }

/* Post nav */
.sp2-post-nav { display:grid; grid-template-columns:1fr; gap:10px; margin-top:26px; }
@media(min-width:580px) { .sp2-post-nav { grid-template-columns:1fr 1fr; } }
.sp2-nav-item { display:flex; flex-direction:column; gap:6px; padding:14px 18px; background:var(--bg); border:1.5px solid var(--border); border-radius:var(--radius-lg); text-decoration:none; transition:all var(--transition); min-width:0; }
.sp2-nav-item:hover { border-color:var(--primary); background:var(--primary-light); }
.sp2-nav-next { text-align:right; align-items:flex-end; }
.sp2-nav-dir { font-size:.68rem; font-weight:800; color:var(--primary); text-transform:uppercase; letter-spacing:.06em; display:flex; align-items:center; gap:3px; }
.sp2-nav-next .sp2-nav-dir { flex-direction:row-reverse; }
.sp2-nav-dir svg { width:14px; height:14px; }
.sp2-nav-title { font-size:.84rem; font-weight:600; color:var(--text); line-height:1.4; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }

/* Related */
.sp2-related { margin-top:44px; padding-top:32px; border-top:2px solid var(--primary-light); }
.sp2-related-title { font-size:1.1rem; font-weight:800; color:var(--text); margin-bottom:20px; display:flex; align-items:center; gap:10px; }
.sp2-related-title::before { content:''; display:inline-block; width:4px; height:20px; background:var(--primary); border-radius:2px; }
.sp2-related-grid { display:grid; grid-template-columns:1fr; gap:14px; }
@media(min-width:560px) { .sp2-related-grid { grid-template-columns:repeat(2,1fr); } }
@media(min-width:900px) { .sp2-related-grid { grid-template-columns:repeat(3,1fr); } }
.sp2-rel-item { display:flex; flex-direction:column; background:var(--bg); border:1.5px solid var(--border); border-radius:var(--radius-lg); overflow:hidden; text-decoration:none; color:inherit; transition:all var(--transition); }
.sp2-rel-item:hover { border-color:var(--primary); box-shadow:0 4px 16px rgba(21,101,192,.1); transform:translateY(-2px); }
.sp2-rel-thumb { aspect-ratio:16/9; overflow:hidden; background:var(--bg-2); flex-shrink:0; }
.sp2-rel-thumb img { width:100%; height:100%; object-fit:cover; transition:transform .35s ease; display:block; }
.sp2-rel-item:hover .sp2-rel-thumb img { transform:scale(1.05); }
.sp2-rel-noimg { width:100%; height:100%; display:flex; align-items:center; justify-content:center; background:var(--primary-light); color:var(--primary); opacity:.3; }
.sp2-rel-body { padding:12px 14px; flex:1; }
.sp2-rel-body h3 { font-size:.84rem; font-weight:700; color:var(--text); line-height:1.4; margin:0 0 5px; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.sp2-rel-item:hover .sp2-rel-body h3 { color:var(--primary); }
.sp2-rel-body time { font-size:.68rem; color:var(--muted); }

/* SIDEBAR */
.sp2-cta-widget { background:linear-gradient(145deg,#0a2463,#1565c0) !important; border-color:#1565c0 !important; text-align:center; }
.sp2-cta-head { margin:0 auto 10px; color:rgba(255,255,255,.25); }
.sp2-cta-head svg { width:36px; height:36px; margin:0 auto; }
.sp2-cta-widget h3 { color:#fff; font-size:1rem; margin-bottom:6px; }
.sp2-cta-widget > p { color:rgba(255,255,255,.72); font-size:.82rem; margin-bottom:16px; }
.sp2-cta-hours { font-size:.72rem; color:rgba(255,255,255,.5); margin-top:12px; padding-top:10px; border-top:1px solid rgba(255,255,255,.12); display:flex; align-items:center; justify-content:center; gap:5px; }
.sp2-cta-hours svg { width:13px; height:13px; flex-shrink:0; }
.sp2-recent-item { display:flex; gap:10px; padding:9px 0; border-bottom:1px solid var(--border); }
.sp2-recent-item:last-child { border-bottom:none; }
.sp2-recent-thumb { flex-shrink:0; width:58px; height:58px; border-radius:var(--radius); overflow:hidden; display:block; background:var(--bg-2); }
.sp2-recent-thumb img { width:100%; height:100%; object-fit:cover; }
.sp2-recent-info { display:flex; flex-direction:column; gap:4px; min-width:0; }
.sp2-recent-info a { font-size:.8rem; font-weight:600; color:var(--text); line-height:1.4; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.sp2-recent-info a:hover { color:var(--primary); }
.sp2-recent-info time { font-size:.68rem; color:var(--muted); }

/* TOC */
#toc-widget { display:none; background:var(--bg-2); }
.toc-list { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:2px; }
.toc-h3 { padding-left:12px; }
.toc-link { display:block; padding:6px 10px; font-size:.8rem; color:var(--muted); border-radius:5px; border-left:2px solid transparent; transition:all var(--transition); text-decoration:none; line-height:1.4; }
.toc-link:hover { background:var(--bg); color:var(--primary); border-left-color:var(--primary); }
.toc-link.active { background:var(--primary-light); color:var(--primary); border-left-color:var(--primary); font-weight:700; }

/* ── BREADCRUMB TOÀN SITE ── */
/* Reset cứng — xóa mọi background pill */
.breadcrumb, nav.breadcrumb, .sp2-breadcrumb,
.yoast-breadcrumb, .rank-math-breadcrumb,
ol.breadcrumb__list { background:none !important; padding:0 !important; border-radius:0 !important; border:none !important; margin:0 !important; }

/* Mobile */
@media(max-width:480px) {
  .sp2-title { font-size:1.5rem; }
  .sp2-layout { gap:24px; }
  .sp2-related-grid { grid-template-columns:1fr 1fr; }
  .sp2-post-nav { grid-template-columns:1fr; }
  .sp2-author-box { flex-direction:column; align-items:center; text-align:center; }
}
@media(hover:none) {
  .sp2-rel-item:hover { transform:none; box-shadow:none; border-color:var(--border); }
}
.spv-bc-bar{background:var(--bg-2);border-bottom:1px solid var(--border);padding:10px 0}.spv-bc{display:flex;flex-wrap:wrap;align-items:center;gap:3px;font-size:.78rem;color:var(--muted)}.spv-bc a{color:var(--text-2);font-weight:500}.spv-bc a:hover{color:var(--primary)}.spv-bc-sep{display:inline-flex;align-items:center;color:var(--border-2)}.spv-bc-sep svg{width:13px;height:13px}.spv-bc-cur{color:var(--muted)}.spv-top-section{padding:28px 0 0;background:var(--bg)}.spv-top-grid{display:grid;grid-template-columns:1fr;gap:28px}@media(min-width:768px){.spv-top-grid{grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:40px;align-items:start}}@media(min-width:1024px){.spv-top-grid{grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr);gap:56px}}.spv-gallery-col{display:flex;flex-direction:column;gap:10px;min-width:0}.spv-main-box{position:relative;background:var(--bg-2);border:1px solid var(--border);border-radius:14px;overflow:hidden;aspect-ratio:1;display:flex;align-items:center;justify-content:center}.spv-main-img{width:100%;height:100%;object-fit:contain;display:block;transition:transform .3s ease;cursor:zoom-in}.spv-main-box:hover .spv-main-img{transform:scale(1.02)}.spv-no-img{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--primary);opacity:.1}.spv-badge-sale{position:absolute;top:12px;left:12px;background:#e53e3e;color:#fff;font-size:.68rem;font-weight:800;padding:3px 10px;border-radius:100px;z-index:2}.spv-btn-zoom{position:absolute;top:10px;right:10px;width:36px;height:36px;background:rgba(255,255,255,.9);border:1px solid var(--border);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text);opacity:0;transition:opacity var(--transition)}.spv-main-box:hover .spv-btn-zoom{opacity:1}.spv-btn-zoom svg{width:16px;height:16px}.spv-thumbs-row{display:flex;gap:8px;flex-wrap:wrap}.spv-thumb{width:72px;height:72px;border-radius:8px;overflow:hidden;border:2px solid var(--border);background:none;padding:0;cursor:pointer;transition:border-color var(--transition);flex-shrink:0}.spv-thumb img{width:100%;height:100%;object-fit:cover;display:block}.spv-thumb:hover{border-color:var(--primary)}.spv-thumb.active{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-light)}.spv-gallery-share{display:flex;align-items:center;gap:8px;font-size:.75rem;color:var(--muted)}.spv-sh-fb,.spv-sh-zalo{width:30px;height:30px;border-radius:6px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;transition:all var(--transition);color:var(--muted)}.spv-sh-fb:hover{background:#1877f2;border-color:#1877f2;color:#fff}.spv-sh-zalo:hover{background:#0068ff;border-color:#0068ff;color:#fff}.spv-sh-fb svg,.spv-sh-zalo svg{width:15px;height:15px}.spv-info-col{display:flex;flex-direction:column;gap:14px;min-width:0}.spv-tags-row{display:flex;flex-wrap:wrap;gap:6px}.spv-cat-pill{display:inline-block;padding:3px 12px;border-radius:100px;background:var(--primary-light);color:var(--primary);font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;transition:all var(--transition)}.spv-cat-pill:hover{background:var(--primary);color:#fff}.spv-h1{font-size:clamp(1.3rem,3vw,1.9rem);font-weight:800;line-height:1.25;color:var(--text);margin:0;letter-spacing:-.02em}.spv-meta-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap;font-size:.8rem}.spv-stars{color:#f59e0b;letter-spacing:1px}.spv-meta-txt{color:var(--muted)}.spv-sku{color:var(--muted);font-size:.72rem;margin-left:auto}.spv-price-wrap{background:var(--bg-2);border-radius:10px;padding:14px 16px;border-left:4px solid var(--primary)}.spv-price-big{font-size:1.8rem;font-weight:900;color:#e53e3e;line-height:1}.spv-price-big del{font-size:1rem;color:var(--muted);font-weight:400;margin-left:8px}.spv-price-contact{font-size:1.2rem;font-weight:800;color:var(--primary)}.spv-price-sub{font-size:.72rem;color:var(--muted);margin-top:5px}.spv-short{font-size:.875rem;color:var(--text-2);line-height:1.7;padding:12px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.spv-short ul{padding-left:1.2rem;margin:0}.spv-short ul li{list-style:disc;margin-bottom:.3rem}.spv-quick-specs{border:1px solid var(--border);border-radius:8px;overflow:hidden}.spv-qs-row{display:flex;align-items:baseline;padding:8px 14px;border-bottom:1px solid var(--border);font-size:.83rem;gap:8px}.spv-qs-row:last-child{border-bottom:none}.spv-qs-row:nth-child(even){background:var(--bg-2)}.spv-qs-row>span{color:var(--muted);font-weight:600;min-width:100px;flex-shrink:0}.spv-qs-row>strong{color:var(--text);font-weight:500}.spv-wc-wrap form.cart{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.spv-wc-wrap .qty{height:46px;width:60px;text-align:center;border:1.5px solid var(--border);border-radius:8px;font-size:1rem;font-family:inherit;outline:none}.spv-wc-wrap .qty:focus{border-color:var(--primary)}.spv-wc-wrap .single_add_to_cart_button{background:var(--primary)!important;color:#fff!important;border:none!important;border-radius:8px!important;padding:12px 22px!important;font-size:.9rem!important;font-weight:700!important;min-height:46px!important;cursor:pointer!important;font-family:inherit!important}.spv-wc-wrap .single_add_to_cart_button:hover{background:#0d47a1!important}.spv-cta-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.spv-btn-call,.spv-btn-zalo{display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:10px;text-decoration:none;min-width:0;transition:all var(--transition)}.spv-btn-call{background:var(--primary);color:#fff!important}.spv-btn-call:hover{background:#0d47a1}.spv-btn-zalo{background:#0068ff;color:#fff!important}.spv-btn-zalo:hover{background:#0053cc}.spv-btn-call svg,.spv-btn-zalo svg{width:22px;height:22px;flex-shrink:0}.spv-btn-call span,.spv-btn-zalo span{display:flex;flex-direction:column;gap:1px;min-width:0;overflow:hidden}.spv-btn-call span small,.spv-btn-zalo span small{font-size:.65rem;opacity:.82}.spv-btn-call span strong,.spv-btn-zalo span strong{font-size:.86rem;font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.spv-btn-email{display:flex;align-items:center;gap:8px;padding:10px 14px;border:1.5px solid var(--border);border-radius:8px;font-size:.78rem;color:var(--text-2);transition:all var(--transition);text-decoration:none}.spv-btn-email:hover{border-color:var(--primary);color:var(--primary)}.spv-btn-email svg{width:15px;height:15px;flex-shrink:0;color:var(--primary)}.spv-commits-bar{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:12px 14px;background:var(--bg-2);border-radius:10px;border:1px solid var(--border)}@media(min-width:400px){.spv-commits-bar{grid-template-columns:repeat(5,1fr)}}.spv-commit{display:flex;flex-direction:column;align-items:center;gap:4px;text-align:center}.spv-commit svg{width:20px;height:20px;color:var(--primary)}.spv-commit span{font-size:.6rem;color:var(--text-2);line-height:1.3;font-weight:600}.spv-bottom-section{padding:36px 0 64px;background:var(--bg-2);border-top:1px solid var(--border)}.spv-bottom-grid{display:grid;grid-template-columns:1fr;gap:28px;align-items:start}@media(min-width:900px){.spv-bottom-grid{grid-template-columns:minmax(0,1fr) 300px;gap:40px}}.spv-content-col{min-width:0;background:var(--bg);border-radius:14px;padding:24px;border:1px solid var(--border)}@media(min-width:768px){.spv-content-col{padding:32px}}.spv-sidebar-col{min-width:0;display:flex;flex-direction:column;gap:18px}@media(min-width:900px){.spv-sidebar-col{position:sticky;top:86px}}.spv-tabs-nav{display:flex;gap:0;border-bottom:2px solid var(--border);margin-bottom:24px;overflow-x:auto;scrollbar-width:none}.spv-tabs-nav::-webkit-scrollbar{display:none}.spv-tab{padding:11px 20px;font-size:.875rem;font-weight:700;color:var(--muted);background:none;border:none;border-bottom:3px solid transparent;cursor:pointer;white-space:nowrap;transition:all var(--transition);margin-bottom:-2px;font-family:inherit}.spv-tab:hover{color:var(--text)}.spv-tab.active{color:var(--primary);border-bottom-color:var(--primary)}.spv-pane{display:none}.spv-pane.active{display:block}.spv-entry{font-size:.9375rem;line-height:1.85;color:var(--text-2);overflow:hidden;width:100%}.spv-entry>*{margin-bottom:1.1rem}.spv-entry>*:last-child{margin-bottom:0}.spv-entry h2{font-size:1.2rem;font-weight:800;color:var(--text);margin-top:2rem;margin-bottom:.7rem;padding-bottom:.4rem;border-bottom:2px solid var(--primary-light)}.spv-entry h2:first-child{margin-top:0}.spv-entry h3{font-size:1rem;font-weight:700;color:var(--text);margin-top:1.5rem;margin-bottom:.5rem;padding-left:10px;border-left:3px solid var(--primary)}.spv-entry p{color:var(--text-2);margin-bottom:1rem}.spv-entry a{color:var(--primary);text-decoration:underline}.spv-entry img{display:block;width:100%;max-width:700px;height:auto!important;margin:1.4rem auto;border-radius:10px;box-sizing:border-box}.spv-entry ul,.spv-entry ol{padding-left:1.3rem;margin-bottom:1rem}.spv-entry ul{list-style:disc}.spv-entry ol{list-style:decimal}.spv-entry li{color:var(--text-2);margin-bottom:.35rem}.spv-entry::after{content:'';display:table;clear:both}.spv-attr-table{width:100%;border-collapse:collapse;border-radius:8px;overflow:hidden;border:1px solid var(--border)}.spv-attr-table th{background:var(--bg-2);padding:10px 14px;font-size:.84rem;font-weight:700;color:var(--text);border-bottom:1px solid var(--border);text-align:left;width:160px}.spv-attr-table td{padding:10px 14px;font-size:.84rem;color:var(--text-2);border-bottom:1px solid var(--border)}.spv-attr-table tr:last-child th,.spv-attr-table tr:last-child td{border-bottom:none}.spv-attr-table tr:nth-child(even) td,.spv-attr-table tr:nth-child(even) th{background:var(--bg-2)}.spv-faq-item{border:1.5px solid var(--border);border-radius:10px;overflow:hidden;margin-bottom:8px;transition:border-color var(--transition)}.spv-faq-item:last-child{margin-bottom:0}.spv-faq-btn{width:100%;display:flex;justify-content:space-between;align-items:center;gap:12px;padding:14px 18px;background:var(--bg);border:none;cursor:pointer;text-align:left;font-family:inherit;font-size:.88rem;font-weight:700;color:var(--text);transition:background var(--transition)}.spv-faq-btn:hover{background:var(--bg-2)}.spv-faq-btn[aria-expanded=true]{background:var(--primary-light);color:var(--primary)}.spv-faq-ico{width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--bg-2);color:var(--primary);font-size:1.1rem;flex-shrink:0;transition:all var(--transition)}.spv-faq-btn[aria-expanded=true] .spv-faq-ico{background:var(--primary);color:#fff}.spv-faq-body{padding:14px 18px;background:var(--bg-2);border-top:1px solid var(--border)}.spv-faq-body p{font-size:.86rem;color:var(--text-2);line-height:1.7;margin:0}.spv-sidebar-cta{background:linear-gradient(145deg,#0a2463,#1565c0);border-radius:12px;padding:20px;text-align:center}.spv-sc-icon{margin:0 auto 10px}.spv-sc-icon svg{width:36px;height:36px;color:rgba(255,255,255,.2);margin:0 auto}.spv-sidebar-cta h3{color:#fff;font-size:1rem;margin-bottom:6px}.spv-sidebar-cta>p{color:rgba(255,255,255,.72);font-size:.82rem;margin-bottom:16px;line-height:1.6}.spv-sc-hours{font-size:.7rem;color:rgba(255,255,255,.5);margin-top:10px;padding-top:10px;border-top:1px solid rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;gap:5px}.spv-sc-hours svg{width:13px;height:13px}.spv-sb-prod{display:flex;align-items:center;gap:10px;text-decoration:none;color:inherit;padding:6px 0;border-bottom:1px solid var(--border);transition:color var(--transition)}.spv-sb-prod:last-child{border-bottom:none}.spv-sb-prod:hover .spv-sb-info>span{color:var(--primary)}.spv-sb-thumb{width:52px;height:52px;border-radius:6px;overflow:hidden;flex-shrink:0;background:var(--bg-2)}.spv-sb-thumb img{width:100%;height:100%;object-fit:cover;display:block}.spv-sb-noimg{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--primary);opacity:.2}.spv-sb-info{display:flex;flex-direction:column;gap:3px;min-width:0}.spv-sb-info>span{font-size:.8rem;font-weight:600;color:var(--text);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;transition:color var(--transition)}.spv-sb-info>strong{font-size:.78rem;color:#e53e3e;font-weight:700}.spv-related-full{padding:44px 0 64px;border-top:1px solid var(--border)}.spv-rel-head{display:flex;justify-content:space-between;align-items:center;gap:14px;margin-bottom:22px}.spv-rel-head h2{font-size:1.25rem;font-weight:800;margin:0}.spv-rel-more{display:inline-flex;align-items:center;gap:5px;font-size:.82rem;font-weight:700;color:var(--primary);transition:gap var(--transition)}.spv-rel-more:hover{gap:9px}.spv-rel-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}@media(min-width:540px){.spv-rel-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(min-width:900px){.spv-rel-grid{grid-template-columns:repeat(5,minmax(0,1fr))}}.spv-rel-card{display:flex;flex-direction:column;background:var(--bg);border:1.5px solid var(--border);border-radius:12px;overflow:hidden;text-decoration:none;color:inherit;transition:all var(--transition)}.spv-rel-card:hover{border-color:var(--primary);box-shadow:0 6px 24px rgba(21,101,192,.12);transform:translateY(-4px)}.spv-rel-img{position:relative;aspect-ratio:1;overflow:hidden;background:var(--bg-2)}.spv-rel-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s ease}.spv-rel-card:hover .spv-rel-img img{transform:scale(1.07)}.spv-rel-noimg{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--primary);opacity:.12}.spv-rel-badge{position:absolute;top:8px;left:8px;background:#e53e3e;color:#fff;font-size:.62rem;font-weight:800;padding:2px 8px;border-radius:100px;z-index:1}.spv-rel-hover{position:absolute;inset:0;background:rgba(21,101,192,.65);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--transition);color:#fff}.spv-rel-hover svg{width:24px;height:24px}.spv-rel-card:hover .spv-rel-hover{opacity:1}.spv-rel-body{padding:12px 13px;flex:1;display:flex;flex-direction:column;gap:3px}.spv-rel-cat{font-size:.62rem;font-weight:700;color:var(--primary);text-transform:uppercase;letter-spacing:.05em}.spv-rel-body h3{font-size:.82rem;font-weight:700;color:var(--text);line-height:1.35;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.spv-rel-card:hover .spv-rel-body h3{color:var(--primary)}.spv-rel-price{font-size:.84rem;font-weight:800;color:#e53e3e;margin-top:auto;padding-top:4px}@media(max-width:480px){.spv-cta-row{grid-template-columns:1fr}.spv-commits-bar{grid-template-columns:repeat(3,1fr)}.spv-rel-grid{grid-template-columns:repeat(2,1fr)}.spv-h1{font-size:1.3rem}}@media(hover:none){.spv-rel-card:hover{transform:none;box-shadow:none;border-color:var(--border)}.spv-rel-hover{display:none}.spv-btn-zoom{opacity:1}}