/**
 * pages.css – FTN Land Theme
 * @package FTNLand
 */

/* PAGE HERO */
.page-hero{position:relative;background:var(--color-dark);color:#fff;padding:72px 0 80px;overflow:hidden}
.page-hero__bg{position:absolute;inset:0;background:linear-gradient(135deg,var(--color-dark) 0%,var(--color-dark2) 50%,#0d2a1a 100%);z-index:0}
.page-hero__stripe,.page-hero__stripe2{position:absolute;border-radius:50%;z-index:0;pointer-events:none}
.page-hero__stripe{width:600px;height:600px;background:radial-gradient(circle,rgba(106,191,69,.12) 0%,transparent 70%);top:-200px;right:-100px}
.page-hero__stripe2{width:400px;height:400px;background:radial-gradient(circle,rgba(196,18,48,.10) 0%,transparent 70%);bottom:-150px;left:-80px}
.page-hero .container{position:relative;z-index:1}
.page-hero__inner{display:flex;align-items:center;justify-content:space-between;gap:48px}
.page-hero__inner--center{flex-direction:column;align-items:center;text-align:center}
.page-hero__eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:var(--color-secondary-light);margin-bottom:12px}
.page-hero__eyebrow::before{content:'';width:20px;height:2px;background:var(--color-secondary-light);border-radius:2px}
.page-hero__title{font-size:clamp(28px,4vw,52px);font-weight:900;line-height:1.15;letter-spacing:-.5px;margin-bottom:20px}
.page-hero__title em{font-style:normal;color:var(--color-secondary-light)}
.page-hero__desc{font-size:16px;line-height:1.72;color:rgba(255,255,255,.75);max-width:560px;margin-bottom:28px}
.page-hero__inner--center .page-hero__desc{margin-inline:auto}
.page-hero__buttons{display:flex;gap:12px;flex-wrap:wrap}
.page-hero .breadcrumb{display:flex;align-items:center;gap:8px;font-size:13px;color:rgba(255,255,255,.55);margin-bottom:16px;flex-wrap:wrap}
.page-hero .breadcrumb a{color:rgba(255,255,255,.7);transition:color .2s}
.page-hero .breadcrumb a:hover{color:#fff}
.page-hero .breadcrumb__sep{font-size:10px;color:rgba(255,255,255,.3)}
.page-hero .breadcrumb__current{color:rgba(255,255,255,.9)}
.page-hero .breadcrumb__list{display:flex;align-items:center;gap:8px;list-style:none;flex-wrap:wrap}
.page-hero .breadcrumb__item{display:flex;align-items:center;gap:8px}
.page-hero .breadcrumb__item:not(:last-child)::after{content:'/';color:rgba(255,255,255,.3);font-size:11px}

/* HERO STATS */
.hero-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;min-width:280px}
.hero-stat-box{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-md);padding:20px 16px;text-align:center;backdrop-filter:blur(8px);transition:var(--transition)}
.hero-stat-box:hover{background:rgba(255,255,255,.12)}
.hero-stat-box__num{font-size:28px;font-weight:900;color:#fff;line-height:1;margin-bottom:6px}
.hero-stat-box__num span{color:var(--color-secondary-light);font-size:18px}
.hero-stat-box__label{font-size:12px;color:rgba(255,255,255,.65);font-weight:500}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:8px;border:none;padding:13px 28px;font-size:14px;font-weight:700;border-radius:var(--radius-sm);cursor:pointer;transition:transform .2s,box-shadow .2s,background .2s;font-family:var(--font-body);text-decoration:none}
.btn--primary{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));color:#fff;box-shadow:0 6px 20px rgba(196,18,48,.3)}
.btn--primary:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(196,18,48,.42);color:#fff}
.btn--secondary{background:linear-gradient(135deg,var(--color-secondary),var(--color-secondary-mid));color:#fff;box-shadow:0 6px 20px rgba(30,125,58,.3)}
.btn--secondary:hover{transform:translateY(-2px);color:#fff}
.btn--ghost{background:rgba(255,255,255,.08);color:#fff;border:1.5px solid rgba(255,255,255,.3)}
.btn--ghost:hover{background:rgba(255,255,255,.15);color:#fff}
.btn--outline{background:transparent;color:var(--color-primary);border:2px solid var(--color-primary)}
.btn--outline:hover{background:var(--color-primary);color:#fff}

/* SECTION HEADING */
.section-head{margin-bottom:48px}
.section-head--center{text-align:center}
.section__label{display:inline-flex;align-items:center;gap:8px;font-size:10.5px;font-weight:800;text-transform:uppercase;letter-spacing:2.5px;color:var(--color-secondary);margin-bottom:10px}
.section__label::before{content:'';width:18px;height:2.5px;background:currentColor;border-radius:2px}
.section__label--red{color:var(--color-primary)}
.section__title{font-size:clamp(24px,3vw,40px);font-weight:900;color:var(--color-dark);line-height:1.2;letter-spacing:-.3px}
.section__title .accent-red{color:var(--color-primary)}
.section__title .accent-green{color:var(--color-secondary)}
.section__desc{margin-top:14px;font-size:15px;color:var(--color-gray);line-height:1.72}

/* PAGE.PHP LAYOUT */
.page-content-layout{display:grid;grid-template-columns:1fr 300px;gap:48px;align-items:start}
.page-article{min-width:0}
.page-featured-img{margin-bottom:32px}
.page-featured-img__img{width:100%;height:380px;object-fit:cover;border-radius:var(--radius-lg)}

/* STORY (ve-chung-toi) */
.story-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.story-image{position:relative}
.story-image__main img{width:100%;height:460px;object-fit:cover;border-radius:var(--radius-xl)}
.story-float{position:absolute;background:#fff;border-radius:var(--radius-md);box-shadow:var(--shadow-md);padding:14px 18px;display:flex;align-items:center;gap:12px;border:1px solid var(--color-border)}
.story-float--tl{top:24px;left:-20px}
.story-float--br{bottom:24px;right:-20px}
.story-float__icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.story-float__icon--red{background:var(--color-primary-light);color:var(--color-primary)}
.story-float__icon--green{background:var(--color-secondary-pale);color:var(--color-secondary)}
.story-float__text strong{display:block;font-size:15px;font-weight:800;color:var(--color-dark);line-height:1}
.story-float__text span{font-size:11px;color:var(--color-gray)}
.story-text .section__title{margin-top:8px}
.story-text__lead{font-size:15.5px;font-weight:600;color:var(--color-dark);line-height:1.65;margin:16px 0 12px}
.story-checkpoints{margin-top:20px;display:flex;flex-direction:column;gap:10px}
.checkpoint{display:flex;align-items:center;gap:10px;font-size:14px;font-weight:500;color:var(--color-text)}
.checkpoint i{color:var(--color-secondary);font-size:15px;flex-shrink:0}

/* STATS BAND */
.stats-band{background:linear-gradient(135deg,var(--color-dark) 0%,var(--color-dark2) 100%);color:#fff;padding:48px 0}
.stats-band__grid{display:grid;grid-template-columns:repeat(5,1fr);gap:0}
.stat-cell{text-align:center;padding:24px 20px;border-right:1px solid rgba(255,255,255,.1)}
.stat-cell:last-child{border-right:none}
.stat-cell__num{font-size:36px;font-weight:900;color:#fff;line-height:1;margin-bottom:8px}
.stat-cell__num sup{font-size:18px;color:var(--color-secondary-light)}
.stat-cell__label{font-size:13px;color:rgba(255,255,255,.65);font-weight:500}

/* VALUES */
.values-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.value-card{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:32px 24px;transition:var(--transition);text-align:center}
.value-card:hover{box-shadow:var(--shadow-md);transform:translateY(-4px);border-color:transparent}
.value-card__icon{width:60px;height:60px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:22px;margin:0 auto 16px}
.value-card__icon--red{background:var(--color-primary-light);color:var(--color-primary)}
.value-card__icon--green{background:var(--color-secondary-pale);color:var(--color-secondary)}
.value-card__icon--gold{background:#fef9ec;color:var(--color-gold)}
.value-card__icon--blue{background:#eff6ff;color:#3b82f6}
.value-card__title{font-size:15px;font-weight:800;color:var(--color-dark);margin-bottom:8px}
.value-card__desc{font-size:13.5px;color:var(--color-gray);line-height:1.65}

/* TEAM */
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.team-card{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;transition:var(--transition);text-align:center}
.team-card:hover{box-shadow:var(--shadow-md);transform:translateY(-4px)}
.team-card__img-wrap{aspect-ratio:1;overflow:hidden}
.team-card__img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.team-card:hover .team-card__img-wrap img{transform:scale(1.06)}
.team-card__info{padding:16px}
.team-card__name{font-size:15px;font-weight:800;color:var(--color-dark);margin-bottom:4px}
.team-card__role{font-size:12.5px;color:var(--color-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.06em}

/* CTA BAND */
.cta-band{background:linear-gradient(135deg,var(--color-dark) 0%,#0a2d18 100%);color:#fff;padding:72px var(--container-pad)}
.cta-band .container{max-width:var(--container-width);margin-inline:auto}
.cta-band__inner{display:flex;align-items:center;justify-content:space-between;gap:40px}
.cta-band h2{font-size:clamp(24px,3vw,36px);font-weight:900;line-height:1.2;margin-bottom:12px}
.cta-band p{font-size:15px;color:rgba(255,255,255,.75);max-width:480px}
.cta-band__actions{display:flex;gap:14px;flex-shrink:0;flex-wrap:wrap}

/* CONTACT PAGE */
.contact-quick{background:#fff;border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-sm)}
.contact-quick__grid{display:grid;grid-template-columns:repeat(4,1fr)}
.contact-quick__item{display:flex;align-items:center;gap:16px;padding:24px 28px;border-right:1px solid var(--color-border);text-decoration:none;color:var(--color-text);transition:var(--transition)}
.contact-quick__item:last-child{border-right:none}
.contact-quick__item:hover{background:var(--color-bg)}
.contact-quick__icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.contact-quick__icon--red{background:var(--color-primary-light);color:var(--color-primary)}
.contact-quick__icon--green{background:var(--color-secondary-pale);color:var(--color-secondary)}
.contact-quick__icon--blue{background:#eff6ff;color:#3b82f6}
.contact-quick__icon--gold{background:#fef9ec;color:var(--color-gold)}
.contact-quick__label{font-size:11.5px;font-weight:600;color:var(--color-gray);text-transform:uppercase;letter-spacing:.06em;margin-bottom:2px}
.contact-quick__value{font-size:16px;font-weight:800;color:var(--color-dark);line-height:1.2}
.contact-quick__note{font-size:12px;color:var(--color-gray);margin-top:2px}
.contact-layout{display:grid;grid-template-columns:1fr 380px;gap:48px;align-items:start}
.form-card{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:40px;box-shadow:var(--shadow-sm)}
.form-card__head{margin-bottom:28px}
.form-card__head h2{font-size:24px;font-weight:900;color:var(--color-dark);margin:10px 0 8px}
.form-card__head p{font-size:14px;color:var(--color-gray)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.form-group{margin-bottom:16px}
.form-group label{display:block;font-size:13px;font-weight:700;color:var(--color-dark);margin-bottom:6px}
.form-group label span{color:var(--color-primary)}
.form-control{width:100%;padding:11px 14px;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);font-size:14px;font-family:var(--font-body);background:#fff;color:var(--color-text);transition:border-color .2s,box-shadow .2s}
.form-control:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(196,18,48,.1)}
textarea.form-control{min-height:120px;resize:vertical}
.form-submit{width:100%;justify-content:center;padding:14px;font-size:15px;border-radius:var(--radius-md)}
.form-privacy{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--color-gray);margin-top:12px}
.form-privacy i{color:var(--color-secondary)}
.contact-info{display:flex;flex-direction:column;gap:20px}
.info-card{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-sm)}
.info-card__head{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.info-card__icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.info-card__icon--red{background:var(--color-primary-light);color:var(--color-primary)}
.info-card__icon--green{background:var(--color-secondary-pale);color:var(--color-secondary)}
.info-card__title{font-size:15px;font-weight:800;color:var(--color-dark)}
.offices-grid{display:flex;flex-direction:column;gap:14px}
.office-item__city{font-size:13px;font-weight:700;color:var(--color-dark);display:flex;align-items:center;gap:6px;margin-bottom:2px}
.office-item__city i{color:var(--color-primary);font-size:12px}
.office-item__addr{font-size:13px;color:var(--color-gray);padding-left:18px}
.social-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.social-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--color-border);border-radius:var(--radius-sm);text-decoration:none;color:var(--color-text);font-size:18px;transition:var(--transition)}
.social-item:hover{border-color:currentColor}
.social-item--fb{color:#1877f2}
.social-item--yt{color:#ff0000}
.social-item--zl{color:#0068ff}
.social-item--li{color:#0a66c2}
.social-item__name{font-size:12px;font-weight:700;color:var(--color-dark);line-height:1}
.social-item__handle{font-size:11px;color:var(--color-gray)}
.info-card--map{padding:0;overflow:hidden}
.map-embed{width:100%}

/* SERVICES PAGE */
.services-full-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:48px}
.service-card-full{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:32px;transition:var(--transition);display:flex;flex-direction:column}
.service-card-full:hover{box-shadow:var(--shadow-md);transform:translateY(-4px);border-color:transparent}
.service-card-full__icon{width:64px;height:64px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:24px;margin-bottom:20px;flex-shrink:0}
.service-card-full__icon--red{background:var(--color-primary-light);color:var(--color-primary)}
.service-card-full__icon--green{background:var(--color-secondary-pale);color:var(--color-secondary)}
.service-card-full__icon--gold{background:#fef9ec;color:var(--color-gold)}
.service-card-full__icon--blue{background:#eff6ff;color:#3b82f6}
.service-card-full__icon--purple{background:#f5f3ff;color:#7c3aed}
.service-card-full__icon--teal{background:#f0fdfa;color:#0d9488}
.service-card-full__sub{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--color-gray);margin-bottom:6px}
.service-card-full__title{font-size:18px;font-weight:800;color:var(--color-dark);margin-bottom:12px}
.service-card-full__desc{font-size:13.5px;color:var(--color-gray);line-height:1.65;margin-bottom:16px}
.service-card-full__features{list-style:none;margin-bottom:20px;flex:1}
.service-card-full__features li{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--color-text);margin-bottom:7px}
.service-card-full__features i{color:var(--color-secondary);font-size:12px;flex-shrink:0}
.service-card-full__link{display:inline-flex;align-items:center;gap:6px;font-size:13.5px;font-weight:700;color:var(--color-primary);text-decoration:none;transition:gap .2s;margin-top:auto}
.service-card-full__link:hover{gap:10px}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:48px}
.why-item{text-align:center;padding:32px 20px;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:var(--transition)}
.why-item:hover{box-shadow:var(--shadow-md);transform:translateY(-4px)}
.why-item__icon{width:56px;height:56px;background:var(--color-primary-light);color:var(--color-primary);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;margin:0 auto 14px}
.why-item__num{font-size:28px;font-weight:900;color:var(--color-dark);margin-bottom:6px}
.why-item__label{font-size:13px;color:var(--color-gray)}

/* section--bg */
.section--bg { background: var(--color-bg); }

/* RESPONSIVE */
@media(max-width:1024px){
    .page-hero__inner{flex-direction:column;text-align:center}
    .page-hero__buttons{justify-content:center}
    .hero-stats{width:100%;max-width:400px;margin-inline:auto}
    .values-grid{grid-template-columns:repeat(2,1fr)}
    .team-grid{grid-template-columns:repeat(2,1fr)}
    .services-full-grid{grid-template-columns:repeat(2,1fr)}
    .why-grid{grid-template-columns:repeat(2,1fr)}
    .stats-band__grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:768px){
    .story-grid{grid-template-columns:1fr;gap:40px}
    .story-float{display:none}
    .contact-layout{grid-template-columns:1fr}
    .contact-quick__grid{grid-template-columns:repeat(2,1fr)}
    .contact-quick__item:nth-child(2){border-right:none}
    .contact-quick__item:nth-child(3){border-right:none;border-top:1px solid var(--color-border)}
    .contact-quick__item:nth-child(4){border-top:1px solid var(--color-border)}
    .form-row{grid-template-columns:1fr}
    .cta-band__inner{flex-direction:column;text-align:center}
    .cta-band__actions{justify-content:center}
    .page-content-layout{grid-template-columns:1fr}
    .stats-band__grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:580px){
    .contact-quick__grid{grid-template-columns:1fr}
    .contact-quick__item{border-right:none!important;border-bottom:1px solid var(--color-border)}
    .values-grid{grid-template-columns:1fr}
    .services-full-grid{grid-template-columns:1fr}
    .why-grid{grid-template-columns:1fr}
    .stats-band__grid{grid-template-columns:1fr}
    .form-card{padding:24px 20px}
    .social-grid{grid-template-columns:1fr}
}

/* ============================================================
   PAGE HERO SIMPLE (dùng cho tin tức, archive, v.v.)
   Thiết kế theo ảnh: breadcrumb + H1 (accent xanh) + meta row
   ============================================================ */
.page-hero-simple {
    background: linear-gradient(135deg, var(--color-dark) 0%, var(--color-dark2) 55%, #0d2a1a 100%);
    padding: 44px 0 48px;
    position: relative;
    overflow: hidden;
}
.page-hero-simple::after {
    content: '';
    position: absolute;
    width: 500px; height: 500px;
    background: radial-gradient(circle, rgba(106,191,69,.10) 0%, transparent 70%);
    top: -180px; right: -80px;
    pointer-events: none;
}
.page-hero-simple .container { position: relative; z-index: 1; }

/* Breadcrumb trong simple hero */
.page-hero-simple .breadcrumb {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    color: rgba(255,255,255,.5);
    margin-bottom: 18px;
    flex-wrap: wrap;
    list-style: none;
}
.page-hero-simple .breadcrumb a { color: rgba(255,255,255,.65); transition: color .2s; }
.page-hero-simple .breadcrumb a:hover { color: #fff; }
.page-hero-simple .breadcrumb__sep { font-size: 11px; color: rgba(255,255,255,.3); }
.page-hero-simple .breadcrumb__current { color: rgba(255,255,255,.85); }
.page-hero-simple .breadcrumb__list { display: flex; align-items: center; gap: 8px; list-style: none; flex-wrap: wrap; }
.page-hero-simple .breadcrumb__item { display: flex; align-items: center; gap: 8px; }
.page-hero-simple .breadcrumb__item:not(:last-child)::after {
    content: '›';
    color: rgba(255,255,255,.3);
    font-size: 14px;
}

.page-hero-simple__eyebrow {
    font-size: 11.5px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: var(--color-secondary-light);
    margin-bottom: 10px;
}
.page-hero-simple__title {
    font-size: clamp(26px, 3.5vw, 44px);
    font-weight: 900;
    color: #fff;
    line-height: 1.15;
    letter-spacing: -.4px;
    margin-bottom: 16px;
}
.page-hero-simple__title em,
.page-hero-simple__title .accent-green {
    font-style: normal;
    color: var(--color-secondary-light);
}
.page-hero-simple__title .accent-red { color: var(--color-primary); }

/* Meta row: icon + text nhỏ */
.page-hero-simple__meta {
    display: flex;
    align-items: center;
    gap: 20px;
    flex-wrap: wrap;
}
.page-hero-simple__meta-item {
    display: flex;
    align-items: center;
    gap: 7px;
    font-size: 13px;
    color: rgba(255,255,255,.65);
    font-weight: 500;
}
.page-hero-simple__meta-item i {
    color: var(--color-secondary-light);
    font-size: 13px;
}

/* Override: các trang dùng page-hero cũ → chuyển sang simple */
/* Xoá kiểu hero cũ có stats box, buttons lớn cho page.php/ve-chung-toi.php */
/* (Các trang đó giữ nguyên page-hero riêng) */

/* ============================================================
   HOMEPAGE – front-page.php
   ============================================================ */

/* Hero */
/* ── HOME HERO v2.4 – compact, 2-col, left-align ── */
.home-hero {
  position: relative;
  min-height: 72vh;
  display: flex;
  align-items: center;
  overflow: hidden;
}
.home-hero__bg {
  position: absolute; inset: 0;
  background: url('https://images.unsplash.com/photo-1486325212027-8081e485255e?w=1600&q=85') center/cover no-repeat;
  z-index: 0;
}
.home-hero__overlay {
  position: absolute; inset: 0;
  background: linear-gradient(110deg, rgba(10,18,28,.92) 0%, rgba(10,18,28,.80) 45%, rgba(8,22,16,.60) 100%);
  z-index: 1;
}
.home-hero__accent {
  position: absolute; bottom: 0; left: 0; right: 0;
  height: 4px; z-index: 2;
  background: linear-gradient(90deg, var(--color-primary) 0%, var(--color-secondary) 100%);
}

/* Inner: 2-col grid */
.home-hero__inner {
  position: relative; z-index: 3;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
  align-items: center;
  padding-top: 60px;
  padding-bottom: 60px;
}

/* Left column */
.home-hero__left { color: #fff; }
.home-hero__eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 11px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 2.5px;
  color: var(--color-secondary-light); margin-bottom: 18px;
}
.home-hero__eyebrow::before {
  content: ''; width: 20px; height: 2px;
  background: var(--color-secondary-light); border-radius: 2px;
}
.home-hero__title {
  font-size: clamp(30px, 4.5vw, 55px);
  font-weight: 900; line-height: 1.3;
  letter-spacing: -.5px; margin-bottom: 18px;
}
.home-hero__title em { font-style: normal; color: var(--color-secondary-light); }
.home-hero__desc {
  font-size: 15.5px; line-height: 1.72;
  color: rgba(255,255,255,.76); max-width: 480px; margin-bottom: 28px;
}
.home-hero__buttons {
  display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 36px;
}

/* Inline stats row */
.home-hero__stats {
  display: flex; align-items: center; gap: 0;
}
.home-hero__stat {
  display: flex; flex-direction: column; gap: 2px; padding: 0 22px 0 0;
}
.home-hero__stat:first-child { padding-left: 0; }
.home-hero__stat strong {
  font-size: 22px; font-weight: 900; color: #fff; line-height: 1;
}
.home-hero__stat span {
  font-size: 11.5px; color: rgba(255,255,255,.58); font-weight: 500;
}
.home-hero__stat-divider {
  width: 1px; height: 32px;
  background: rgba(255,255,255,.2);
  margin-right: 22px; flex-shrink: 0;
}

/* Right column – video button */
.home-hero__right {
  display: flex;
  align-items: center;
  justify-content: center;
}
.hero-video-btn {
  position: relative;
  width: 100%; max-width: 460px;
  border: none; background: none; cursor: pointer; padding: 0;
  border-radius: 16px; overflow: hidden;
  box-shadow: 0 24px 60px rgba(0,0,0,.45);
  transition: transform .3s cubic-bezier(.22,1,.36,1), box-shadow .3s;
}
.hero-video-btn:hover { transform: scale(1.025); box-shadow: 0 32px 72px rgba(0,0,0,.55); }
.hero-video-btn__thumb {
  position: relative; aspect-ratio: 16/9; overflow: hidden;
}
.hero-video-btn__thumb img {
  width: 100%; height: 100%; object-fit: cover; display: block;
  transition: transform .5s cubic-bezier(.22,1,.36,1);
}
.hero-video-btn:hover .hero-video-btn__thumb img { transform: scale(1.06); }
.hero-video-btn__overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(10,18,28,.55) 0%, rgba(10,18,28,.15) 60%, transparent 100%);
}

/* Play button circle */
.hero-video-btn__play {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -60%);
  width: 68px; height: 68px; border-radius: 50%;
  background: rgba(255,255,255,.95);
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 8px 32px rgba(0,0,0,.35);
  transition: transform .3s cubic-bezier(.34,1.56,.64,1), background .2s;
  z-index: 2;
}
.hero-video-btn__play i {
  color: var(--color-primary); font-size: 22px;
  margin-left: 4px; /* optically center play icon */
}
.hero-video-btn:hover .hero-video-btn__play {
  transform: translate(-50%, -60%) scale(1.12);
  background: #fff;
}

/* Label below thumb inside button */
.hero-video-btn__label {
  position: absolute; bottom: 0; left: 0; right: 0;
  padding: 14px 18px;
  text-align: left; z-index: 2;
}
.hero-video-btn__label span {
  display: block; font-size: 13.5px; font-weight: 700; color: #fff;
  line-height: 1.3; margin-bottom: 2px;
}
.hero-video-btn__label small {
  font-size: 11.5px; color: rgba(255,255,255,.65);
}

/* Pulse ring animation on play button */
.hero-video-btn__play::before {
  content: '';
  position: absolute; inset: -8px;
  border-radius: 50%;
  border: 2px solid rgba(255,255,255,.5);
  animation: pulse-ring 2.2s ease-out infinite;
}
@keyframes pulse-ring {
  0%   { transform: scale(1);   opacity: .7; }
  70%  { transform: scale(1.3); opacity: 0; }
  100% { transform: scale(1.3); opacity: 0; }
}

/* ── VIDEO MODAL ── */
.video-modal {
  position: fixed; inset: 0; z-index: 9999;
  display: flex; align-items: center; justify-content: center;
}
.video-modal[hidden] { display: none; }
.video-modal__backdrop {
  position: absolute; inset: 0;
  background: rgba(5,10,18,.88);
  backdrop-filter: blur(6px);
  cursor: pointer;
}
.video-modal__box {
  position: relative; z-index: 1;
  width: min(880px, 94vw);
  animation: modal-pop .32s cubic-bezier(.34,1.56,.64,1);
}
@keyframes modal-pop {
  from { transform: scale(.88); opacity: 0; }
  to   { transform: scale(1);   opacity: 1; }
}
.video-modal__close {
  position: absolute; top: -44px; right: 0;
  width: 36px; height: 36px; border-radius: 50%;
  border: 1.5px solid rgba(255,255,255,.3);
  background: rgba(255,255,255,.1); color: #fff;
  font-size: 15px; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background .2s, transform .2s;
}
.video-modal__close:hover { background: rgba(255,255,255,.22); transform: rotate(90deg); }
.video-modal__frame {
  position: relative; aspect-ratio: 16/9;
  border-radius: 12px; overflow: hidden;
  box-shadow: 0 32px 80px rgba(0,0,0,.6);
}
.video-modal__frame iframe {
  position: absolute; inset: 0;
  width: 100%; height: 100%; border: none;
}

/* Search widget */
#search-widget { position:relative; z-index:10; margin-top:-40px; margin-bottom:0; padding: 0 var(--container-pad); }
.search-widget__card { background:#fff; border-radius:var(--radius-xl); box-shadow:var(--shadow-lg); padding:24px 28px; border:1px solid var(--color-border); }
.search-tabs { display:flex; gap:4px; margin-bottom:20px; border-bottom:1px solid var(--color-border); padding-bottom:0; }
.search-tab { padding:10px 18px; border:none; background:transparent; font-size:13.5px; font-weight:700; color:var(--color-gray); cursor:pointer; border-bottom:2.5px solid transparent; transition:all .2s; display:flex; align-items:center; gap:6px; font-family:var(--font-body); margin-bottom:-1px; }
.search-tab:hover { color:var(--color-primary); }
.search-tab.is-active { color:var(--color-primary); border-bottom-color:var(--color-primary); }
.search-tab i { font-size:12px; }
.search-form { display:grid; grid-template-columns:1fr 1fr 1fr auto; gap:14px; align-items:end; }
.search-field label { display:block; font-size:12px; font-weight:700; color:var(--color-dark); margin-bottom:6px; text-transform:uppercase; letter-spacing:.04em; }
.search-field select { width:100%; padding:10px 12px; border:1.5px solid var(--color-border); border-radius:var(--radius-sm); font-size:13.5px; font-family:var(--font-body); color:var(--color-text); background:#fff; outline:none; transition:border-color .2s; }
.search-field select:focus { border-color:var(--color-primary); }
.btn--search { background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark)); color:#fff; padding:12px 28px; border:none; border-radius:var(--radius-sm); font-size:14px; font-weight:700; cursor:pointer; display:flex; align-items:center; gap:8px; transition:transform .2s,box-shadow .2s; font-family:var(--font-body); white-space:nowrap; align-self:end; }
.btn--search:hover { transform:translateY(-2px); box-shadow:0 8px 24px rgba(196,18,48,.35); color:#fff; }

/* Intro */
.intro-grid { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; }
.intro-text__desc { font-size:15px; color:var(--color-gray); line-height:1.72; margin:14px 0 20px; }
.features-list { display:grid; grid-template-columns:1fr 1fr; gap:8px 16px; margin-bottom:24px; }
.features-list__item { display:flex; align-items:center; gap:8px; font-size:13.5px; font-weight:600; color:var(--color-text); }
.features-list__item i { color:var(--color-secondary); font-size:14px; flex-shrink:0; }
.intro-image { position:relative; }
.intro-image__main img { width:100%; height:420px; object-fit:cover; border-radius:var(--radius-xl); }
.float-card { position:absolute; top:30px; left:-20px; background:#fff; border-radius:var(--radius-md); box-shadow:var(--shadow-md); padding:12px 16px; display:flex; align-items:center; gap:10px; border:1px solid var(--color-border); }
.float-card__icon { width:36px; height:36px; background:var(--color-primary-light); color:var(--color-primary); border-radius:8px; display:flex; align-items:center; justify-content:center; font-size:15px; }
.float-card__text strong { display:block; font-size:14px; font-weight:900; color:var(--color-dark); line-height:1; }
.float-card__text span { font-size:11px; color:var(--color-gray); }
.float-card--green { position:absolute; bottom:30px; right:-20px; background:linear-gradient(135deg,var(--color-secondary),var(--color-secondary-mid)); border-radius:var(--radius-md); padding:14px 18px; color:#fff; box-shadow:var(--shadow-md); text-align:center; }
.float-card__number { font-size:22px; font-weight:900; line-height:1; }
.float-card__label { font-size:11px; opacity:.85; margin-top:3px; }

/* Stats bar */
#stats-bar { background:linear-gradient(135deg,var(--color-dark) 0%,var(--color-dark2) 100%); padding:40px 0; }
.stats-bar__grid { display:grid; grid-template-columns:repeat(4,1fr); max-width:var(--container-width); margin-inline:auto; padding-inline:var(--container-pad); }
.stat-cell { text-align:center; padding:20px; border-right:1px solid rgba(255,255,255,.1); color:#fff; }
.stat-cell:last-child { border-right:none; }
.stat-cell__num { font-size:36px; font-weight:900; line-height:1; margin-bottom:6px; }
.stat-cell__num sup { font-size:18px; color:var(--color-secondary-light); }
.stat-cell__label { font-size:12.5px; color:rgba(255,255,255,.65); }

/* section header */
.section__header { display:flex; align-items:flex-end; justify-content:space-between; margin-bottom:36px; gap:16px; }
.link-all { display:inline-flex; align-items:center; gap:6px; font-size:13px; font-weight:700; color:var(--color-primary); white-space:nowrap; transition:gap .2s; }
.link-all:hover { gap:10px; }

/* Services grid */
.services-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.service-card { background:#fff; border:1px solid var(--color-border); border-radius:var(--radius-lg); padding:28px 22px; transition:var(--transition); }
.service-card:hover { box-shadow:var(--shadow-md); transform:translateY(-4px); border-color:transparent; }
.service-card__icon { width:52px; height:52px; border-radius:14px; display:flex; align-items:center; justify-content:center; font-size:20px; margin-bottom:14px; }
.service-card__icon--red   { background:var(--color-primary-light);  color:var(--color-primary); }
.service-card__icon--green { background:var(--color-secondary-pale); color:var(--color-secondary); }
.service-card__title { font-size:15px; font-weight:800; color:var(--color-dark); margin-bottom:8px; }
.service-card__desc { font-size:13px; color:var(--color-gray); line-height:1.65; }

/* Projects grid */
.projects-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.project-card { background:#fff; border:1px solid var(--color-border); border-radius:var(--radius-lg); overflow:hidden; transition:var(--transition); }
.project-card:hover { box-shadow:var(--shadow-md); transform:translateY(-4px); border-color:transparent; }
.project-card__image { position:relative; aspect-ratio:3/2; overflow:hidden; }
.project-card__image img { width:100%; height:100%; object-fit:cover; transition:transform .5s; }
.project-card:hover .project-card__image img { transform:scale(1.06); }
.project-card__badge { position:absolute; top:12px; left:12px; padding:4px 11px; border-radius:50px; font-size:10px; font-weight:800; letter-spacing:.08em; text-transform:uppercase; color:#fff; }
.project-card__badge--red   { background:var(--color-primary); }
.project-card__badge--green { background:var(--color-secondary); }
.project-card__badge--gold  { background:var(--color-gold); color:#1a1a1a; }
.project-card__body { padding:18px 20px; }
.project-card__title { font-size:15px; font-weight:800; color:var(--color-dark); margin-bottom:6px; line-height:1.3; }
.project-card__title a { color:inherit; }
.project-card__title a:hover { color:var(--color-primary); }
.project-card__excerpt { font-size:13px; color:var(--color-gray); margin-bottom:12px; line-height:1.6; }
.project-card__footer { display:flex; align-items:center; justify-content:space-between; border-top:1px solid var(--color-border); padding-top:10px; }
.project-card__price { font-size:15px; font-weight:900; color:var(--color-primary); }
.project-card__location { font-size:12px; color:var(--color-gray); display:flex; align-items:center; gap:4px; }
.project-card__location i { color:var(--color-secondary); font-size:11px; }

/* News grid */
.news-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.news-card { background:#fff; border:1px solid var(--color-border); border-radius:var(--radius-lg); overflow:hidden; transition:var(--transition); }
.news-card:hover { box-shadow:var(--shadow-md); transform:translateY(-4px); border-color:transparent; }
.news-card__image { position:relative; aspect-ratio:3/2; overflow:hidden; }
.news-card__image img { width:100%; height:100%; object-fit:cover; transition:transform .5s; }
.news-card:hover .news-card__image img { transform:scale(1.06); }
.news-card__category { position:absolute; top:12px; left:12px; background:var(--color-secondary); color:#fff; padding:3px 10px; border-radius:50px; font-size:10px; font-weight:800; text-transform:uppercase; }
.news-card__body { padding:18px 20px; }
.news-card__date { display:flex; align-items:center; gap:5px; font-size:12px; color:var(--color-gray-light); margin-bottom:8px; }
.news-card__date i { font-size:11px; color:var(--color-secondary-light); }
.news-card__title { font-size:15px; font-weight:800; color:var(--color-dark); line-height:1.42; margin-bottom:8px; }
.news-card__title a { color:inherit; }
.news-card__title a:hover { color:var(--color-primary); }
.news-card__excerpt { font-size:13px; color:var(--color-gray); line-height:1.65; margin-bottom:12px; }
.news-card__read-more { display:inline-flex; align-items:center; gap:5px; font-size:12.5px; font-weight:700; color:var(--color-primary); transition:gap .2s; }
.news-card__read-more:hover { gap:9px; }

/* ============================================================
   ARCHIVE / INDEX
   ============================================================ */
.archive-wrapper { background:var(--color-bg); padding:44px 0 80px; }
.archive-layout { display:grid; grid-template-columns:1fr 300px; gap:36px; align-items:start; }

/* Cat filter */
.cat-filter { background:#fff; border-bottom:1px solid var(--color-border); position:sticky; top:68px; z-index:50; box-shadow:var(--shadow-sm); }
.cat-filter__inner { max-width:var(--container-width); margin-inline:auto; padding-inline:var(--container-pad); display:flex; gap:0; overflow-x:auto; scrollbar-width:none; }
.cat-filter__inner::-webkit-scrollbar { display:none; }
.cat-filter__tab { display:inline-flex; align-items:center; gap:6px; padding:14px 18px; border:none; background:transparent; font-size:13px; font-weight:600; color:var(--color-gray); cursor:pointer; white-space:nowrap; border-bottom:2.5px solid transparent; transition:all .2s; font-family:var(--font-body); text-decoration:none; }
.cat-filter__tab:hover { color:var(--color-primary); }
.cat-filter__tab.is-active { color:var(--color-primary); border-bottom-color:var(--color-primary); }
.cat-filter__count { font-size:10.5px; font-weight:700; background:var(--color-bg); border:1px solid var(--color-border); padding:1px 7px; border-radius:50px; color:var(--color-gray); }
.cat-filter__tab.is-active .cat-filter__count { background:var(--color-primary-light); border-color:rgba(196,18,48,.2); color:var(--color-primary); }

/* Featured post */
.post-featured { border-radius:var(--radius-xl); overflow:hidden; position:relative; height:380px; cursor:pointer; margin-bottom:32px; box-shadow:var(--shadow-md); display:block; text-decoration:none; }
.post-featured img { width:100%; height:100%; object-fit:cover; transition:transform .6s ease; }
.post-featured:hover img { transform:scale(1.04); }
.post-featured__overlay { position:absolute; inset:0; background:linear-gradient(to top, rgba(10,18,28,.92) 38%, rgba(10,18,28,.15) 72%, transparent); }
.post-featured__body { position:absolute; bottom:0; left:0; right:0; padding:28px 30px; }
.post-featured__cat { display:inline-flex; align-items:center; gap:5px; color:#fff; font-size:9.5px; font-weight:800; letter-spacing:1.2px; text-transform:uppercase; padding:4px 13px; border-radius:50px; margin-bottom:11px; background:var(--color-secondary); }
.post-featured__title { font-size:clamp(17px,2vw,22px); font-weight:900; color:#fff; line-height:1.3; margin-bottom:10px; }
.post-featured:hover .post-featured__title { color:var(--color-secondary-light); }
.post-featured__meta { display:flex; align-items:center; gap:18px; font-size:12px; color:rgba(255,255,255,.6); flex-wrap:wrap; }
.post-featured__meta-item { display:flex; align-items:center; gap:5px; }
.post-featured__meta-item i { color:var(--color-secondary-light); font-size:10px; }

/* Toolbar */
.post-toolbar { display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom:22px; flex-wrap:wrap; }
.post-toolbar__count { font-size:13px; color:var(--color-gray); }
.post-toolbar__count strong { color:var(--color-text); font-weight:700; }

/* Post card */
.post-list { display:flex; flex-direction:column; gap:18px; }
.post-card { background:#fff; border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--color-border); transition:transform .3s,box-shadow .3s; display:grid; grid-template-columns:240px 1fr; }
.post-card:hover { transform:translateY(-4px); box-shadow:0 18px 50px rgba(0,0,0,.10); border-color:transparent; }
.post-card__thumb { position:relative; overflow:hidden; }
.post-card__thumb img { width:100%; height:100%; object-fit:cover; transition:transform .5s; display:block; }
.post-card:hover .post-card__thumb img { transform:scale(1.07); }
.post-card__badge { position:absolute; top:12px; left:12px; color:#fff; font-size:9.5px; font-weight:800; letter-spacing:1px; text-transform:uppercase; padding:4px 11px; border-radius:50px; text-decoration:none; }
.post-card__badge--green  { background:var(--color-secondary); }
.post-card__badge--red    { background:var(--color-primary); }
.post-card__badge--gold   { background:var(--color-gold); color:#1a1a1a; }
.post-card__badge--teal   { background:#0891b2; }
.post-card__badge--violet { background:#7c3aed; }
.post-card__body { padding:20px 24px; display:flex; flex-direction:column; justify-content:space-between; gap:8px; }
.post-card__meta { font-size:11.5px; color:var(--color-gray-light); font-weight:500; display:flex; align-items:center; gap:14px; flex-wrap:wrap; }
.post-card__meta-item { display:flex; align-items:center; gap:4px; }
.post-card__title { font-size:15.5px; font-weight:800; color:var(--color-dark); line-height:1.42; }
.post-card__title a { color:inherit; }
.post-card:hover .post-card__title a { color:var(--color-primary); }
.post-card__excerpt { font-size:13px; color:var(--color-gray); line-height:1.7; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.post-card__footer { display:flex; align-items:center; justify-content:space-between; padding-top:12px; border-top:1px solid var(--color-border); gap:8px; flex-wrap:wrap; }
.post-card__author { display:flex; align-items:center; gap:7px; }
.post-card__author img { width:24px; height:24px; border-radius:50%; object-fit:cover; }
.post-card__author span { font-size:11.5px; font-weight:600; color:var(--color-gray); }
.post-read-more { display:inline-flex; align-items:center; gap:5px; font-size:12.5px; font-weight:700; color:var(--color-primary); transition:gap .2s; text-decoration:none; }
.post-read-more:hover { gap:9px; }

/* Pagination */
.pagination-wrap { margin-top:40px; }
.pagination { display:flex; align-items:center; justify-content:center; gap:5px; flex-wrap:wrap; }
.pagination .page-numbers { min-width:38px; height:38px; padding:0 10px; display:inline-flex; align-items:center; justify-content:center; border-radius:var(--radius-sm); border:1.5px solid var(--color-border); font-size:13px; font-weight:600; color:var(--color-gray); background:#fff; text-decoration:none; transition:all .2s; }
.pagination .page-numbers:hover { border-color:var(--color-primary); color:var(--color-primary); background:var(--color-primary-light); }
.pagination .page-numbers.current { background:var(--color-primary); border-color:var(--color-primary); color:#fff; }
.pagination .dots { border:none; background:transparent; }

/* No posts */
.no-posts { text-align:center; padding:60px 20px; }
.no-posts i { font-size:48px; color:var(--color-border); margin-bottom:16px; display:block; }
.no-posts h2 { font-size:20px; font-weight:800; color:var(--color-dark); margin-bottom:8px; }
.no-posts p { color:var(--color-gray); margin-bottom:24px; }

/* ============================================================
   SINGLE POST
   ============================================================ */
.post-header { background:linear-gradient(135deg,var(--color-dark) 0%,var(--color-dark2) 55%,#0d2a1a 100%); color:#fff; padding:52px 0 56px; position:relative; overflow:hidden; }
.post-header::after { content:''; position:absolute; width:500px; height:500px; background:radial-gradient(circle,rgba(106,191,69,.10) 0%,transparent 70%); top:-200px; right:-80px; pointer-events:none; }
.post-header__inner { position:relative; z-index:1; }
.post-header .breadcrumb { display:flex; align-items:center; gap:8px; font-size:13px; color:rgba(255,255,255,.5); margin-bottom:18px; flex-wrap:wrap; }
.post-header .breadcrumb a { color:rgba(255,255,255,.7); }
.post-header .breadcrumb a:hover { color:#fff; }
.post-header .breadcrumb__sep { color:rgba(255,255,255,.3); }
.post-header .breadcrumb__current { color:rgba(255,255,255,.85); }
.post-header .breadcrumb__list { display:flex; align-items:center; gap:8px; list-style:none; flex-wrap:wrap; }
.post-header .breadcrumb__item:not(:last-child)::after { content:'›'; color:rgba(255,255,255,.3); font-size:14px; margin-left:4px; }
.post-header__cat { display:inline-flex; align-items:center; gap:6px; background:rgba(106,191,69,.2); color:var(--color-secondary-light); border:1px solid rgba(106,191,69,.3); padding:5px 14px; border-radius:50px; font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.08em; margin-bottom:14px; text-decoration:none; }
.post-header__title { font-size:clamp(22px,3.5vw,40px); font-weight:900; line-height:1.22; color:#fff; margin-bottom:20px; max-width:760px; }
.post-header__meta { display:flex; align-items:center; gap:16px; flex-wrap:wrap; }
.post-header__meta-item { display:flex; align-items:center; gap:7px; font-size:13px; color:rgba(255,255,255,.7); }
.post-header__meta-item i { color:var(--color-secondary-light); font-size:12px; }
.post-header__avatar { width:32px; height:32px; border-radius:50%; border:2px solid rgba(255,255,255,.3); object-fit:cover; }

/* Single layout */
.single-wrapper { background:var(--color-bg); padding:40px 0 80px; }
.single-layout  { display:grid; grid-template-columns:1fr 300px; gap:36px; align-items:start; }

/* Quan trọng: main column không được mở rộng quá grid cell */
.single-layout > main { min-width: 0; overflow: hidden; }

.article-card   { background:#fff; border-radius:var(--radius-xl); border:1px solid var(--color-border); overflow:hidden; box-shadow:var(--shadow-sm); }

/* Article card */
.article-thumb img { width:100%; max-height:480px; object-fit:cover; display:block; }
.article-thumb__caption { font-size:12px; color:var(--color-gray); text-align:center; padding:8px 16px; background:var(--color-bg); border-top:1px solid var(--color-border); }
.article-thumb { position:relative; }
.article-thumb img { width:100%; max-height:480px; object-fit:cover; }
.article-thumb__caption { font-size:12px; color:var(--color-gray); text-align:center; padding:8px 16px; background:var(--color-bg); border-top:1px solid var(--color-border); }

/* Article toolbar */
.article-toolbar { display:flex; align-items:center; justify-content:space-between; padding:14px 28px; border-bottom:1px solid var(--color-border); background:var(--color-bg); flex-wrap:wrap; gap:10px; }
.article-toolbar__stats { display:flex; gap:16px; }
.article-toolbar__stat { display:flex; align-items:center; gap:5px; font-size:12.5px; color:var(--color-gray); }
.article-toolbar__stat i { color:var(--color-secondary); font-size:12px; }
.article-toolbar__share { display:flex; align-items:center; gap:7px; }
.article-toolbar__label { font-size:12px; font-weight:600; color:var(--color-gray); }
.share-btn { width:32px; height:32px; border-radius:8px; border:1.5px solid var(--color-border); background:#fff; display:flex; align-items:center; justify-content:center; cursor:pointer; font-size:12px; color:var(--color-gray); transition:all .2s; text-decoration:none; }
.share-btn:hover,.share-btn:focus { transform:translateY(-1px); }
.share-btn--fb:hover  { background:#1877f2; border-color:#1877f2; color:#fff; }
.share-btn--tw:hover  { background:#000; border-color:#000; color:#fff; }
.share-btn--link:hover { background:var(--color-secondary); border-color:var(--color-secondary); color:#fff; }
.share-btn--print:hover{ background:var(--color-dark); border-color:var(--color-dark); color:#fff; }

/* Article body */
.article-body  { padding:32px 36px; }

/* entry-content – toàn bộ nội dung phải nằm trong khung */
.entry-content {
  font-size: 15.5px;
  line-height: 1.82;
  color: var(--color-text);
  /* Quan trọng: ép mọi child không tràn ra ngoài */
  overflow-wrap: break-word;
  word-break: break-word;
  min-width: 0;
}

/* Ảnh & media luôn nằm trong khung – không bao giờ tràn */
.entry-content img,
.entry-content video,
.entry-content iframe,
.entry-content figure,
.entry-content .wp-block-image,
.entry-content .wp-block-embed,
.entry-content .wp-block-video {
  max-width: 100% !important;
  height: auto;
  display: block;
}

/* Ảnh trong bài viết */
.entry-content img {
  border-radius: var(--radius-md);
  margin: 20px 0;
  width: auto;       /* không force width=100%, giữ tỉ lệ gốc */
  max-width: 100%;   /* nhưng không được tràn khung */
}

/* Figure với caption */
.entry-content figure {
  margin: 24px 0;
}
.entry-content figure img {
  margin: 0;
  width: 100%;
}
.entry-content figcaption {
  font-size: 12.5px;
  color: var(--color-gray);
  text-align: center;
  margin-top: 8px;
  font-style: italic;
}

/* iframe embed (YouTube, Google Maps…) */
.entry-content iframe {
  width: 100%;
  border-radius: var(--radius-md);
  margin: 20px 0;
}

/* Responsive embed wrapper */
.entry-content .wp-block-embed__wrapper,
.entry-content .embed-wrap {
  position: relative;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  border-radius: var(--radius-md);
  margin: 20px 0;
}
.entry-content .wp-block-embed__wrapper iframe,
.entry-content .embed-wrap iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  margin: 0;
  border-radius: 0;
}

/* Typography */
.entry-content h2 { font-size:22px; font-weight:900; color:var(--color-dark); margin:5px 0 14px; padding-bottom:8px; border-bottom:0px solid var(--color-border); }
.entry-content h3 { font-size:18px; font-weight:800; color:var(--color-dark); margin:24px 0 10px; }
.entry-content h4 { font-size:16px; font-weight:700; color:var(--color-dark); margin:20px 0 8px; }
.entry-content p  { margin-bottom:16px; }
.entry-content a  { color:var(--color-primary); text-decoration:underline; }
.entry-content a:hover { color:var(--color-primary-dark); }
.entry-content strong,
.entry-content b   { font-weight:700; color:var(--color-dark); }

/* ── List styles – phục hồi bullet/number bị reset bởi global ul{list-style:none} ── */
.entry-content ul,
.entry-content ul.wp-block-list,
.entry-content .wp-block-list {
  list-style: disc !important;
  padding-left: 22px !important;
  margin-bottom: 18px;
}
.entry-content ol {
  list-style: decimal !important;
  padding-left: 22px !important;
  margin-bottom: 18px;
}
.entry-content li {
  list-style: inherit !important;
  margin-bottom: 7px;
  padding-left: 4px;
  line-height: 1.7;
}
/* Nested list */
.entry-content ul ul,
.entry-content ol ol,
.entry-content ul ol,
.entry-content ol ul {
  margin-top: 6px;
  margin-bottom: 0;
}
.entry-content ul ul  { list-style: circle !important; }
.entry-content ul ul ul { list-style: square !important; }

.entry-content blockquote {
  border-left:4px solid var(--color-primary);
  background:var(--color-primary-light);
  padding:16px 20px;
  margin:24px 0;
  border-radius:0 var(--radius-sm) var(--radius-sm) 0;
  font-style:italic;
}
.entry-content blockquote cite { display:block; font-style:normal; font-size:13px; color:var(--color-gray); margin-top:8px; }

.entry-content table  { width:100%; border-collapse:collapse; margin:20px 0; font-size:14px; display:block; overflow-x:auto; }
.entry-content th     { background:var(--color-dark); color:#fff; padding:10px 14px; text-align:left; font-size:12.5px; text-transform:uppercase; letter-spacing:.04em; white-space:nowrap; }
.entry-content td     { padding:10px 14px; border-bottom:1px solid var(--color-border); }
.entry-content tr:nth-child(even) td { background:var(--color-bg); }

/* Tags */
.article-tags { display:flex; align-items:center; flex-wrap:wrap; gap:8px; margin-top:28px; padding-top:20px; border-top:1px solid var(--color-border); }
.article-tags__label { font-size:12.5px; font-weight:700; color:var(--color-gray); display:flex; align-items:center; gap:6px; }
.article-tag { font-size:12px; font-weight:600; color:var(--color-text); background:var(--color-bg); border:1px solid var(--color-border); padding:4px 12px; border-radius:50px; text-decoration:none; transition:var(--transition); }
.article-tag:hover { background:var(--color-primary-light); border-color:rgba(196,18,48,.2); color:var(--color-primary); }

/* Author box */
.author-box { display:flex; align-items:center; gap:20px; background:var(--color-bg); border-top:1px solid var(--color-border); padding:24px 36px; }
.author-box__avatar { width:72px; height:72px; border-radius:50%; object-fit:cover; border:3px solid var(--color-secondary-pale); flex-shrink:0; }
.author-box__role { font-size:10.5px; font-weight:700; text-transform:uppercase; letter-spacing:.1em; color:var(--color-secondary); margin-bottom:3px; }
.author-box__name { font-size:16px; font-weight:800; color:var(--color-dark); margin-bottom:4px; }
.author-box__bio { font-size:13px; color:var(--color-gray); line-height:1.65; }

/* Post nav */
.post-nav { display:grid; grid-template-columns:1fr 1fr; gap:0; border-top:1px solid var(--color-border); }
.post-nav__item { padding:16px 24px; }
.post-nav__item--next { text-align:right; border-left:1px solid var(--color-border); }
.post-nav__dir { display:flex; align-items:center; gap:5px; font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:var(--color-gray); margin-bottom:5px; }
.post-nav__item--next .post-nav__dir { justify-content:flex-end; }
.post-nav__title { font-size:14px; font-weight:700; color:var(--color-dark); text-decoration:none; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; line-height:1.4; }
.post-nav__title:hover { color:var(--color-primary); }

/* Related */
.related-section { padding:32px; border-top:1px solid var(--color-border); }
.related-section__title { font-size:15px; font-weight:800; color:var(--color-dark); margin-bottom:20px; display:flex; align-items:center; gap:8px; }
.related-section__title i { color:var(--color-primary); }
.related-grid {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 0;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  overflow: hidden;
}
.related-card {
  border-right: 1px solid var(--color-border);
  display: flex;
  flex-direction: column;
}
.related-card:last-child { border-right: none; }

/* Image wrapper – luôn đúng tỉ lệ 16/9 */
.related-card__img-wrap {
  display: block;
  position: relative;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: var(--color-bg);
  flex-shrink: 0;
}
.related-card__img-wrap img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .4s ease;
  display: block;
}
.related-card:hover .related-card__img-wrap img { transform: scale(1.06); }

/* Placeholder khi không có ảnh */
.related-card__img-wrap--no-thumb {
  background: linear-gradient(135deg, var(--color-bg) 0%, #e8edf3 100%);
  display: flex;
  align-items: center;
  justify-content: center;
}
.related-card__img-wrap--no-thumb::after {
  content: '\f1ea'; /* fa-newspaper */
  font-family: 'Font Awesome 6 Free';
  font-weight: 900;
  font-size: 32px;
  color: var(--color-border);
  position: absolute;
}

.related-card__body { padding: 14px 16px; flex: 1; }
.related-card__date {
  font-size: 11.5px;
  color: var(--color-gray-light);
  display: flex; align-items: center; gap: 5px;
  margin-bottom: 7px;
}
.related-card__date i { color: var(--color-secondary-light); font-size: 10px; }
.related-card__title {
  font-size: 13.5px;
  font-weight: 700;
  color: var(--color-dark);
  line-height: 1.45;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.related-card__title a { color: inherit; text-decoration: none; }
.related-card:hover .related-card__title a { color: var(--color-primary); }

/* Sidebar */
.sidebar { position:sticky; top:126px; display:flex; flex-direction:column; gap:20px; }
/* .widget base – xem định nghĩa đầy đủ tại block WIDGET SYSTEM bên dưới */
.widget__head { display:flex; align-items:center; gap:10px; padding:13px 18px; border-bottom:1px solid var(--color-border); background:var(--color-bg); }
.widget__head-icon { width:30px; height:30px; border-radius:8px; display:flex; align-items:center; justify-content:center; font-size:13px; flex-shrink:0; }
.widget__head-icon--red   { background:var(--color-primary-light);  color:var(--color-primary); }
.widget__head-icon--green { background:var(--color-secondary-pale); color:var(--color-secondary); }
.widget__head-icon--gold  { background:rgba(212,168,71,.12); color:var(--color-gold); }
.widget__title { font-size:12px; font-weight:800; color:var(--color-dark); text-transform:uppercase; letter-spacing:.5px; }
.widget__body { padding:16px 18px; }
.widget .search-form { display:flex; gap:8px; }
.widget .search-field { flex:1; }
.widget .search-field input { width:100%; padding:10px 12px; border:1.5px solid var(--color-border); border-radius:var(--radius-sm); font-size:13px; font-family:var(--font-body); color:var(--color-text); outline:none; transition:border-color .2s; }
.widget .search-field input:focus { border-color:var(--color-primary); }
.widget .search-submit { width:40px; height:40px; border-radius:var(--radius-sm); border:none; background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark)); color:#fff; cursor:pointer; display:flex; align-items:center; justify-content:center; }
.w-cats { padding:6px 0; }
.w-cat { display:flex; align-items:center; justify-content:space-between; gap:10px; padding:9px 18px; cursor:pointer; transition:background .18s; font-size:13px; text-decoration:none; color:var(--color-text); }
.w-cat:hover { background:var(--color-bg); }
.w-cat.is-active { background:var(--color-primary-light); }
.w-cat__left { display:flex; align-items:center; gap:9px; }
.w-cat__dot { width:8px; height:8px; border-radius:50%; flex-shrink:0; }
.w-cat__name { font-weight:600; transition:color .18s; }
.w-cat:hover .w-cat__name, .w-cat.is-active .w-cat__name { color:var(--color-primary); }
.w-cat__count { font-size:10.5px; font-weight:700; color:var(--color-gray-light); background:var(--color-bg); padding:2px 7px; border-radius:50px; border:1px solid var(--color-border); }
.w-cat.is-active .w-cat__count { background:var(--color-primary); color:#fff; border-color:var(--color-primary); }
.w-posts { display:flex; flex-direction:column; }
.w-post { display:grid; grid-template-columns:68px 1fr; gap:11px; padding:12px 0; border-bottom:1px solid var(--color-border); text-decoration:none; color:var(--color-text); }
.w-post:last-child { border-bottom:none; padding-bottom:0; }
.w-post__thumb { width:68px; height:68px; border-radius:var(--radius-sm); overflow:hidden; flex-shrink:0; }
.w-post__thumb img { width:100%; height:100%; object-fit:cover; }
.w-post__title { font-size:13px; font-weight:700; color:var(--color-dark); line-height:1.4; display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden; margin-bottom:5px; transition:color .2s; }
.w-post:hover .w-post__title { color:var(--color-primary); }
.w-post__date { font-size:11px; color:var(--color-gray-light); display:flex; align-items:center; gap:4px; }
.widget--cta { background:linear-gradient(135deg,var(--color-dark),var(--color-dark2)); border-color:transparent; }
.widget-cta__inner { padding:24px; text-align:center; }
.widget-cta__icon { width:56px; height:56px; background:rgba(255,255,255,.1); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:22px; color:var(--color-secondary-light); margin:0 auto 14px; }
.widget-cta__title { font-size:16px; font-weight:900; color:#fff; margin-bottom:8px; }
.widget-cta__desc { font-size:13px; color:rgba(255,255,255,.7); margin-bottom:16px; line-height:1.6; }
.widget-cta__phone { display:flex; align-items:center; justify-content:center; gap:7px; font-size:13.5px; font-weight:700; color:var(--color-secondary-light); margin-top:12px; text-decoration:none; }

/* ============================================================
   RESPONSIVE – Homepage, Archive, Single
   ============================================================ */
@media(max-width:1024px) {
    .intro-grid { grid-template-columns:1fr; gap:40px; }
    .float-card,.float-card--green { display:none; }
    .services-grid { grid-template-columns:repeat(2,1fr); }
    .projects-grid { grid-template-columns:repeat(2,1fr); }
    .news-grid { grid-template-columns:repeat(2,1fr); }
    .search-form { grid-template-columns:1fr 1fr; }
    .btn--search { width:100%; justify-content:center; grid-column:1/-1; }
    .single-layout, .archive-layout { grid-template-columns:1fr; }
    .sidebar { position:static; }
}
@media(max-width:768px) {
    .home-hero__inner { grid-template-columns:1fr; gap:40px; padding-top:64px; padding-bottom:64px; }
    .home-hero__right { display:none; }
    .services-grid { grid-template-columns:1fr 1fr; }
    .projects-grid { grid-template-columns:1fr; }
    .news-grid { grid-template-columns:1fr; }
    .stats-bar__grid { grid-template-columns:repeat(2,1fr); }
    .post-card { grid-template-columns:140px 1fr; }
    .related-grid { grid-template-columns: 1fr; }
    .related-card { border-right: none; border-bottom: 1px solid var(--color-border); }
    .related-card:last-child { border-bottom: none; }
    .post-nav { grid-template-columns:1fr; }
    .post-nav__item--next { border-left:none; border-top:1px solid var(--color-border); text-align:left; }
    .post-nav__item--next .post-nav__dir { justify-content:flex-start; }
    .article-body { padding:20px; }
    .author-box { flex-direction:column; text-align:center; }
}
@media(max-width:580px) {
    .home-hero__title { font-size:28px; }
    .home-hero__stats { gap: 0; }
    .home-hero__stat strong { font-size:18px; }
    .search-form { grid-template-columns:1fr; }
    .services-grid { grid-template-columns:1fr; }
    .stats-bar__grid { grid-template-columns:1fr 1fr; }
    .post-card { grid-template-columns:1fr; }
    .post-card__thumb { height:200px; }
    .archive-wrapper { padding:24px 0 60px; }
}

/* ============================================================
   DU AN – page-templates/page-du-an.php + single-project.php
   ============================================================ */

/* Hero */
.du-an-hero { position:relative; background:linear-gradient(135deg,var(--color-dark) 0%,var(--color-dark2) 55%,#0d2a1a 100%); color:#fff; padding:56px 0 60px; overflow:hidden; }
.du-an-hero__bg { position:absolute; inset:0; background:url('https://images.unsplash.com/photo-1486325212027-8081e485255e?w=1600&q=70') center/cover; opacity:.18; }
.du-an-hero__stripe { position:absolute; bottom:0; left:0; right:0; height:5px; background:linear-gradient(90deg,var(--color-primary),var(--color-secondary)); }
.du-an-hero__inner { position:relative; z-index:1; }
.du-an-hero .breadcrumb { display:flex; align-items:center; gap:8px; font-size:13px; color:rgba(255,255,255,.5); margin-bottom:16px; flex-wrap:wrap; list-style:none; }
.du-an-hero .breadcrumb__list { display:flex; align-items:center; gap:8px; list-style:none; flex-wrap:wrap; }
.du-an-hero .breadcrumb__item:not(:last-child)::after { content:'›'; color:rgba(255,255,255,.3); margin-left:4px; }
.du-an-hero .breadcrumb a { color:rgba(255,255,255,.7); }
.du-an-hero .breadcrumb a:hover { color:#fff; }
.du-an-hero .breadcrumb__current { color:rgba(255,255,255,.85); }
.du-an-hero__eyebrow { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:2px; color:var(--color-secondary-light); margin-bottom:12px; }
.du-an-hero__title { font-size:clamp(26px,4vw,52px); font-weight:900; line-height:1.12; margin-bottom:16px; }
.du-an-hero__title em { font-style:normal; color:var(--color-secondary-light); }
.du-an-hero__desc { font-size:15px; line-height:1.72; color:rgba(255,255,255,.78); max-width:600px; margin-bottom:28px; }
.du-an-hero__btns { display:flex; gap:12px; flex-wrap:wrap; margin-bottom:36px; }
.du-an-hero__stats { display:flex; gap:36px; flex-wrap:wrap; }
.du-an-hero__stat { text-align:center; }
.du-an-hero__stat-num { font-size:26px; font-weight:900; color:var(--color-secondary-light); line-height:1; }
.du-an-hero__stat-lbl { font-size:11.5px; color:rgba(255,255,255,.65); margin-top:4px; }

/* Filter tabs */
.da-filter-tabs { background:#fff; border-bottom:1px solid var(--color-border); position:sticky; top:68px; z-index:50; box-shadow:var(--shadow-sm); }
.da-filter-tabs__inner { display:flex; gap:0; overflow-x:auto; scrollbar-width:none; }
.da-filter-tabs__inner::-webkit-scrollbar { display:none; }
.da-ftab { display:inline-flex; align-items:center; gap:7px; padding:14px 18px; border:none; background:transparent; font-size:13px; font-weight:600; color:var(--color-gray); cursor:pointer; white-space:nowrap; border-bottom:2.5px solid transparent; transition:all .2s; font-family:var(--font-body); text-decoration:none; }
.da-ftab:hover { color:var(--color-primary); }
.da-ftab.is-active { color:var(--color-primary); border-bottom-color:var(--color-primary); }
.da-ftab__cnt { font-size:10.5px; font-weight:700; background:var(--color-bg); border:1px solid var(--color-border); padding:1px 6px; border-radius:50px; color:var(--color-gray); }
.da-ftab.is-active .da-ftab__cnt { background:var(--color-primary-light); border-color:rgba(196,18,48,.2); color:var(--color-primary); }

/* Layout */
.da-wrapper { background:var(--color-bg); padding:36px 0 80px; }
.da-layout { display:grid; grid-template-columns:1fr 280px; gap:32px; align-items:start; }

/* Filter row */
.da-filter-row { margin-bottom:16px; }
.da-filter-form { display:grid; grid-template-columns:1fr 1fr 1fr auto; gap:12px; align-items:end; background:#fff; border:1px solid var(--color-border); border-radius:var(--radius-lg); padding:18px 20px; }
.da-fg label { display:block; font-size:11.5px; font-weight:700; color:var(--color-dark); margin-bottom:5px; text-transform:uppercase; letter-spacing:.04em; }
.da-fselect { width:100%; padding:9px 12px; border:1.5px solid var(--color-border); border-radius:var(--radius-sm); font-size:13px; font-family:var(--font-body); color:var(--color-text); background:#fff; outline:none; transition:border-color .2s; }
.da-fselect:focus { border-color:var(--color-primary); }
.da-filter-submit { padding:9px 18px; height:38px; align-self:flex-end; }

/* Meta row */
.da-meta-row { display:flex; align-items:center; justify-content:space-between; margin-bottom:18px; flex-wrap:wrap; gap:8px; }
.da-meta-count { font-size:13px; color:var(--color-gray); }
.da-meta-count strong { color:var(--color-text); font-weight:700; }

/* Project card grid */
.da-project-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.da-project-card { background:#fff; border:1px solid var(--color-border); border-radius:var(--radius-lg); overflow:hidden; transition:transform .3s,box-shadow .3s; }
.da-project-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-md); border-color:transparent; }
.da-project-card__thumb { position:relative; aspect-ratio:4/3; overflow:hidden; }
.da-project-card__thumb a { display:block; height:100%; }
.da-project-card__thumb img { width:100%; height:100%; object-fit:cover; transition:transform .5s; }
.da-project-card:hover .da-project-card__thumb img { transform:scale(1.06); }
.da-pc-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(10,18,28,.65) 0%,transparent 55%); }
.da-pc-badges { position:absolute; top:12px; left:12px; display:flex; gap:6px; flex-wrap:wrap; }
.da-pbadge { display:inline-flex; align-items:center; gap:4px; padding:4px 11px; border-radius:50px; font-size:10px; font-weight:800; letter-spacing:.06em; text-transform:uppercase; color:#fff; }
.da-pbadge--hot  { background:var(--color-primary); }
.da-pbadge--new  { background:var(--color-secondary); }
.da-pbadge--soon { background:var(--color-gold); color:#1a1a1a; }
.da-pbadge--type { background:rgba(255,255,255,.15); backdrop-filter:blur(4px); border:1px solid rgba(255,255,255,.25); }
.da-pc-price { position:absolute; bottom:12px; right:12px; text-align:right; }
.da-pfrom { font-size:10px; color:rgba(255,255,255,.75); }
.da-pval { font-size:16px; font-weight:900; color:#fff; line-height:1; }
.da-punit { font-size:10px; color:rgba(255,255,255,.75); }
.da-project-card__body { padding:16px 18px; }
.da-pc-dev { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.06em; color:var(--color-secondary); margin-bottom:4px; }
.da-pc-name { font-size:14.5px; font-weight:800; color:var(--color-dark); line-height:1.3; margin-bottom:6px; }
.da-pc-name a { color:inherit; }
.da-pc-name a:hover { color:var(--color-primary); }
.da-pc-loc { font-size:12px; color:var(--color-gray); display:flex; align-items:center; gap:5px; margin-bottom:10px; }
.da-pc-loc i { color:var(--color-secondary); font-size:11px; flex-shrink:0; }
.da-pc-specs { display:grid; grid-template-columns:1fr 1fr; gap:5px 10px; margin-bottom:12px; }
.da-pspec { display:flex; align-items:center; gap:6px; font-size:12px; color:var(--color-gray); }
.da-pspec i { color:var(--color-secondary-light); font-size:11px; width:14px; text-align:center; }
.da-pc-footer { border-top:1px solid var(--color-border); padding-top:12px; }
.da-pc-progress { margin-bottom:10px; }
.da-prog-lbl { display:flex; justify-content:space-between; font-size:11.5px; margin-bottom:5px; color:var(--color-gray); }
.da-prog-bar { height:5px; background:var(--color-border); border-radius:50px; overflow:hidden; }
.da-prog-fill { height:100%; background:linear-gradient(90deg,var(--color-primary),var(--color-secondary)); border-radius:50px; transition:width .6s ease; }
.da-pc-btn { width:100%; justify-content:center; padding:9px 14px; font-size:12.5px; }

/* Sidebar widgets */
.da-sidebar { position:sticky; top:126px; display:flex; flex-direction:column; gap:18px; }
.da-sc { background:#fff; border:1px solid var(--color-border); border-radius:var(--radius-lg); overflow:hidden; }
.da-sc__head { display:flex; align-items:center; gap:10px; padding:13px 16px; border-bottom:1px solid var(--color-border); background:var(--color-bg); }
.da-sc__icon { width:30px; height:30px; border-radius:8px; display:flex; align-items:center; justify-content:center; font-size:13px; flex-shrink:0; }
.da-sc__icon--red   { background:var(--color-primary-light); color:var(--color-primary); }
.da-sc__icon--green { background:var(--color-secondary-pale); color:var(--color-secondary); }
.da-sc__icon--gold  { background:rgba(212,168,71,.12); color:var(--color-gold); }
.da-sc__title { font-size:12px; font-weight:800; color:var(--color-dark); text-transform:uppercase; letter-spacing:.5px; }
.da-city-list { padding:6px 0; }
.da-city-row { display:flex; align-items:center; justify-content:space-between; padding:9px 16px; font-size:13px; color:var(--color-text); text-decoration:none; transition:background .18s; }
.da-city-row:hover { background:var(--color-bg); }
.da-city-row.is-active { background:var(--color-primary-light); }
.da-city-row.is-active span:first-child { color:var(--color-primary); font-weight:700; }
.da-city-cnt { font-size:11px; font-weight:700; background:var(--color-bg); border:1px solid var(--color-border); padding:2px 8px; border-radius:50px; color:var(--color-gray); }
.da-city-row.is-active .da-city-cnt { background:var(--color-primary); border-color:var(--color-primary); color:#fff; }
.da-type-chips { display:flex; flex-wrap:wrap; gap:7px; padding:14px 16px; }
.da-type-chip { display:inline-flex; padding:5px 13px; border-radius:50px; border:1.5px solid var(--color-border); font-size:12px; font-weight:600; color:var(--color-gray); cursor:pointer; transition:all .2s; text-decoration:none; }
.da-type-chip:hover { border-color:var(--color-primary); color:var(--color-primary); }
.da-type-chip.is-active { background:var(--color-primary); border-color:var(--color-primary); color:#fff; }
.da-feat-list { padding:12px 16px; display:flex; flex-direction:column; gap:12px; }
.da-feat-item { display:grid; grid-template-columns:56px 1fr; gap:10px; align-items:center; }
.da-feat-img { width:56px; height:56px; border-radius:var(--radius-sm); overflow:hidden; flex-shrink:0; }
.da-feat-img img { width:100%; height:100%; object-fit:cover; }
.da-feat-name { font-size:12.5px; font-weight:700; color:var(--color-dark); line-height:1.3; }
.da-feat-name a { color:inherit; }
.da-feat-name a:hover { color:var(--color-primary); }
.da-feat-price { font-size:12px; font-weight:800; color:var(--color-primary); }
.da-feat-loc { font-size:11px; color:var(--color-gray); display:flex; align-items:center; gap:4px; }
.da-feat-loc i { color:var(--color-secondary); font-size:10px; }
.da-sc--cta { background:linear-gradient(135deg,var(--color-dark),var(--color-dark2)); border-color:transparent; }
.da-sc-cta__inner { padding:22px; text-align:center; }
.da-sc-cta__icon { width:52px; height:52px; background:rgba(255,255,255,.1); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:20px; color:var(--color-secondary-light); margin:0 auto 12px; }
.da-sc-cta__title { font-size:15px; font-weight:900; color:#fff; margin-bottom:6px; }
.da-sc-cta__desc { font-size:12.5px; color:rgba(255,255,255,.7); margin-bottom:14px; line-height:1.6; }
.da-sc-cta__phone { display:flex; align-items:center; justify-content:center; gap:6px; font-size:13px; font-weight:700; color:var(--color-secondary-light); margin-top:10px; text-decoration:none; }

/* ── SINGLE PROJECT ── */
.project-header { background:linear-gradient(135deg,var(--color-dark) 0%,var(--color-dark2) 55%,#0d2a1a 100%); padding:44px 0 48px; }
.project-header__inner { position:relative; z-index:1; }
.project-header .breadcrumb,.project-header .breadcrumb__list { display:flex; align-items:center; gap:8px; list-style:none; flex-wrap:wrap; font-size:13px; color:rgba(255,255,255,.5); margin-bottom:14px; }
.project-header .breadcrumb__item:not(:last-child)::after { content:'›'; color:rgba(255,255,255,.3); margin-left:4px; }
.project-header .breadcrumb a { color:rgba(255,255,255,.7); }
.project-header .breadcrumb a:hover { color:#fff; }
.project-header .breadcrumb__current { color:rgba(255,255,255,.85); }
.project-header__badges { display:flex; gap:8px; margin-bottom:12px; flex-wrap:wrap; }
.project-header__badge { padding:4px 13px; border-radius:50px; font-size:10.5px; font-weight:700; text-transform:uppercase; letter-spacing:.06em; }
.project-header__badge--status { background:var(--color-secondary); color:#fff; }
.project-header__badge--type   { background:rgba(255,255,255,.12); color:rgba(255,255,255,.9); border:1px solid rgba(255,255,255,.2); }
.project-header__title { font-size:clamp(22px,3.5vw,42px); font-weight:900; color:#fff; line-height:1.2; margin-bottom:16px; }
.project-header__meta { display:flex; align-items:center; gap:16px; flex-wrap:wrap; }
.project-header__meta-item { display:flex; align-items:center; gap:7px; font-size:13px; color:rgba(255,255,255,.75); }
.project-header__meta-item i { color:var(--color-secondary-light); font-size:12px; }
.project-header__meta-item--price { font-weight:800; color:#fff; font-size:14px; }
.project-header__meta-item--price i { color:var(--color-gold); }

.project-wrapper { background:var(--color-bg); padding:40px 0 80px; }
.project-layout { display:grid; grid-template-columns:1fr 300px; gap:32px; align-items:start; }

.project-gallery { border-radius:var(--radius-xl); overflow:hidden; box-shadow:var(--shadow-md); margin-bottom:20px; }
.project-gallery__main { width:100%; max-height:520px; object-fit:cover; }

.project-specs-bar { display:grid; grid-template-columns:repeat(4,1fr); gap:0; background:#fff; border:1px solid var(--color-border); border-radius:var(--radius-lg); overflow:hidden; margin-bottom:16px; }
.project-spec { padding:16px; display:flex; align-items:center; gap:10px; border-right:1px solid var(--color-border); }
.project-spec:last-child { border-right:none; }
.project-spec__icon { width:36px; height:36px; background:var(--color-secondary-pale); border-radius:9px; display:flex; align-items:center; justify-content:center; font-size:14px; color:var(--color-secondary); flex-shrink:0; }
.project-spec__label { font-size:10.5px; font-weight:700; text-transform:uppercase; letter-spacing:.06em; color:var(--color-gray); display:block; }
.project-spec__val { font-size:13.5px; font-weight:800; color:var(--color-dark); }

.project-progress-section { background:#fff; border:1px solid var(--color-border); border-radius:var(--radius-lg); padding:16px 20px; margin-bottom:16px; }
.project-progress-lbl { display:flex; justify-content:space-between; align-items:center; font-size:13px; margin-bottom:8px; }
.project-progress-lbl strong { color:var(--color-primary); font-size:16px; }
.project-progress-bar { height:8px; background:var(--color-border); border-radius:50px; overflow:hidden; }
.project-progress-fill { height:100%; background:linear-gradient(90deg,var(--color-primary),var(--color-secondary)); border-radius:50px; transition:width .6s ease; }

.project-content { background:#fff; border:1px solid var(--color-border); border-radius:var(--radius-lg); padding:28px 32px; }

/* Project sidebar */
.project-sidebar { position:sticky; top:126px; display:flex; flex-direction:column; gap:18px; }
.pj-cta-box { background:linear-gradient(135deg,var(--color-dark),var(--color-dark2)); border-radius:var(--radius-lg); padding:22px; }
.pj-cta-price { margin-bottom:14px; }
.pj-cta-from { font-size:11px; color:rgba(255,255,255,.6); display:block; margin-bottom:2px; }
.pj-cta-val { font-size:28px; font-weight:900; color:var(--color-secondary-light); line-height:1; }
.pj-cta-progress { margin-bottom:16px; }
.pj-cta-prog-lbl { display:flex; justify-content:space-between; font-size:12px; color:rgba(255,255,255,.7); margin-bottom:6px; }
.pj-cta-prog-lbl strong { color:#fff; }
.pj-cta-phone { display:flex; align-items:center; justify-content:center; gap:7px; font-size:14px; font-weight:700; color:var(--color-secondary-light); text-decoration:none; margin-top:10px; }
.pj-info-box { background:#fff; border:1px solid var(--color-border); border-radius:var(--radius-lg); overflow:hidden; }
.pj-info-box__title { display:flex; align-items:center; gap:8px; font-size:12.5px; font-weight:800; color:var(--color-dark); padding:13px 16px; border-bottom:1px solid var(--color-border); background:var(--color-bg); text-transform:uppercase; letter-spacing:.4px; }
.pj-info-box__title i { color:var(--color-primary); }
.pj-info-row { display:flex; align-items:flex-start; justify-content:space-between; gap:10px; padding:10px 16px; border-bottom:1px solid var(--color-border); font-size:13px; }
.pj-info-row:last-child { border-bottom:none; }
.pj-info-row__label { display:flex; align-items:center; gap:6px; color:var(--color-gray); font-weight:500; white-space:nowrap; }
.pj-info-row__label i { color:var(--color-secondary); font-size:12px; width:14px; text-align:center; }
.pj-info-row__val { font-weight:700; color:var(--color-dark); text-align:right; }
.pj-related-box { background:#fff; border:1px solid var(--color-border); border-radius:var(--radius-lg); overflow:hidden; }
.pj-related-box__title { display:flex; align-items:center; gap:8px; font-size:12.5px; font-weight:800; color:var(--color-dark); padding:13px 16px; border-bottom:1px solid var(--color-border); background:var(--color-bg); text-transform:uppercase; letter-spacing:.4px; }
.pj-related-box__title i { color:var(--color-secondary); }
.pj-related-item { display:grid; grid-template-columns:60px 1fr; gap:10px; padding:12px 16px; border-bottom:1px solid var(--color-border); text-decoration:none; transition:background .18s; }
.pj-related-item:last-child { border-bottom:none; }
.pj-related-item:hover { background:var(--color-bg); }
.pj-related-img { width:60px; height:60px; border-radius:var(--radius-sm); object-fit:cover; }
.pj-related-name { font-size:12.5px; font-weight:700; color:var(--color-dark); line-height:1.3; margin-bottom:3px; }
.pj-related-item:hover .pj-related-name { color:var(--color-primary); }
.pj-related-loc { font-size:11px; color:var(--color-gray); display:flex; align-items:center; gap:4px; }
.pj-related-loc i { color:var(--color-secondary); font-size:10px; }
.pj-related-price { font-size:12px; font-weight:800; color:var(--color-primary); }

/* CTA Band (homepage) */
.cta-band { background:linear-gradient(135deg,var(--color-primary-dark) 0%,var(--color-primary) 50%,#c41230dd 100%); padding:56px 0; }
.cta-band__inner { display:flex; align-items:center; justify-content:space-between; gap:32px; flex-wrap:wrap; }
.cta-band h2 { font-size:clamp(22px,3vw,36px); font-weight:900; color:#fff; line-height:1.22; }
.cta-band p { font-size:15px; color:rgba(255,255,255,.82); margin-top:8px; }
.cta-band__actions { display:flex; gap:12px; flex-wrap:wrap; flex-shrink:0; }

/* ============================================================
   TUYEN DUNG – page-templates/page-tuyen-dung.php + single-job.php
   ============================================================ */

/* Hero */
.td-hero { position:relative; background:linear-gradient(135deg,var(--color-dark) 0%,var(--color-dark2) 55%,#1a0d1e 100%); color:#fff; padding:56px 0 60px; overflow:hidden; }
.td-hero__bg { position:absolute; inset:0; background:url('https://images.unsplash.com/photo-1600880292203-757bb62b4baf?w=1600&q=70') center/cover; opacity:.14; }
.td-hero__inner { position:relative; z-index:1; }
.td-hero .breadcrumb,.td-hero .breadcrumb__list { display:flex; align-items:center; gap:8px; list-style:none; flex-wrap:wrap; font-size:13px; color:rgba(255,255,255,.5); margin-bottom:16px; }
.td-hero .breadcrumb__item:not(:last-child)::after { content:'›'; color:rgba(255,255,255,.3); margin-left:4px; }
.td-hero .breadcrumb a { color:rgba(255,255,255,.7); }
.td-hero .breadcrumb__current { color:rgba(255,255,255,.85); }
.td-hero__eyebrow { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:2px; color:var(--color-secondary-light); margin-bottom:12px; }
.td-hero__title { font-size:clamp(24px,4vw,50px); font-weight:900; line-height:1.12; margin-bottom:16px; }
.td-hero__title em { font-style:normal; color:var(--color-secondary-light); }
.td-hero__desc { font-size:15px; line-height:1.72; color:rgba(255,255,255,.78); max-width:580px; margin-bottom:26px; }
.td-hero__btns { display:flex; gap:12px; flex-wrap:wrap; margin-bottom:32px; }
.td-hero__pills { display:flex; gap:10px; flex-wrap:wrap; }
.td-hero-pill { display:flex; align-items:center; gap:7px; background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.15); padding:7px 14px; border-radius:50px; font-size:12.5px; color:rgba(255,255,255,.88); }
.td-hero-pill i { color:var(--color-secondary-light); }

/* Why grid */
.td-why-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.td-why-card { background:#fff; border:1px solid var(--color-border); border-radius:var(--radius-lg); padding:24px 20px; transition:var(--transition); }
.td-why-card:hover { box-shadow:var(--shadow-md); transform:translateY(-4px); border-color:transparent; }
.td-why-icon { width:52px; height:52px; border-radius:14px; display:flex; align-items:center; justify-content:center; font-size:20px; margin-bottom:14px; }
.td-why-icon--gold   { background:rgba(212,168,71,.12); color:var(--color-gold); }
.td-why-icon--green  { background:var(--color-secondary-pale); color:var(--color-secondary); }
.td-why-icon--red    { background:var(--color-primary-light); color:var(--color-primary); }
.td-why-icon--blue   { background:#e8f4fd; color:#2563eb; }
.td-why-title { font-size:14.5px; font-weight:800; color:var(--color-dark); margin-bottom:8px; }
.td-why-desc { font-size:13px; color:var(--color-gray); line-height:1.65; }

/* Careers layout */
.td-careers-layout { display:grid; grid-template-columns:1fr 280px; gap:28px; align-items:start; }
.td-filter-bar { display:grid; grid-template-columns:1fr 1fr 1fr auto; gap:12px; align-items:end; background:#fff; border:1px solid var(--color-border); border-radius:var(--radius-lg); padding:16px 18px; margin-bottom:16px; }
.td-filter-group label { display:block; font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.05em; color:var(--color-dark); margin-bottom:5px; }
.td-filter-select { width:100%; padding:9px 12px; border:1.5px solid var(--color-border); border-radius:var(--radius-sm); font-size:13px; font-family:var(--font-body); color:var(--color-text); background:#fff; outline:none; transition:border-color .2s; }
.td-filter-select:focus { border-color:var(--color-primary); }
.td-filter-submit { padding:9px 16px; height:38px; }
.td-jobs-meta { margin-bottom:16px; }
.td-jobs-count { font-size:13px; color:var(--color-gray); }
.td-jobs-count strong { color:var(--color-text); font-weight:700; }

/* Job cards */
.td-job-list { display:flex; flex-direction:column; gap:14px; }
.td-job-card { background:#fff; border:1px solid var(--color-border); border-radius:var(--radius-lg); padding:20px; transition:box-shadow .2s,transform .2s; }
.td-job-card:hover { box-shadow:var(--shadow-md); transform:translateY(-2px); border-color:transparent; }
.td-job-card--featured { border-color:rgba(196,18,48,.3); background:linear-gradient(135deg,rgba(253,232,236,.4) 0%,#fff 60%); }
.td-job-card__row { display:grid; grid-template-columns:40px 1fr auto; gap:14px; align-items:flex-start; margin-bottom:12px; }
.td-job-icon { width:40px; height:40px; border-radius:10px; display:flex; align-items:center; justify-content:center; font-size:16px; flex-shrink:0; }
.td-job-icon--red    { background:var(--color-primary-light); color:var(--color-primary); }
.td-job-icon--green  { background:var(--color-secondary-pale); color:var(--color-secondary); }
.td-job-icon--blue   { background:#e8f4fd; color:#2563eb; }
.td-job-icon--violet { background:#f3e8ff; color:#7c3aed; }
.td-job-tags { display:flex; gap:6px; flex-wrap:wrap; margin-bottom:6px; }
.td-jtag { display:inline-flex; align-items:center; gap:4px; padding:3px 9px; border-radius:50px; font-size:10px; font-weight:800; text-transform:uppercase; letter-spacing:.05em; }
.td-jtag--hot    { background:var(--color-primary); color:#fff; }
.td-jtag--red    { background:var(--color-primary-light); color:var(--color-primary); border:1px solid rgba(196,18,48,.2); }
.td-jtag--green  { background:var(--color-secondary-pale); color:var(--color-secondary); border:1px solid rgba(30,125,58,.2); }
.td-jtag--blue   { background:#e8f4fd; color:#2563eb; border:1px solid rgba(37,99,235,.2); }
.td-jtag--violet { background:#f3e8ff; color:#7c3aed; border:1px solid rgba(124,58,237,.2); }
.td-job-title { font-size:15px; font-weight:800; color:var(--color-dark); line-height:1.3; margin-bottom:3px; }
.td-job-title a { color:inherit; }
.td-job-title a:hover { color:var(--color-primary); }
.td-job-dept { font-size:12px; color:var(--color-gray); }
.td-apply-btn { padding:8px 14px; font-size:12px; white-space:nowrap; }
.td-job-metas { display:flex; gap:16px; flex-wrap:wrap; margin-bottom:10px; }
.td-jmeta { display:flex; align-items:center; gap:6px; font-size:12.5px; color:var(--color-gray); }
.td-jmeta i { color:var(--color-secondary-light); font-size:12px; }
.td-job-desc { font-size:13px; color:var(--color-gray); line-height:1.65; margin-bottom:12px; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.td-job-footer { display:flex; align-items:center; justify-content:space-between; border-top:1px solid var(--color-border); padding-top:10px; flex-wrap:wrap; gap:8px; }
.td-job-deadline { font-size:12px; color:var(--color-gray); display:flex; align-items:center; gap:5px; }
.td-job-deadline i { color:var(--color-secondary); }
.td-job-more { font-size:12.5px; font-weight:700; color:var(--color-primary); display:flex; align-items:center; gap:5px; text-decoration:none; transition:gap .2s; }
.td-job-more:hover { gap:9px; }

/* Tuyển dụng sidebar */
.td-sidebar { position:sticky; top:126px; display:flex; flex-direction:column; gap:18px; }
.td-sc { background:#fff; border:1px solid var(--color-border); border-radius:var(--radius-lg); overflow:hidden; }
.td-sc__head { display:flex; align-items:center; gap:10px; padding:12px 16px; border-bottom:1px solid var(--color-border); background:var(--color-bg); }
.td-sc__icon { width:28px; height:28px; border-radius:7px; display:flex; align-items:center; justify-content:center; font-size:12px; flex-shrink:0; }
.td-sc__icon--gold  { background:rgba(212,168,71,.12); color:var(--color-gold); }
.td-sc__icon--green { background:var(--color-secondary-pale); color:var(--color-secondary); }
.td-sc__title { font-size:11.5px; font-weight:800; color:var(--color-dark); text-transform:uppercase; letter-spacing:.5px; }
.td-sc__body { padding:14px 16px; }
.td-benefit-item { display:flex; align-items:center; gap:8px; padding:7px 0; border-bottom:1px solid var(--color-border); font-size:13px; color:var(--color-text); }
.td-benefit-item:last-child { border-bottom:none; padding-bottom:0; }
.td-benefit-item i { color:var(--color-secondary); width:16px; text-align:center; font-size:13px; flex-shrink:0; }
.td-process-step { display:grid; grid-template-columns:36px 1fr; gap:10px; align-items:flex-start; padding:10px 0; border-bottom:1px solid var(--color-border); }
.td-process-step:last-child { border-bottom:none; padding-bottom:0; }
.td-process-num { width:36px; height:36px; border-radius:50%; background:var(--color-primary-light); color:var(--color-primary); display:flex; align-items:center; justify-content:center; font-size:12px; font-weight:900; flex-shrink:0; }
.td-process-title { font-size:13px; font-weight:800; color:var(--color-dark); }
.td-process-desc { font-size:11.5px; color:var(--color-gray); margin-top:1px; }
.td-sc--cta { background:linear-gradient(135deg,var(--color-primary-dark),var(--color-primary)); border-color:transparent; }
.td-sc-cta__icon { width:50px; height:50px; background:rgba(255,255,255,.15); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:20px; color:#fff; margin:20px auto 12px; }
.td-sc-cta__title { font-size:15px; font-weight:900; color:#fff; margin-bottom:6px; text-align:center; }
.td-sc-cta__desc { font-size:12.5px; color:rgba(255,255,255,.8); margin-bottom:14px; line-height:1.6; text-align:center; padding:0 16px; }
.td-sc-cta__phone { display:flex; align-items:center; justify-content:center; gap:7px; font-size:13px; font-weight:700; color:rgba(255,255,255,.9); margin-top:10px; text-decoration:none; padding-bottom:14px; }

/* ── SINGLE JOB ── */
.job-header { background:linear-gradient(135deg,var(--color-dark) 0%,var(--color-dark2) 55%,#1a0d1e 100%); padding:44px 0 48px; }
.job-header__inner { position:relative; z-index:1; }
.job-header .breadcrumb,.job-header .breadcrumb__list { display:flex; align-items:center; gap:8px; list-style:none; flex-wrap:wrap; font-size:13px; color:rgba(255,255,255,.5); margin-bottom:14px; }
.job-header .breadcrumb__item:not(:last-child)::after { content:'›'; color:rgba(255,255,255,.3); margin-left:4px; }
.job-header .breadcrumb a { color:rgba(255,255,255,.7); }
.job-header .breadcrumb__current { color:rgba(255,255,255,.85); }
.job-header__badges { display:flex; gap:8px; margin-bottom:12px; flex-wrap:wrap; }
.job-header__badge { padding:4px 13px; border-radius:50px; font-size:10.5px; font-weight:700; text-transform:uppercase; letter-spacing:.06em; }
.job-header__badge--dept { background:rgba(30,125,58,.25); color:var(--color-secondary-light); border:1px solid rgba(106,191,69,.3); }
.job-header__badge--type { background:rgba(255,255,255,.12); color:rgba(255,255,255,.9); }
.job-header__badge--hot  { background:var(--color-primary); color:#fff; }
.job-header__title { font-size:clamp(20px,3vw,38px); font-weight:900; color:#fff; line-height:1.2; margin-bottom:16px; }
.job-header__meta { display:flex; align-items:center; gap:16px; flex-wrap:wrap; }
.job-header__meta-item { display:flex; align-items:center; gap:7px; font-size:13px; color:rgba(255,255,255,.75); }
.job-header__meta-item i { color:var(--color-secondary-light); font-size:12px; }

.job-wrapper { background:var(--color-bg); padding:40px 0 80px; }
.job-layout { display:grid; grid-template-columns:1fr 300px; gap:32px; align-items:start; }
.job-back-link { display:inline-flex; align-items:center; gap:7px; font-size:13px; font-weight:700; color:var(--color-gray); padding:10px 18px; border:1.5px solid var(--color-border); border-radius:var(--radius-sm); transition:all .2s; text-decoration:none; margin-bottom:20px; background:#fff; }
.job-back-link:hover { border-color:var(--color-primary); color:var(--color-primary); }

/* job-article – card wrapper */
.job-article { background:#fff; border:1px solid var(--color-border); border-radius:var(--radius-xl); overflow:hidden; box-shadow:var(--shadow-sm); }

/* Nội dung WP Editor trong trang tuyển dụng */
.job-article .entry-content {
  padding: 32px 36px;
  font-size: 15px;
  line-height: 1.8;
  color: var(--color-text);
}
/* H2 – dạng section heading có viền trái */
.job-article .entry-content h2 {
  font-size: 18px; font-weight: 800; color: var(--color-dark);
  margin: 28px 0 14px;
  padding: 11px 16px;
  background: var(--color-bg);
  border-left: 4px solid var(--color-primary);
  border-bottom: none;
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
}
.job-article .entry-content h2:first-child { margin-top: 0; }
.job-article .entry-content h3 {
  font-size: 16px; font-weight: 700; color: var(--color-dark);
  margin: 22px 0 10px;
  display: flex; align-items: center; gap: 8px;
}
.job-article .entry-content h3::before {
  content: ''; width: 4px; height: 16px;
  background: var(--color-secondary);
  border-radius: 2px; flex-shrink: 0;
}
/* ul: dùng icon check thay bullet */
.job-article .entry-content ul {
  list-style: none !important;
  padding-left: 0 !important;
  margin-bottom: 20px;
}
.job-article .entry-content ul li {
  list-style: none !important;
  padding-left: 0 !important;
  display: flex; align-items: flex-start; gap: 10px;
  margin-bottom: 8px; font-size: 14.5px; line-height: 1.72;
}
.job-article .entry-content ul li::before {
  content: '\f00c';
  font-family: 'Font Awesome 6 Free'; font-weight: 900;
  font-size: 11px; color: var(--color-secondary);
  margin-top: 5px; flex-shrink: 0;
}
/* ol: giữ số thứ tự */
.job-article .entry-content ol {
  list-style: decimal !important;
  padding-left: 22px !important;
  margin-bottom: 20px;
}
.job-article .entry-content ol li {
  list-style: decimal !important;
  padding-left: 4px;
  margin-bottom: 8px; font-size: 14.5px; line-height: 1.72;
}
.job-article .entry-content p { margin-bottom: 14px; font-size: 14.5px; }
.job-article .entry-content strong,
.job-article .entry-content b { font-weight: 700; color: var(--color-dark); }
.job-section { padding:24px 28px; border-bottom:1px solid var(--color-border); }
.job-section:last-child { border-bottom:none; }
.job-section__title { display:flex; align-items:center; gap:10px; font-size:17px; font-weight:900; color:var(--color-dark); margin-bottom:16px; }
.job-section__title i { width:32px; height:32px; border-radius:8px; background:var(--color-primary-light); color:var(--color-primary); display:flex; align-items:center; justify-content:center; font-size:14px; flex-shrink:0; }
.job-desc p { font-size:14.5px; color:var(--color-text); line-height:1.75; margin-bottom:10px; }
.job-list-items { list-style:none; display:flex; flex-direction:column; gap:8px; }
.jli { display:flex; align-items:flex-start; gap:8px; font-size:14px; color:var(--color-text); line-height:1.65; padding:6px 0; border-bottom:1px solid var(--color-bg); }
.jli::before { content:'✓'; color:var(--color-secondary); font-weight:900; font-size:13px; margin-top:2px; flex-shrink:0; }
.jli.check::before { display:none; }
.jli.check i { color:var(--color-secondary); flex-shrink:0; margin-top:3px; }
.jli.green::before { color:var(--color-secondary); }
.job-salary-grid { display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-bottom:14px; }
.job-salary-box { background:var(--color-bg); border:1px solid var(--color-border); border-radius:var(--radius-md); padding:16px; text-align:center; }
.job-salary-box__val { font-size:22px; font-weight:900; color:var(--color-primary); margin-bottom:4px; }
.job-salary-box__lbl { font-size:12px; color:var(--color-gray); }
.job-benefit-chips { display:flex; flex-wrap:wrap; gap:8px; }
.job-bc { display:inline-flex; align-items:center; gap:6px; padding:6px 12px; border-radius:50px; background:var(--color-bg); border:1px solid var(--color-border); font-size:12.5px; color:var(--color-text); font-weight:500; }
.job-bc i { color:var(--color-secondary); font-size:12px; }

/* Apply form */
.job-apply-form { padding:28px; background:var(--color-bg); border-top:2px solid var(--color-primary); }
.job-apply-form__title { display:flex; align-items:center; gap:10px; font-size:18px; font-weight:900; color:var(--color-dark); margin-bottom:6px; }
.job-apply-form__title i { color:var(--color-primary); }
.job-apply-form__intro { font-size:13.5px; color:var(--color-gray); margin-bottom:20px; }
.job-apply-form__intro strong { color:var(--color-primary); }
.job-form { display:flex; flex-direction:column; gap:16px; }
.job-form__row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.job-form__group { display:flex; flex-direction:column; gap:5px; }
.job-form__group label { font-size:12.5px; font-weight:700; color:var(--color-dark); }
.job-form__group label span { color:var(--color-primary); }
.job-form__control { width:100%; padding:10px 13px; border:1.5px solid var(--color-border); border-radius:var(--radius-sm); font-size:13.5px; font-family:var(--font-body); color:var(--color-text); background:#fff; outline:none; transition:border-color .2s; resize:vertical; }
.job-form__control:focus { border-color:var(--color-primary); box-shadow:0 0 0 3px rgba(196,18,48,.08); }
.job-file-upload { display:flex; align-items:center; gap:12px; padding:14px 16px; border:1.5px dashed var(--color-border); border-radius:var(--radius-sm); cursor:pointer; background:#fff; transition:border-color .2s; }
.job-file-upload:hover { border-color:var(--color-primary); }
.job-file-upload i { font-size:22px; color:var(--color-secondary); flex-shrink:0; }
.job-file-label { font-size:13px; color:var(--color-gray); }
.job-file-name { font-size:12px; color:var(--color-primary); margin-top:2px; font-weight:600; }
.job-form__submit { align-self:flex-start; padding:12px 28px; }
.job-form__privacy { font-size:12px; color:var(--color-gray); display:flex; align-items:center; gap:6px; }
.job-form__privacy i { color:var(--color-secondary); }

/* Job sidebar */
.job-sidebar { position:sticky; top:126px; display:flex; flex-direction:column; gap:18px; }
.job-sc { background:#fff; border:1px solid var(--color-border); border-radius:var(--radius-lg); overflow:hidden; }
.job-sc__title { display:flex; align-items:center; gap:8px; font-size:12.5px; font-weight:800; color:var(--color-dark); padding:13px 16px; border-bottom:1px solid var(--color-border); background:var(--color-bg); text-transform:uppercase; letter-spacing:.4px; }
.job-sc__title i { color:var(--color-primary); }
.job-sc-row { display:flex; align-items:flex-start; justify-content:space-between; gap:10px; padding:10px 16px; border-bottom:1px solid var(--color-border); font-size:13px; }
.job-sc-row:last-of-type { border-bottom:none; }
.job-sc-row__label { display:flex; align-items:center; gap:6px; color:var(--color-gray); white-space:nowrap; }
.job-sc-row__label i { color:var(--color-secondary); font-size:12px; width:14px; text-align:center; }
.job-sc-row__val { font-weight:700; color:var(--color-dark); text-align:right; }
.job-sc-related { display:grid; grid-template-columns:36px 1fr; gap:10px; padding:12px 16px; border-bottom:1px solid var(--color-border); text-decoration:none; transition:background .18s; }
.job-sc-related:last-of-type { border-bottom:none; }
.job-sc-related:hover { background:var(--color-bg); }
.job-sc-related__icon { width:36px; height:36px; border-radius:9px; background:var(--color-primary-light); color:var(--color-primary); display:flex; align-items:center; justify-content:center; font-size:14px; flex-shrink:0; }
.job-sc-related__title { font-size:13px; font-weight:700; color:var(--color-dark); line-height:1.3; }
.job-sc-related:hover .job-sc-related__title { color:var(--color-primary); }
.job-sc-related__meta { font-size:11.5px; color:var(--color-gray); margin-top:2px; }
.job-sc-all-link { display:flex; align-items:center; justify-content:center; gap:6px; padding:12px; font-size:12.5px; font-weight:700; color:var(--color-primary); border-top:1px solid var(--color-border); text-decoration:none; transition:gap .2s; }
.job-sc-all-link:hover { gap:10px; }
.job-sc--cta { background:linear-gradient(135deg,var(--color-dark),var(--color-dark2)); border-color:transparent; }
.job-sc-cta__icon { width:48px; height:48px; background:rgba(255,255,255,.1); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:18px; color:var(--color-secondary-light); margin:18px auto 10px; }
.job-sc-cta__title { font-size:15px; font-weight:900; color:#fff; text-align:center; margin-bottom:6px; }
.job-sc-cta__desc { font-size:12.5px; color:rgba(255,255,255,.7); text-align:center; margin-bottom:14px; line-height:1.6; padding:0 16px; }
.job-sc-cta__btn { display:flex; align-items:center; justify-content:center; gap:7px; font-size:13px; font-weight:700; color:var(--color-secondary-light); text-decoration:none; padding:8px 16px; }
.job-sc-cta__btn:hover { color:#fff; }
.job-sc-cta__btn:last-child { padding-bottom:18px; }

/* ============================================================
   RESPONSIVE – Du An, Tuyển Dụng
   ============================================================ */
@media(max-width:1024px) {
    .da-project-grid { grid-template-columns:repeat(2,1fr); }
    .da-layout,.project-layout,.td-careers-layout,.job-layout { grid-template-columns:1fr; }
    .da-sidebar,.project-sidebar,.td-sidebar,.job-sidebar { position:static; }
    .da-filter-form { grid-template-columns:1fr 1fr; }
    .da-filter-submit { grid-column:1/-1; width:100%; justify-content:center; }
    .td-filter-bar { grid-template-columns:1fr 1fr; }
    .td-filter-submit { grid-column:1/-1; width:100%; justify-content:center; }
    .td-why-grid { grid-template-columns:repeat(2,1fr); }
    .project-specs-bar { grid-template-columns:repeat(2,1fr); }
    .project-spec:nth-child(2) { border-right:none; }
}
@media(max-width:768px) {
    .du-an-hero__stats { gap:20px; }
    .da-project-grid { grid-template-columns:1fr; }
    .td-why-grid { grid-template-columns:1fr 1fr; }
    .job-form__row { grid-template-columns:1fr; }
    .job-salary-grid { grid-template-columns:1fr; }
    .td-job-card__row { grid-template-columns:36px 1fr; }
    .td-job-action { grid-column:1/-1; display:flex; }
    .td-apply-btn { width:100%; justify-content:center; }
}
@media(max-width:580px) {
    .da-filter-form { grid-template-columns:1fr; }
    .td-filter-bar { grid-template-columns:1fr; }
    .td-why-grid { grid-template-columns:1fr; }
    .project-specs-bar { grid-template-columns:1fr 1fr; }
    .cta-band__inner { flex-direction:column; text-align:center; }
    .cta-band__actions { justify-content:center; }
}

/* ============================================================
   COMMENTS
   ============================================================ */
.comments-section {
    background: #fff;
    border-radius: var(--radius-xl);
    border: 1px solid var(--color-border);
    overflow: hidden;
    margin-top: 24px;
}
.comments-section__head {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 14px 28px;
    border-bottom: 1px solid var(--color-border);
    background: var(--color-bg);
}
.comments-section__icon {
    width: 32px; height: 32px;
    border-radius: 9px;
    background: var(--color-primary-light);
    color: var(--color-primary);
    display: flex; align-items: center; justify-content: center;
    font-size: 13px;
}
.comments-section__title { font-size: 14px; font-weight: 800; color: var(--color-dark); }
.comments-section__count {
    font-size: 11.5px; font-weight: 700;
    color: var(--color-gray-light);
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    padding: 2px 8px; border-radius: 50px;
}
.comments-section__body { padding: 24px 28px; }

/* Comment list */
.comment-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; }
.comment-item { padding: 18px 0; border-bottom: 1px solid var(--color-border); }
.comment-item:last-child { border-bottom: none; padding-bottom: 0; }
.comment-item__head { display: flex; align-items: center; gap: 12px; margin-bottom: 10px; }
.comment-item__avatar { width: 38px; height: 38px; border-radius: 50%; object-fit: cover; border: 2px solid var(--color-secondary-pale); flex-shrink: 0; }
.comment-item__name { font-size: 14px; font-weight: 700; color: var(--color-dark); }
.comment-author-badge {
    font-size: 10.5px; color: var(--color-secondary); font-weight: 700;
    background: var(--color-secondary-pale); padding: 2px 7px;
    border-radius: 50px; margin-left: 6px;
}
.comment-item__date { font-size: 11px; color: var(--color-gray-light); margin-top: 1px; }
.comment-item__text { font-size: 14px; color: var(--color-gray); line-height: 1.75; }
.comment-item__actions { display: flex; gap: 14px; margin-top: 10px; }
.comment-item__action { font-size: 12px; font-weight: 600; color: var(--color-gray-light); display: flex; align-items: center; gap: 5px; transition: color .18s; background: none; border: none; cursor: pointer; padding: 0; font-family: var(--font-body); }
.comment-item__action:hover { color: var(--color-primary); }
.comment-awaiting { font-size: 13px; color: var(--color-gray); font-style: italic; }

/* Nested comments */
.children { list-style: none; padding: 0; margin: 0; }
.children .comment-item { padding: 14px 0 14px 48px; border-bottom: 1px solid var(--color-border); position: relative; }
.children .comment-item::before {
    content: ''; position: absolute;
    left: 18px; top: 0; bottom: 0;
    width: 2px; background: var(--color-primary-light); border-radius: 2px;
}
.children .comment-item:last-child { border-bottom: none; }

/* Comment form */
.comment-form { margin-top: 24px; padding-top: 24px; border-top: 1px solid var(--color-border); }
.comment-form .comment-form__title,
.comment-form .comment-reply-title {
    font-size: 15px; font-weight: 800; color: var(--color-dark);
    margin-bottom: 18px; display: flex; align-items: center; gap: 8px;
}
.comment-form .comment-reply-title i { color: var(--color-secondary); }
.comment-form__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 12px; }
.cf-field { display: flex; flex-direction: column; gap: 6px; margin-bottom: 12px; }
.cf-field label { font-size: 13px; font-weight: 700; color: var(--color-dark); }
.cf-field input,
.cf-field textarea {
    padding: 10px 14px;
    border: 1.5px solid var(--color-border);
    border-radius: var(--radius-sm);
    font-size: 14px; font-family: var(--font-body);
    color: var(--color-text); background: #fff;
    outline: none; transition: border-color .2s;
}
.cf-field input:focus, .cf-field textarea:focus { border-color: var(--color-primary); }
.cf-field textarea { min-height: 120px; resize: vertical; }
.cf-submit { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
.cf-policy { font-size: 12px; color: var(--color-gray-light); line-height: 1.6; }
.cf-policy a { color: var(--color-primary); }
.comments-protected { padding: 20px; font-style: italic; color: var(--color-gray); }
.no-comments { padding: 20px 0; font-size: 14px; color: var(--color-gray); }

/* ============================================================
   SEARCH RESULTS
   ============================================================ */
.search-highlight { background: rgba(196,18,48,.12); color: var(--color-primary); border-radius: 3px; padding: 0 2px; font-weight: 700; }

@media(max-width:700px) {
    .comment-form__grid { grid-template-columns: 1fr; }
    .comments-section__body { padding: 18px 20px; }
    .children .comment-item { padding-left: 28px; }
    .children .comment-item::before { left: 10px; }
}

/* ══════════════════════════════════════════════════════════
   SIDEBAR WIDGETS – Trang tin tức (page-tin-tuc.php)
   ══════════════════════════════════════════════════════════ */

/* Widget search */
.w-search { display:flex; gap:0; border:1.5px solid var(--color-border); border-radius:var(--radius-sm); overflow:hidden; }
.w-search__input { flex:1; border:none; outline:none; padding:9px 14px; font-size:13px; font-family:var(--font-body); background:#fff; color:var(--color-text); }
.w-search__btn { background:var(--color-primary); color:#fff; border:none; padding:9px 14px; cursor:pointer; transition:background .2s; font-size:14px; }
.w-search__btn:hover { background:var(--color-primary-dark); }

/* Widget projects (sidebar) */
.w-projects { display:flex; flex-direction:column; gap:0; }
.w-project { display:grid; grid-template-columns:64px 1fr; gap:11px; padding:12px 0; border-bottom:1px solid var(--color-border); }
.w-project:last-child { border-bottom:none; padding-bottom:0; }
.w-project__thumb img { width:64px; height:50px; object-fit:cover; border-radius:var(--radius-sm); }
.w-project__name { font-size:13px; font-weight:600; line-height:1.35; margin-bottom:3px; }
.w-project__name a { color:var(--color-text); text-decoration:none; transition:color .2s; }
.w-project__name a:hover { color:var(--color-primary); }
.w-project__price { font-size:12px; font-weight:700; color:var(--color-primary); margin-bottom:2px; }
.w-project__loc { font-size:11px; color:var(--color-gray); display:flex; align-items:center; gap:4px; }
.w-project__loc i { color:var(--color-secondary); font-size:10px; }
.w-view-all { display:flex; align-items:center; gap:7px; margin-top:14px; padding:9px 16px; background:var(--color-bg); border:1.5px solid var(--color-border); border-radius:var(--radius-sm); font-size:12.5px; font-weight:700; color:var(--color-text); text-decoration:none; transition:all .2s; justify-content:center; }
.w-view-all:hover { background:var(--color-primary-light); border-color:var(--color-primary); color:var(--color-primary); }
.w-view-all i { font-size:11px; }

/* Widget tags */
.w-tags { display:flex; flex-wrap:wrap; gap:7px; }
.w-tag { display:inline-block; padding:5px 12px; background:var(--color-bg); border:1.5px solid var(--color-border); border-radius:50px; font-size:11.5px; font-weight:600; color:var(--color-gray); cursor:pointer; transition:all .2s; text-decoration:none; }
.w-tag:hover, .w-tag.is-active { background:var(--color-primary-light); border-color:rgba(196,18,48,.25); color:var(--color-primary); }

/* Widget newsletter */
.widget--newsletter { background:linear-gradient(135deg,var(--color-dark),var(--color-dark2)); }
.widget--newsletter .widget__head { border-bottom-color:rgba(255,255,255,.1); }
.widget--newsletter .widget__head-icon { background:rgba(196,18,48,.25); color:var(--color-primary-light); }
.widget--newsletter .widget__title { color:#fff; }
.w-nl__desc { font-size:13px; color:rgba(255,255,255,.6); margin-bottom:14px; line-height:1.55; }
.w-nl__input { width:100%; border:1.5px solid rgba(255,255,255,.15); background:rgba(255,255,255,.08); border-radius:var(--radius-sm); padding:10px 14px; font-size:13px; color:#fff; font-family:var(--font-body); outline:none; margin-bottom:10px; transition:border-color .2s; }
.w-nl__input::placeholder { color:rgba(255,255,255,.35); }
.w-nl__input:focus { border-color:rgba(196,18,48,.5); }
.w-nl__btn { width:100%; background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark)); color:#fff; border:none; border-radius:var(--radius-sm); padding:11px; font-size:13px; font-weight:700; cursor:pointer; font-family:var(--font-body); display:flex; align-items:center; justify-content:center; gap:7px; transition:transform .2s,box-shadow .2s; }
.w-nl__btn:hover { transform:translateY(-1px); box-shadow:0 8px 20px rgba(196,18,48,.35); }

/* page-hero cho trang tin tức (class không có __bg/__stripe) */
.page-hero:not(:has(.page-hero__bg)) {
    background:linear-gradient(135deg,var(--color-dark) 0%,var(--color-dark2) 100%);
    padding:60px 0 50px;
    position:relative;
    overflow:hidden;
}
.page-hero:not(:has(.page-hero__bg))::before {
    content:'';position:absolute;top:-40px;right:-60px;width:400px;height:400px;
    background:radial-gradient(circle,rgba(196,18,48,.12) 0%,transparent 70%);
    border-radius:50%;
}
.page-hero__title { font-size:clamp(26px,3.5vw,40px); font-weight:900; color:#fff; line-height:1.2; margin:10px 0 16px; }
.page-hero__title em { color:var(--color-secondary-light); font-style:normal; }
.page-hero__meta { display:flex; align-items:center; gap:20px; flex-wrap:wrap; }
.page-hero__meta-item { display:flex; align-items:center; gap:7px; font-size:13px; color:rgba(255,255,255,.6); }
.page-hero__meta-item i { color:var(--color-secondary-light); font-size:12px; }

/* post-card badge màu blue */
.post-card__badge--blue { background:var(--color-primary-light); color:#0891b2; }
@media (max-width:480px) {
    .page-hero__meta { gap:12px; }
    .page-hero__meta-item { font-size:12px; }
}

/* ═══════════════════════════════════════════════════════
   PAGE HERO SIMPLE – dùng đồng nhất cho tất cả các trang
   Copy từ ftnland-list-news.html
   ═══════════════════════════════════════════════════════ */
.page-hero-simple {
    background: var(--color-dark);
    padding: 44px 0 48px;
    position: relative;
    overflow: hidden;
}
.page-hero-simple::before {
    content: '';
    position: absolute;
    inset: 0;
    background: url('https://images.unsplash.com/photo-1560518883-ce09059eeffa?w=1400&q=50') center/cover no-repeat;
    opacity: .1;
}
.page-hero-simple::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(110deg, rgba(15,25,35,.96) 50%, rgba(30,125,58,.18));
}
.page-hero-simple .container { position: relative; z-index: 1; }

/* Breadcrumb bên trong hero-simple */
.page-hero-simple .breadcrumb {
    display: flex; align-items: center; gap: 6px; flex-wrap: wrap;
    list-style: none; margin: 0 0 14px; padding: 0;
    font-size: 12px; font-weight: 500; color: rgba(255,255,255,.45);
}
.page-hero-simple .breadcrumb__list { display:flex; align-items:center; gap:6px; flex-wrap:wrap; list-style:none; margin:0; padding:0; }
.page-hero-simple .breadcrumb__item { display:flex; align-items:center; gap:6px; }
.page-hero-simple .breadcrumb a { color: rgba(255,255,255,.5); text-decoration: none; transition: color .18s; }
.page-hero-simple .breadcrumb a:hover { color: var(--color-secondary-light); }
.page-hero-simple .breadcrumb__sep { color: rgba(255,255,255,.22); font-size: 11px; }
.page-hero-simple .breadcrumb__item--current { color: rgba(255,255,255,.6); }

/* Title */
.page-hero-simple__title {
    font-size: clamp(26px, 3.5vw, 44px);
    font-weight: 900;
    color: #fff;
    line-height: 1.15;
    letter-spacing: -.4px;
    margin: 0 0 10px;
}
.page-hero-simple__title em { font-style: normal; color: var(--color-secondary-light); }

/* Meta / mô tả ngắn */
.page-hero-simple__meta {
    display: flex;
    align-items: center;
    gap: 22px;
    flex-wrap: wrap;
    font-size: 13px;
    color: rgba(255,255,255,.55);
}
.page-hero-simple__meta-item {
    display: flex; align-items: center; gap: 6px;
}
.page-hero-simple__meta-item i { color: var(--color-secondary-light); font-size: 11px; }

@media (max-width: 580px) {
    .page-hero-simple { padding: 32px 0 36px; }
    .page-hero-simple__title { font-size: 26px; }
    .page-hero-simple__meta { gap: 12px; font-size: 12px; }
}

/* ═══════════════════════════════════════════════
   JOB CARD – archive-job.php (từ ftnland-tuyen-dung.html)
   ═══════════════════════════════════════════════ */
.filter-bar{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:22px;margin-bottom:24px;display:flex;gap:14px;flex-wrap:wrap;align-items:flex-end}
.filter-group{flex:1;min-width:140px}
.filter-group label{display:block;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:var(--color-gray);margin-bottom:7px}
.filter-select{width:100%;padding:10px 14px;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);font-size:13.5px;font-family:var(--font-body);color:var(--color-text);background:#fff;outline:none;transition:border-color .2s}
.filter-select:focus{border-color:var(--color-primary)}
.filter-btn{padding:10px 22px;height:42px;align-self:flex-end}
.job-list{display:flex;flex-direction:column;gap:16px}
.job-card{background:#fff;border:1.5px solid var(--color-border);border-radius:var(--radius-xl);padding:22px 26px;transition:border-color .25s,box-shadow .25s,transform .25s;position:relative;overflow:hidden}
.job-card:hover{border-color:rgba(196,18,48,.3);box-shadow:var(--shadow-md);transform:translateY(-3px)}
.job-card--featured{border-top-color:var(--color-primary);border-top-width:3px}
.job-card--featured::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--color-primary),var(--color-secondary))}
.job-card__row{display:flex;align-items:flex-start;gap:16px;margin-bottom:14px}
.job-card__icon{width:52px;height:52px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.job-card__icon--red{background:var(--color-primary-light);color:var(--color-primary)}
.job-card__icon--green{background:var(--color-secondary-pale);color:var(--color-secondary)}
.job-card__icon--gold{background:#fef9ec;color:var(--color-gold)}
.job-card__icon--blue{background:#e8f4fd;color:#2563eb}
.job-card__info{flex:1;min-width:0}
.job-card__tags{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:5px}
.job-tag{display:inline-flex;align-items:center;padding:2px 9px;border-radius:12px;font-size:10.5px;font-weight:700;letter-spacing:.2px}
.tag--hot{background:rgba(196,18,48,.1);color:var(--color-primary)}
.tag--full{background:rgba(30,125,58,.1);color:var(--color-secondary)}
.tag--dept{background:var(--color-bg);color:var(--color-gray);border:1px solid var(--color-border)}
.tag--mgr{background:#fef9ec;color:var(--color-gold)}
.job-card__title{font-size:17px;font-weight:800;color:var(--color-dark);margin-bottom:3px;line-height:1.3}
.job-card__title a{color:inherit;text-decoration:none}
.job-card__title a:hover{color:var(--color-primary)}
.job-card__dept{font-size:12.5px;color:var(--color-gray)}
.job-card__action{flex-shrink:0}
.job-card__metas{display:flex;gap:18px;flex-wrap:wrap;margin-bottom:12px}
.job-meta{display:flex;align-items:center;gap:6px;font-size:12.5px;color:var(--color-gray)}
.job-meta i{color:var(--color-secondary);font-size:11px}
.job-card__desc{font-size:13.5px;color:var(--color-gray);line-height:1.65;margin-bottom:16px}
.job-card__footer{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;border-top:1px solid var(--color-border);padding-top:14px}
.job-card__deadline{font-size:11.5px;color:var(--color-gray-light)}
.job-card__deadline i{color:var(--color-gold);margin-right:4px}
.job-card__more{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:700;color:var(--color-primary);text-decoration:none;transition:gap .2s}
.job-card__more:hover{gap:10px}
@media(max-width:680px){.job-card__row{flex-wrap:wrap}.job-card__action{width:100%}.job-card__action .btn{width:100%;justify-content:center}.filter-bar{flex-direction:column}.filter-group{min-width:100%}}

/* ═══════════════════════════════════════════════════════════════
   FTNLAND WIDGET SYSTEM
   ═══════════════════════════════════════════════════════════════ */

/* ── Base card – khớp với style người dùng đã định nghĩa ─── */
.widget,
.ftnland-widget {
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 0;
  margin-bottom: 20px;
  overflow: hidden;
}
.widget:last-child,
.ftnland-widget:last-child { margin-bottom: 0; }

/* ── Tiêu đề widget ───────────────────────────────────────── */
.widget-title {
  font-size: 15px;
  font-weight: 800;
  color: var(--color-dark);
  margin-bottom: 16px;
  padding-bottom: 0;
  border-bottom: 0 solid var(--color-primary);
  text-transform: uppercase;
  letter-spacing: .04em;
}

/* ── Widget header wrapper (before_title / after_title) ───── */
/* Thêm padding + đường kẻ dưới, không có background màu xám */
.widget-head {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 16px 18px 12px;
  border-bottom: 1px solid var(--color-border);
}

/* Icon trước tiêu đề widget */
.widget-head .widget-title-icon,
.widget-head > i[class*="fa"] {
  width: 28px; height: 28px;
  border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  font-size: 12px;
  flex-shrink: 0;
  /* Màu mặc định – override theo class widget bên dưới */
  background: rgba(196,18,48,.08);
  color: var(--color-primary);
}
/* Màu icon theo loại widget */
.ftn-widget-project-filter  .widget-head > i { background: rgba(196,18,48,.08);   color: var(--color-primary); }
.ftn-widget-featured-projects .widget-head > i { background: rgba(212,160,23,.12); color: #c8930a; }
.ftn-widget-recent-posts    .widget-head > i { background: rgba(37,99,235,.1);   color: #2563eb; }
.ftn-widget-job-filter      .widget-head > i { background: rgba(124,58,237,.1);  color: #7c3aed; }
/* sidebar.php fallback */
.widget .widget-head > i { background: rgba(196,18,48,.08); color: var(--color-primary); }

/* Ẩn hicon cũ nếu còn sót */
.widget-hicon { display: none; }

/* ── Padding nội dung bên trong ───────────────────────────── */
.ftnland-widget > *:not(.widget-head) { padding: 14px 18px; }

/* ── City list ────────────────────────────────────────────── */
.ftn-widget__city-list {
  display: flex; flex-direction: column; gap: 2px;
  padding: 8px 10px 10px !important;
}
.ftn-widget__city-row {
  display: flex; align-items: center; gap: 10px;
  padding: 9px 10px; border-radius: 8px;
  font-size: 13px; color: var(--color-text);
  text-decoration: none; transition: background .15s;
}
.ftn-widget__city-row:hover { background: #f3f4f6; }
.ftn-widget__city-row.is-active {
  background: rgba(196,18,48,.06);
  color: var(--color-primary);
  font-weight: 700;
}
.city-row__icon { width: 22px; text-align: center; font-size: 12px; color: var(--color-gray); flex-shrink: 0; }
.ftn-widget__city-row.is-active .city-row__icon { color: var(--color-primary); }
.city-row__label { flex: 1; }
.city-row__check { font-size: 10px; color: var(--color-primary); }

/* ── Chips (loại BĐS, tuyển dụng) ────────────────────────── */
.ftn-widget__type-chips,
.ftn-widget__chips { display: flex; flex-wrap: wrap; gap: 6px; padding: 10px 14px 14px !important; }
.ftn-widget__chip {
  display: inline-flex; align-items: center;
  padding: 5px 12px; border-radius: 20px;
  font-size: 12px; font-weight: 600;
  background: #f3f4f6; color: var(--color-text);
  text-decoration: none; border: 1.5px solid transparent;
  transition: all .15s;
}
.ftn-widget__chip:hover { background: #e5e7eb; }
.ftn-widget__chip.is-active {
  background: rgba(196,18,48,.08);
  color: var(--color-primary);
  border-color: rgba(196,18,48,.25);
}

/* ── Danh sách dự án / bài viết compact ──────────────────── */
.ftn-widget__feat-list,
.ftn-widget__posts-list { display: flex; flex-direction: column; gap: 4px; padding: 10px 10px 12px !important; }

.ftn-widget__feat-item,
.ftn-widget__post-item {
  display: flex; gap: 10px; text-decoration: none;
  padding: 8px; border-radius: 8px;
  transition: background .15s;
}
.ftn-widget__feat-item:hover,
.ftn-widget__post-item:hover { background: #f8f9fa; }

.feat-item__thumb,
.post-item__thumb {
  width: 68px; height: 52px; border-radius: 6px;
  overflow: hidden; flex-shrink: 0; background: #f3f4f6;
}
.feat-item__thumb img,
.post-item__thumb img { width: 100%; height: 100%; object-fit: cover; }

.feat-item__body,
.post-item__body { flex: 1; min-width: 0; }

.feat-item__name,
.post-item__title {
  font-size: 13px; font-weight: 700; color: var(--color-dark);
  line-height: 1.4; margin: 0 0 4px;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.ftn-widget__feat-item:hover .feat-item__name,
.ftn-widget__post-item:hover .post-item__title { color: var(--color-primary); }
.feat-item__price { font-size: 12px; font-weight: 700; color: var(--color-primary); margin: 0 0 2px; }
.feat-item__loc,
.post-item__date {
  font-size: 11px; color: var(--color-gray); margin: 0;
  display: flex; align-items: center; gap: 4px;
}

/* ── CTA Hotline ──────────────────────────────────────────── */
.ftn-widget__cta {
  text-align: center;
  padding: 24px 18px !important;
  background: linear-gradient(135deg, var(--color-dark) 0%, #1a2d3f 100%);
}
.ftn-widget-cta-hotline { border-color: transparent; }
.cta__icon {
  width: 52px; height: 52px; border-radius: 50%;
  margin: 0 auto 12px;
  background: rgba(106,191,69,.15);
  display: flex; align-items: center; justify-content: center;
  font-size: 22px; color: var(--color-secondary-light, #6abf45);
}
.cta__title { font-size: 15px; font-weight: 800; color: #fff; margin: 0 0 8px; }
.cta__desc  { font-size: 13px; color: rgba(255,255,255,.65); margin: 0 0 16px; line-height: 1.6; }
.cta__btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 10px 20px; border-radius: 30px;
  background: linear-gradient(90deg, var(--color-secondary, #1e7d3a), var(--color-secondary-light, #6abf45));
  color: #fff; font-size: 13px; font-weight: 700; text-decoration: none;
  transition: opacity .2s, transform .2s;
}
.cta__btn:hover { opacity: .9; transform: translateY(-1px); }

/* ── Nhãn section trong job filter ───────────────────────── */
.ftn-widget__filter-label {
  font-size: 10.5px; font-weight: 700; text-transform: uppercase; letter-spacing: .8px;
  color: var(--color-gray); margin: 12px 0 6px;
  display: flex; align-items: center; gap: 6px;
}
.ftn-widget__filter-label:first-child { margin-top: 0; }
.ftn-widget__filter-label i { color: var(--color-primary); font-size: 11px; }

/* ── Empty state ──────────────────────────────────────────── */
.ftn-widget__empty { font-size: 13px; color: var(--color-gray); text-align: center; padding: 12px 0; }

/* ── Jobs layout (2 cột giống projects-layout) ────────────── */
.jobs-layout {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 30px;
  align-items: start;
}
@media (max-width: 1024px) { .jobs-layout { grid-template-columns: 1fr; } }


/* ═══════════════════════════════════════════════════════════════
   HOME SECTIONS – Featured / Values / Testimonials / Contact
   ═══════════════════════════════════════════════════════════════ */

/* ── FEATURED PROJECTS ── */
.featured-grid {
      display: grid;
      grid-template-columns: repeat(2,1fr);
      gap: 26px;
    }
    .featured-card {
      border-radius: 18px;
      overflow: hidden;
      position: relative;
      height: 305px;
      cursor: pointer;
    }
    .featured-card img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s; }
    .featured-card:hover img { transform: scale(1.05); }
    .featured-card__overlay {
      position: absolute;
      inset: 0;
      background: linear-gradient(to top, rgba(10,18,28,.88) 35%, transparent 70%);
    }
    .featured-card__body {
      position: absolute;
      bottom: 0; left: 0; right: 0;
      padding: 22px 24px;
      color: #fff;
    }
    .featured-card__badge {
      display: inline-flex;
      align-items: center;
      gap: 5px;
      font-size: 9.5px; font-weight: 800;
      letter-spacing: 1px;
      text-transform: uppercase;
      padding: 4px 12px;
      border-radius: 50px;
      margin-bottom: 10px;
    }
    .featured-card__badge--red { background: var(--color-primary); }
    .featured-card__badge--gold { background: var(--color-gold); color: #1a1a1a; }
    .featured-card__title { font-size: 18px; font-weight: 800; line-height: 1.3; margin-bottom: 6px; }
    .featured-card__price { font-size: 15px; font-weight: 800; color: var(--color-secondary-light); }
    .featured-card__buttons { display: flex; gap: 10px; margin-top: 12px; }
    .featured-card__btn {
      padding: 7px 18px;
      font-size: 12px; font-weight: 700;
      border-radius: 7px; border: none;
      cursor: pointer; font-family: var(--font-body);
      text-decoration: none;
      transition: opacity .2s, transform .2s;
    }
    .featured-card__btn--red { background: var(--color-primary); color: #fff; }
    .featured-card__btn--outline { background: rgba(255,255,255,.12); color: #fff; border: 1px solid rgba(255,255,255,.4); backdrop-filter: blur(4px); }
    .featured-card__btn:hover { opacity: .88; transform: translateY(-1px); }

/* ── VALUES BAND (homepage – dark green bg) ── */
#values-band {
  background: linear-gradient(135deg, var(--color-secondary), #135228);
  padding: 76px var(--container-pad);
  position: relative;
  overflow: hidden;
}
#values-band::before {
  content: '';
  position: absolute;
  top: -60px; right: -60px;
  width: 320px; height: 320px;
  border-radius: 50%;
  background: rgba(106,191,69,.1);
}
#values-band::after {
  content: '';
  position: absolute;
  bottom: -80px; left: 10%;
  width: 260px; height: 260px;
  border-radius: 50%;
  background: rgba(255,255,255,.04);
}
#values-band .values-band__inner {
  max-width: var(--container-width);
  margin: auto;
  position: relative;
  z-index: 1;
}
#values-band .values-band__header { text-align: center; margin-bottom: 50px; }
#values-band .values-grid {
  display: grid;
  grid-template-columns: repeat(4,1fr);
  gap: 22px;
}
#values-band .value-card {
  background: rgba(255,255,255,.1);
  border: 1px solid rgba(255,255,255,.15);
  border-radius: var(--radius-lg);
  padding: 30px 22px;
  text-align: center;
  backdrop-filter: blur(4px);
  transition: background .3s, transform .3s;
}
#values-band .value-card:hover { background: rgba(255,255,255,.18); transform: translateY(-6px); }
#values-band .value-card__icon {
  width: 60px; height: 60px;
  border-radius: 16px;
  background: rgba(255,255,255,.12);
  display: flex; align-items: center; justify-content: center;
  font-size: 26px;
  color: var(--color-secondary-light);
  margin: 0 auto 18px;
}
#values-band .value-card__title { font-size: 14.5px; font-weight: 800; color: #fff; margin-bottom: 10px; }
#values-band .value-card__description { font-size: 12.5px; color: rgba(255,255,255,.72); line-height: 1.7; }

/* ── TESTIMONIALS ── */
.testimonials__header { text-align: center; margin-bottom: 50px; }
    .testimonials-grid {
      display: grid;
      grid-template-columns: repeat(2,1fr);
      gap: 24px;
    }
    .testimonial-card {
      background: #fff;
      border: 1.5px solid var(--color-border);
      border-radius: 18px;
      padding: 30px;
      transition: var(--transition);
      position: relative;
      overflow: hidden;
    }
    .testimonial-card::before {
      content: '"';
      position: absolute;
      top: -10px; right: 20px;
      font-size: 110px; font-weight: 900;
      color: var(--color-secondary-pale);
      line-height: 1;
      font-family: Georgia, serif;
      pointer-events: none;
    }
    .testimonial-card:hover { border-color: var(--color-secondary); box-shadow: 0 10px 36px rgba(30,125,58,.1); }
    .testimonial-card__stars { color: var(--color-gold); font-size: 13px; margin-bottom: 14px; letter-spacing: 3px; }
    .testimonial-card__text { font-size: 13.5px; color: var(--color-gray); line-height: 1.8; font-style: italic; margin-bottom: 20px; position: relative; z-index: 1; }
    .testimonial-card__author { display: flex; align-items: center; gap: 14px; }
    .testimonial-card__avatar { width: 48px; height: 48px; border-radius: 50%; object-fit: cover; border: 2.5px solid var(--color-secondary-pale); }
    .testimonial-card__name { font-size: 14px; font-weight: 800; color: var(--color-dark); }
    .testimonial-card__role { font-size: 11.5px; color: var(--color-gray-light); margin-top: 1px; }

/* ── PARTNERS BAR ── */
#partners-bar {
      background: #fff;
      padding: 36px var(--container-pad);
      border-top: 1px solid var(--color-border);
      border-bottom: 1px solid var(--color-border);
    }
    .partners-bar__inner {
      max-width: 1100px;
      margin: auto;
      display: flex;
      align-items: center;
      justify-content: space-around;
      gap: 28px;
      flex-wrap: wrap;
      opacity: .4;
      filter: grayscale(1);
    }
    .partner-logo { font-size: 19px; font-weight: 900; letter-spacing: -1px; color: #334155; }

/* ── CONTACT SECTION ── */
#contact {
      background: var(--color-dark2);
      padding: 82px var(--container-pad);
    }
    .contact-grid {
      max-width: 1100px;
      margin: auto;
      display: grid;
      grid-template-columns: 1fr 1.1fr;
      gap: 72px;
      align-items: start;
    }
    .contact-info__title { font-size: 32px; font-weight: 900; color: #fff; line-height: 1.3; margin-bottom: 14px; }
    .contact-info__title span { color: var(--color-secondary-light); }
    .contact-info__description { color: #64748b; font-size: 14.5px; line-height: 1.75; margin-bottom: 32px; }
    .contact-info__list { display: flex; flex-direction: column; gap: 16px; }
    .contact-info__item { display: flex; align-items: center; gap: 14px; }
    .contact-info__item-icon {
      width: 42px; height: 42px;
      border-radius: 11px;
      background: rgba(255,255,255,.07);
      display: flex; align-items: center; justify-content: center;
      color: var(--color-secondary-light); font-size: 15px;
      flex-shrink: 0;
    }
    .contact-info__item span { color: #94a3b8; font-size: 13.5px; }

    /* Contact Form */
    .contact-form { display: flex; flex-direction: column; gap: 16px; }
    .contact-form__row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
    .form-field { display: flex; flex-direction: column; gap: 7px; }
    .form-field label {
      font-size: 10.5px; font-weight: 700;
      color: #64748b;
      text-transform: uppercase;
      letter-spacing: 1px;
    }
    .form-field input,
    .form-field textarea,
    .form-field select {
      background: rgba(255,255,255,.06);
      border: 1.5px solid rgba(255,255,255,.1);
      border-radius: 9px;
      padding: 12px 15px;
      font-size: 13.5px;
      color: #fff;
      font-family: var(--font-body);
      outline: none;
      transition: border-color .2s, background .2s;
    }
    .form-field input::placeholder,
    .form-field textarea::placeholder { color: #475569; }
    .form-field input:focus,
    .form-field textarea:focus,
    .form-field select:focus { border-color: var(--color-secondary-light); background: rgba(255,255,255,.09); }
    .form-field textarea { resize: vertical; min-height: 110px; }
    .form-field select { color: #94a3b8; }
    .form-field select option { background: var(--color-dark2); color: #fff; }

/* ── NEWSLETTER ── */
#newsletter {
      background: linear-gradient(135deg, var(--color-primary), #8a0b1c);
      padding: 58px var(--container-pad);
    }
    .newsletter__inner {
      max-width: 680px;
      margin: auto;
      text-align: center;
    }
    .newsletter__title { font-size: 28px; font-weight: 900; color: #fff; margin-bottom: 8px; }
    .newsletter__description { color: rgba(255,255,255,.78); font-size: 14.5px; margin-bottom: 28px; }
    .newsletter__form {
      display: flex;
      gap: 10px;
      max-width: 480px;
      margin: auto;
    }
    .newsletter__input {
      flex: 1;
      padding: 13px 18px;
      border-radius: 9px;
      border: none;
      font-size: 14px;
      font-family: var(--font-body);
      outline: none;
    }
    .newsletter__btn {
      background: var(--color-dark);
      color: #fff;
      border: none;
      padding: 13px 26px;
      border-radius: 9px;
      font-size: 13.5px; font-weight: 700;
      cursor: pointer;
      font-family: var(--font-body);
      white-space: nowrap;
      transition: background .2s;
    }
    .newsletter__btn:hover { background: #000; }

/* ── Responsive – Home sections ── */
@media (max-width: 900px) {
      #primary-navigation { display: none; }
      .hamburger { display: flex; }
      .intro-grid,
      .contact-grid { grid-template-columns: 1fr; gap: 40px; }
      .services-grid,
      .values-grid { grid-template-columns: repeat(2,1fr); }
      .projects-grid,
      .news-grid,
      .testimonials-grid,
      .featured-grid { grid-template-columns: 1fr; }
      .footer-grid { grid-template-columns: 1fr 1fr; }
      .stats-grid { grid-template-columns: repeat(2,1fr); }
      .search-form { grid-template-columns: 1fr 1fr; }
      .topbar__contact .topbar__contact-item:not(:first-child) { display: none; }
      .float-card--green { right: 0; }
    }
@media (max-width: 600px) {
      .services-grid,
      .values-grid,
      .stats-grid { grid-template-columns: 1fr; }
      .footer-grid { grid-template-columns: 1fr; }
      .newsletter__form { flex-direction: column; }
      .contact-form__row { grid-template-columns: 1fr; }
      .topbar__contact { display: none; }
      #topbar .container { justify-content: flex-end; }
      #search-widget { margin-top: -24px; }
      .hero__content { padding: 60px 20px 80px; }
      .section { padding: 56px 20px; }
      .float-card { left: 0; }
      .float-card--green { display: none; }
    }

/* ============================================================
   TESTIMONIALS SLIDER  (v2.4)
   ============================================================ */
.testi-section { overflow: hidden; }

.testimonials__header {
  text-align: center;
  margin-bottom: 52px;
}

.testi-slider {
  position: relative;
}

/* Track – overflow hidden, ảo để slide */
.testi-slider__track {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  transition: transform .55s cubic-bezier(.22,1,.36,1);
  will-change: transform;
}

/* Card */
.testi-card {
  background: #fff;
  border: 1.5px solid var(--color-border);
  border-radius: 20px;
  padding: 34px 30px;
  position: relative;
  overflow: hidden;
  transition: box-shadow .3s, border-color .3s, transform .3s;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.testi-card:hover {
  box-shadow: 0 16px 48px rgba(30,125,58,.10);
  border-color: rgba(30,125,58,.3);
  transform: translateY(-4px);
}

/* Big quote mark */
.testi-card__quote {
  position: absolute;
  top: -6px; right: 22px;
  font-size: 108px;
  font-weight: 900;
  line-height: 1;
  color: var(--color-secondary-pale);
  font-family: Georgia, serif;
  pointer-events: none;
  user-select: none;
}

/* Stars */
.testi-card__stars { display: flex; gap: 3px; }
.testi-card__stars .fa-star    { color: var(--color-gold); font-size: 14px; }
.testi-card__stars .fa-star-o  { color: #d1d5db; font-size: 14px; }

/* Text */
.testi-card__text {
  font-size: 14.5px;
  color: var(--color-gray);
  line-height: 1.82;
  font-style: italic;
  position: relative;
  z-index: 1;
  flex: 1;
  margin: 0;
}

/* Author */
.testi-card__author {
  display: flex;
  align-items: center;
  gap: 14px;
  padding-top: 16px;
  border-top: 1px solid var(--color-border);
}
.testi-card__avatar {
  width: 52px; height: 52px;
  border-radius: 50%;
  object-fit: cover;
  border: 2.5px solid var(--color-secondary-pale);
  flex-shrink: 0;
}
.testi-card__name {
  font-size: 14.5px;
  font-weight: 800;
  color: var(--color-dark);
  margin-bottom: 2px;
}
.testi-card__role {
  font-size: 12px;
  color: var(--color-gray-light);
}

/* Prev / Next buttons */
.testi-slider__btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 44px; height: 44px;
  border-radius: 50%;
  border: 1.5px solid var(--color-border);
  background: #fff;
  color: var(--color-dark);
  font-size: 14px;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  box-shadow: 0 4px 14px rgba(0,0,0,.09);
  transition: background .2s, border-color .2s, transform .25s cubic-bezier(.34,1.56,.64,1), box-shadow .2s;
  z-index: 10;
}
.testi-slider__btn:hover {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: #fff;
  transform: translateY(-50%) scale(1.1);
  box-shadow: 0 6px 20px rgba(196,18,48,.28);
}
.testi-slider__btn--prev { left: -22px; }
.testi-slider__btn--next { right: -22px; }
.testi-slider__btn:disabled {
  opacity: .35;
  cursor: not-allowed;
  pointer-events: none;
}

/* Dots */
.testi-slider__dots {
  display: flex;
  justify-content: center;
  gap: 8px;
  margin-top: 36px;
}
.testi-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  border: none;
  background: var(--color-border);
  cursor: pointer;
  padding: 0;
  transition: background .25s, width .25s, border-radius .25s;
}
.testi-dot.is-active {
  background: var(--color-primary);
  width: 28px;
  border-radius: 4px;
}

/* Responsive slider */
@media (max-width: 1024px) {
  .testi-slider__track { grid-template-columns: repeat(2, 1fr); }
  .testi-slider__btn--prev { left: -14px; }
  .testi-slider__btn--next { right: -14px; }
}
@media (max-width: 640px) {
  .testi-slider__track { grid-template-columns: 1fr; }
  .testi-slider__btn { display: none; }
}


/* ============================================================
   PROJECT GALLERY LIGHTBOX  (v2.4)
   ============================================================ */

/* Wrapper */
.pg-gallery {
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 4px 24px rgba(0,0,0,.07);
  margin-bottom: 28px;
}

/* Main image */
.pg-gallery__main-wrap {
  position: relative;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: #0f1923;
  cursor: zoom-in;
}
.pg-gallery__main-img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  transition: opacity .35s ease, transform .35s ease;
}
.pg-gallery__main-img.is-loading {
  opacity: .4;
  transform: scale(.98);
}

/* Caption overlay */
.pg-gallery__caption {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  padding: 10px 16px;
  background: linear-gradient(to top, rgba(10,18,28,.7) 0%, transparent 100%);
  font-size: 12.5px;
  color: rgba(255,255,255,.88);
  font-weight: 500;
  pointer-events: none;
}

/* Counter badge */
.pg-gallery__counter {
  position: absolute;
  top: 12px; right: 12px;
  background: rgba(10,18,28,.65);
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  padding: 4px 10px;
  border-radius: 50px;
  backdrop-filter: blur(4px);
  pointer-events: none;
  letter-spacing: .04em;
}

/* Prev / Next overlay on main */
.pg-gallery__nav {
  position: absolute;
  top: 50%; transform: translateY(-50%);
  width: 40px; height: 40px;
  border-radius: 50%;
  border: none;
  background: rgba(255,255,255,.15);
  color: #fff;
  font-size: 14px;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  backdrop-filter: blur(4px);
  transition: background .2s, transform .25s cubic-bezier(.34,1.56,.64,1);
  opacity: 0;
}
.pg-gallery__main-wrap:hover .pg-gallery__nav { opacity: 1; }
.pg-gallery__nav:hover {
  background: rgba(255,255,255,.32);
  transform: translateY(-50%) scale(1.1);
}
.pg-gallery__nav--prev { left: 12px; }
.pg-gallery__nav--next { right: 12px; }

/* Expand button */
.pg-gallery__expand {
  position: absolute;
  bottom: 10px; right: 12px;
  width: 34px; height: 34px;
  border-radius: 8px;
  border: none;
  background: rgba(255,255,255,.18);
  color: #fff;
  font-size: 13px;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  backdrop-filter: blur(4px);
  transition: background .2s, transform .2s;
  opacity: 0;
}
.pg-gallery__main-wrap:hover .pg-gallery__expand { opacity: 1; }
.pg-gallery__expand:hover {
  background: var(--color-primary);
  transform: scale(1.1);
}

/* Thumbnails strip */
.pg-gallery__thumbs {
  display: flex;
  gap: 0;
  overflow-x: auto;
  scrollbar-width: thin;
  scrollbar-color: var(--color-border) transparent;
  padding: 0;
  background: #f1f3f5;
}
.pg-gallery__thumbs::-webkit-scrollbar { height: 4px; }
.pg-gallery__thumbs::-webkit-scrollbar-thumb { background: var(--color-border); border-radius: 2px; }

.pg-gallery__thumb {
  flex-shrink: 0;
  width: 100px;
  height: 68px;
  overflow: hidden;
  padding: 0;
  border: none;
  background: none;
  cursor: pointer;
  position: relative;
  transition: opacity .2s;
  border-right: 1px solid rgba(255,255,255,.6);
}
.pg-gallery__thumb:last-child { border-right: none; }
.pg-gallery__thumb img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .35s ease, filter .25s;
}
.pg-gallery__thumb:hover img   { transform: scale(1.08); filter: brightness(1.1); }
.pg-gallery__thumb.is-active   { outline: 3px solid var(--color-primary); outline-offset: -3px; z-index: 1; }
.pg-gallery__thumb.is-active img { filter: brightness(1.05); }

/* Active indicator bar */
.pg-gallery__thumb.is-active::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 3px;
  background: var(--color-primary);
}

/* ── LIGHTBOX ── */
.pg-lightbox {
  position: fixed; inset: 0; z-index: 10000;
  display: flex; align-items: center; justify-content: center;
}
.pg-lightbox[hidden] { display: none; }

.pg-lightbox__backdrop {
  position: absolute; inset: 0;
  background: rgba(5,10,18,.94);
  backdrop-filter: blur(8px);
  cursor: pointer;
}

.pg-lightbox__box {
  position: relative; z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  width: min(96vw, 1100px);
  animation: lb-pop .3s cubic-bezier(.22,1,.36,1);
}
@keyframes lb-pop {
  from { opacity: 0; transform: scale(.93); }
  to   { opacity: 1; transform: scale(1); }
}

/* Close button */
.pg-lightbox__close {
  position: absolute;
  top: -48px; right: 0;
  width: 38px; height: 38px;
  border-radius: 50%;
  border: 1.5px solid rgba(255,255,255,.3);
  background: rgba(255,255,255,.08);
  color: #fff; font-size: 16px;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  transition: background .2s, transform .25s;
}
.pg-lightbox__close:hover {
  background: rgba(255,255,255,.2);
  transform: rotate(90deg);
}

/* Image wrapper */
.pg-lightbox__img-wrap {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 32px 80px rgba(0,0,0,.7);
  background: #0a0f18;
  max-height: 80vh;
}
.pg-lightbox__img-wrap img {
  max-width: 100%;
  max-height: 80vh;
  object-fit: contain;
  display: block;
  transition: opacity .3s ease;
}
.pg-lightbox__img-wrap img.is-loading { opacity: .3; }

/* Nav arrows */
.pg-lightbox__nav {
  position: absolute;
  top: 50%; transform: translateY(-50%);
  width: 48px; height: 48px;
  border-radius: 50%;
  border: 1.5px solid rgba(255,255,255,.22);
  background: rgba(255,255,255,.08);
  color: #fff; font-size: 16px;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  transition: background .2s, transform .3s cubic-bezier(.34,1.56,.64,1);
  backdrop-filter: blur(4px);
}
.pg-lightbox__nav:hover {
  background: var(--color-primary);
  border-color: var(--color-primary);
  transform: translateY(-50%) scale(1.1);
}
.pg-lightbox__nav--prev { left: -64px; }
.pg-lightbox__nav--next { right: -64px; }

/* Caption & counter */
.pg-lightbox__caption {
  margin-top: 14px;
  font-size: 13.5px;
  color: rgba(255,255,255,.72);
  text-align: center;
  font-weight: 500;
}
.pg-lightbox__counter {
  margin-top: 8px;
  font-size: 12px;
  color: rgba(255,255,255,.42);
  letter-spacing: .06em;
}

/* Responsive lightbox */
@media (max-width: 768px) {
  .pg-lightbox__nav--prev { left: 6px; }
  .pg-lightbox__nav--next { right: 6px; }
  .pg-lightbox__nav { width: 38px; height: 38px; font-size: 13px; }
  .pg-gallery__thumb { width: 76px; height: 52px; }
}

/* Testimonial avatar placeholder (khi không có ảnh) */
.testi-card__avatar--placeholder {
  width: 52px; height: 52px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--color-secondary), var(--color-secondary-mid));
  display: flex; align-items: center; justify-content: center;
  font-size: 20px; font-weight: 800; color: #fff;
  flex-shrink: 0;
  border: 2.5px solid var(--color-secondary-pale);
  font-family: var(--font-body);
}
