/*
Theme Name: Trại Hè Quân Đội
Theme URI: https://traihequandoi.vn
Author: Claude (Anthropic)
Author URI: https://traihequandoi.vn
Description: Theme WordPress cho chương trình "Trại Hè Quân Đội – Học Kỳ Quân Đội". Hiện đại, mạnh mẽ, tông xanh quân đội – vàng kim – đỏ sao. Hỗ trợ Khóa học (CPT), form đăng ký lưu trong wp-admin, Customizer, responsive.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: traihequandoi
Tags: education, camp, military, custom-menu, custom-logo, featured-images, translation-ready, responsive
*/

:root{
  --army:#33561f; --army-dark:#21380f; --army-mid:#4a6b2a; --army-light:#6e8b3d;
  --khaki:#cdbd8e; --gold:#f2a200; --gold-2:#ffc233; --red:#d62828; --red-dark:#b71c1c;
  --cream:#f5f2e9; --ink:#222418; --muted:#6f745c; --line:#e6e2d2; --white:#fff;
  --shadow:0 12px 32px rgba(25,40,10,.13); --radius:14px;
  --font-display:"Oswald","Be Vietnam Pro",sans-serif;
  --font-body:"Be Vietnam Pro",system-ui,Arial,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);color:var(--ink);background:var(--white);line-height:1.65;-webkit-font-smoothing:antialiased}
h1,h2,h3,.display{font-family:var(--font-display);letter-spacing:.5px;text-transform:uppercase;line-height:1.12}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block;height:auto}
.container{width:min(1200px,93%);margin-inline:auto}
.section{padding:74px 0}
.center{text-align:center}
.screen-reader-text{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(1px,1px,1px,1px);clip-path:inset(50%);word-wrap:normal}
.skip-link{position:absolute;left:-9999px;z-index:999;background:var(--gold);color:var(--army-dark);padding:10px 16px;border-radius:0 0 8px 0}
.skip-link:focus{left:0;top:0}

/* Section header */
.sec-head{text-align:center;max-width:760px;margin:0 auto 48px}
.sec-title{font-size:clamp(1.7rem,3.6vw,2.5rem);color:var(--army);margin-bottom:18px}
.sec-title .g{color:var(--gold)}
.divider{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:16px}
.divider span{height:3px;width:46px;background:var(--gold);border-radius:3px}
.divider .d{width:9px;height:9px;border-radius:50%;background:var(--red);transform:rotate(45deg)}
.sec-head p{color:var(--muted);font-size:1.05rem}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-display);font-weight:600;letter-spacing:.8px;
  text-transform:uppercase;font-size:.92rem;padding:13px 26px;border-radius:8px;border:2px solid transparent;cursor:pointer;transition:.22s;line-height:1}
.btn-red{background:var(--red);color:#fff;box-shadow:0 8px 18px rgba(214,40,40,.35)}
.btn-red:hover{background:var(--red-dark);transform:translateY(-2px)}
.btn-gold{background:var(--gold);color:var(--army-dark);box-shadow:0 8px 18px rgba(242,162,0,.35)}
.btn-gold:hover{background:var(--gold-2);transform:translateY(-2px)}
.btn-out{background:transparent;color:#fff;border-color:rgba(255,255,255,.65)}
.btn-out:hover{background:#fff;color:var(--army)}
.btn-out-g{background:transparent;color:var(--army);border-color:var(--army-mid)}
.btn-out-g:hover{background:var(--army);color:#fff}

/* TOP BAR */
.topbar{background:var(--army-dark);color:#d9d6c2;font-size:.84rem}
.topbar .container{display:flex;justify-content:space-between;align-items:center;height:38px}
.topbar .l{display:flex;gap:20px}
.topbar .l span{display:inline-flex;align-items:center;gap:6px}
.topbar .r{display:flex;gap:16px}
.topbar .r a:hover{color:var(--gold)}

/* HEADER */
.header{position:sticky;top:0;z-index:50;background:var(--army);box-shadow:0 3px 16px rgba(0,0,0,.2)}
.nav{display:flex;align-items:center;justify-content:space-between;height:78px;gap:20px}
.brand{display:flex;align-items:center;gap:12px;color:#fff;flex-shrink:0}
.brand img.custom-logo{max-height:56px;width:auto}
.brand .logo{width:48px;height:48px;display:grid;place-items:center;background:var(--red);border-radius:10px;font-size:1.5rem;color:var(--gold);box-shadow:0 0 0 3px rgba(242,162,0,.3);flex-shrink:0}
.brand strong,.brand b{font-family:var(--font-display);font-size:1.2rem;letter-spacing:1px;line-height:1;text-transform:uppercase;white-space:nowrap}
.brand .brand-text span,.brand small{display:block;font-size:.68rem;color:var(--khaki);letter-spacing:.5px;text-transform:none;margin-top:3px;font-family:var(--font-body)}
.menu{display:flex;gap:22px;list-style:none;align-items:center}
.menu li{position:relative}
.menu a{color:#eef0e2;font-family:var(--font-display);font-weight:500;font-size:.92rem;letter-spacing:.5px;text-transform:uppercase;padding:6px 0;position:relative;transition:.2s;display:block}
.menu a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:2px;background:var(--gold);transition:.25s}
.menu a:hover{color:var(--gold)}.menu a:hover::after{width:100%}
.menu .current-menu-item>a,.menu .current_page_item>a,.menu a.active{color:var(--gold)}
.menu .current-menu-item>a::after,.menu .current_page_item>a::after,.menu a.active::after{width:100%}
.menu .sub-menu{position:absolute;top:100%;left:0;min-width:210px;background:var(--army-dark);border-radius:10px;padding:8px;display:none;flex-direction:column;gap:2px;box-shadow:var(--shadow);z-index:20}
.menu li:hover>.sub-menu{display:flex}
.menu .sub-menu a{padding:8px 12px;text-transform:none;font-family:var(--font-body);font-size:.9rem}
.menu .sub-menu a::after{display:none}
.nav-actions{display:flex;align-items:center;gap:12px;flex-shrink:0}
.nav-phone{display:flex;align-items:center;gap:10px}
.nav-phone .ic{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;background:rgba(255,255,255,.12);color:var(--gold);font-size:1.1rem}
.nav-phone small{display:block;color:var(--khaki);font-size:.68rem;text-transform:uppercase;letter-spacing:1px}
.nav-phone b{font-family:var(--font-display);color:var(--gold);font-size:1.15rem;letter-spacing:.5px}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.burger span{width:26px;height:3px;background:#fff;border-radius:3px;transition:.25s}

/* HERO */
.hero{position:relative;color:#fff;overflow:hidden;background:linear-gradient(115deg,var(--army-dark) 0%,var(--army) 55%,var(--army-mid) 100%)}
.hero-bg-img{position:absolute;inset:0;opacity:.13;background-size:cover;background-position:center;mix-blend-mode:luminosity}
.hero::after{content:"";position:absolute;inset:0;background:repeating-linear-gradient(45deg,transparent,transparent 26px,rgba(0,0,0,.05) 26px,rgba(0,0,0,.05) 28px)}
.hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center;padding:56px 0}
.badge{display:inline-flex;align-items:center;gap:9px;background:var(--red);color:#fff;padding:8px 18px;border-radius:50px;font-family:var(--font-display);font-weight:600;letter-spacing:1.5px;text-transform:uppercase;font-size:.76rem;margin-bottom:20px}
.badge .dot{width:8px;height:8px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 4px rgba(242,162,0,.35)}
.hero h1{font-size:clamp(2.4rem,5.2vw,4.1rem);font-weight:700;text-shadow:0 4px 18px rgba(0,0,0,.35)}
.hero h1 .g{color:var(--gold)}
.hero .sub{font-family:var(--font-display);font-weight:500;letter-spacing:2px;color:#fff;font-size:clamp(1rem,2vw,1.4rem);margin-top:6px;text-transform:uppercase}
.hero .sub b{color:var(--gold-2)}
.hero .lead{max-width:560px;color:#e9ebda;font-size:1.05rem;margin:18px 0 0}
.hero-info{display:grid;grid-template-columns:repeat(2,auto);gap:14px;margin:26px 0 30px;justify-content:start}
.chip{display:flex;align-items:center;gap:11px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);border-radius:10px;padding:11px 16px}
.chip .ic{font-size:1.25rem}
.chip small{display:block;color:var(--khaki);font-size:.7rem;text-transform:uppercase;letter-spacing:1px}
.chip b{font-size:.96rem;font-weight:600}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px}
.hero-photo{position:relative}
.hero-photo .frame{position:relative;border-radius:18px;overflow:hidden;box-shadow:0 24px 50px rgba(0,0,0,.4);border:4px solid rgba(255,255,255,.14)}
.hero-photo img{width:100%;aspect-ratio:4/3.4;object-fit:cover;display:block}
/* Hero slider (crossfade) */
.hero-slider.is-slider{display:grid}
.hero-slider.is-slider .hero-slide{grid-area:1/1;opacity:0;transition:opacity .9s ease}
.hero-slider.is-slider .hero-slide.active{opacity:1}
.hero-dots{position:absolute;left:0;right:0;bottom:12px;display:flex;justify-content:center;gap:8px;z-index:2}
.hero-dots .hero-dot{width:9px;height:9px;padding:0;border:0;border-radius:50%;background:rgba(255,255,255,.5);cursor:pointer;transition:background .3s,transform .3s}
.hero-dots .hero-dot.active{background:var(--gold);transform:scale(1.25)}
.hero-photo .float-badge{position:absolute;left:-14px;bottom:24px;background:var(--gold);color:var(--army-dark);padding:14px 20px;border-radius:12px;box-shadow:var(--shadow);font-family:var(--font-display);line-height:1}
.hero-photo .float-badge b{font-size:1.9rem;display:block}
.hero-photo .float-badge span{font-size:.72rem;letter-spacing:1px;text-transform:uppercase}
.hero-photo .ring{position:absolute;top:-22px;right:-22px;width:120px;height:120px;border:6px solid var(--gold);border-radius:50%;opacity:.35;z-index:-1}

/* FEATURES */
.feat-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:18px}
.feat{text-align:center;padding:14px 8px;transition:.25s}
.feat:hover{transform:translateY(-6px)}
.feat .circle{width:92px;height:92px;margin:0 auto 16px;border-radius:50%;display:grid;place-items:center;font-size:2.1rem;background:var(--cream);border:2px solid var(--line);color:var(--army);transition:.25s}
.feat:hover .circle{background:var(--army);color:var(--gold);border-color:var(--army)}
.feat h3{font-size:.98rem;color:var(--army);line-height:1.3}

/* COURSES */
.courses{background:var(--cream)}
.courses-top{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:16px;margin-bottom:40px}
.courses-top .sec-head{text-align:left;margin:0}
.courses-top .divider{justify-content:flex-start}
.course-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.course{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;display:flex;flex-direction:column;border:1px solid var(--line);transition:.25s}
.course:hover{transform:translateY(-6px);box-shadow:0 22px 44px rgba(25,40,10,.2)}
.course-top{position:relative;height:185px;overflow:hidden}
.course-top img{width:100%;height:100%;object-fit:cover;transition:.4s}
.course:hover .course-top img{transform:scale(1.08)}
.course-hot{position:absolute;top:12px;left:12px;z-index:2;background:var(--red);color:#fff;font-family:var(--font-display);font-weight:600;letter-spacing:1px;font-size:.72rem;padding:5px 12px;border-radius:6px;text-transform:uppercase}
.course-status{position:absolute;top:12px;right:12px;z-index:2;font-family:var(--font-display);font-weight:600;letter-spacing:.5px;text-transform:uppercase;font-size:.7rem;padding:5px 12px;border-radius:6px;color:#fff}
.s-open{background:rgba(74,107,42,.92)}
.s-soon{background:rgba(242,162,0,.95);color:var(--army-dark)}
.s-full{background:rgba(90,90,90,.9)}
.course-body{padding:20px 22px;flex:1;display:flex;flex-direction:column}
.course-body h3{font-size:1.18rem;color:var(--army);margin-bottom:14px;line-height:1.25}
.course-body h3 a:hover{color:var(--gold)}
.course-meta{list-style:none;margin-bottom:18px}
.course-meta li{display:flex;gap:9px;align-items:center;padding:5px 0;font-size:.92rem;color:#4a4d3c}
.course-meta .k{color:var(--gold);flex:0 0 18px;text-align:center}
.course-foot{margin-top:auto;display:flex;gap:10px}
.course-foot .btn{flex:1;justify-content:center;padding:11px 10px;font-size:.8rem}
.course[data-status="full"] .btn-red{background:#bdbab0;box-shadow:none;cursor:not-allowed;pointer-events:none}

/* STATS */
.stats{position:relative;color:#fff;text-align:center;overflow:hidden}
.stats-bg{position:absolute;inset:0;background-size:cover;background-position:center}
.stats-bg::after{content:"";position:absolute;inset:0;background:rgba(33,56,15,.93)}
.stats .container{position:relative;z-index:2;padding:54px 0}
.stats .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.stat .ic{font-size:1.9rem;color:var(--gold);margin-bottom:8px}
.stat b{font-family:var(--font-display);font-size:2.6rem;color:var(--gold);display:block;line-height:1}
.stat span{font-size:.92rem;color:#dfe2cf;display:block;margin-top:6px}

/* TRUST */
.trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:26px}
.trust{display:flex;gap:16px;align-items:flex-start}
.trust .ic{flex:0 0 56px;height:56px;border-radius:12px;display:grid;place-items:center;font-size:1.5rem;background:var(--army);color:var(--gold)}
.trust h3{font-size:1.05rem;color:var(--army);margin-bottom:4px}
.trust p{font-size:.9rem;color:var(--muted)}

/* ABOUT */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.about-grid .divider{justify-content:flex-start}
.about-grid h2{text-align:left}
.about-grid p{margin-bottom:14px;color:#4a4d3c}
.about-img{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.about-img img{width:100%;aspect-ratio:4/3;object-fit:cover}
.about-img .tag{position:absolute;left:18px;bottom:18px;background:var(--gold);color:var(--army-dark);padding:9px 16px;border-radius:9px;font-family:var(--font-display);letter-spacing:.5px}
.quote{border-left:4px solid var(--red);padding:4px 0 4px 18px;font-style:italic;color:var(--army);margin:18px 0}

/* SCHEDULE */
.schedule{background:var(--cream)}
.timeline{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.day{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;display:flex;transition:.25s;border:1px solid var(--line)}
.day:hover{transform:translateY(-4px);box-shadow:0 16px 36px rgba(25,40,10,.18)}
.day-num{flex:0 0 80px;background:linear-gradient(160deg,var(--army-mid),var(--army-dark));color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;font-family:var(--font-display)}
.day-num small{font-size:.66rem;letter-spacing:2px;color:var(--khaki)}
.day-num b{font-size:2.3rem;line-height:1;color:var(--gold)}
.day-body{padding:16px 20px}
.day-body h3{font-size:1.08rem;color:var(--army);margin-bottom:5px}
.day-body p{font-size:.9rem;color:var(--muted)}

/* GALLERY */
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.gallery-grid figure{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);margin:0}
.gallery-grid img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3;transition:.4s}
.gallery-grid figure:hover img{transform:scale(1.07)}
.gallery-grid figure.wide{grid-column:span 2}
.gallery-grid figcaption{position:absolute;inset:auto 0 0 0;padding:28px 18px 13px;color:#fff;font-family:var(--font-display);letter-spacing:1px;text-transform:uppercase;font-size:.92rem;background:linear-gradient(transparent,rgba(0,0,0,.78))}
.g-activity{aspect-ratio:4/3;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:#fff;padding:18px;gap:8px}
.g-activity .ic{font-size:2.4rem}
.g-activity b{font-family:var(--font-display);letter-spacing:1px;text-transform:uppercase;font-size:1rem}
.g-activity span{font-size:.8rem;opacity:.85}
.g1{background:linear-gradient(150deg,var(--army-mid),var(--army-dark))}
.g2{background:linear-gradient(150deg,#8a6a16,var(--army))}
.g3{background:linear-gradient(150deg,#9a2a2a,#3a2014)}
.g4{background:linear-gradient(150deg,var(--army),#16200a)}

/* INFO */
.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:34px}
.info-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:32px;border-top:5px solid var(--army-mid)}
.info-card.alt{border-top-color:var(--red)}
.info-card h3{font-size:1.3rem;color:var(--army);margin-bottom:16px;display:flex;align-items:center;gap:12px}
.info-card h3 .ic{width:44px;height:44px;display:grid;place-items:center;border-radius:10px;background:var(--cream);font-size:1.25rem}
.info-list{list-style:none}
.info-list li{padding:9px 0 9px 30px;position:relative;border-bottom:1px dashed var(--line);color:#4a4d3c}
.info-list li:last-child{border-bottom:none}
.info-list li::before{content:"✔";position:absolute;left:0;top:9px;color:var(--army-mid);font-weight:700}
.info-card.alt .info-list li::before{content:"✘";color:var(--red)}

/* CTA */
.cta{position:relative;color:#fff;text-align:center;overflow:hidden}
.cta-bg{position:absolute;inset:0;background-size:cover;background-position:center}
.cta-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(rgba(33,56,15,.94),rgba(51,86,31,.94))}
.cta .container{position:relative;z-index:2;padding:80px 0}
.cta h2{font-size:clamp(1.8rem,4vw,2.8rem);color:#fff;margin-bottom:14px}
.cta p{max-width:620px;margin:0 auto 28px;color:#e7eadb;font-size:1.08rem}
.hotlines{display:flex;flex-wrap:wrap;gap:16px;justify-content:center;margin-top:28px}
.hotline{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.2);border-radius:12px;padding:16px 24px;min-width:220px}
.hotline small{display:block;color:var(--khaki);text-transform:uppercase;letter-spacing:1px;font-size:.7rem;margin-bottom:3px}
.hotline b{font-family:var(--font-display);font-size:1.45rem;color:var(--gold);letter-spacing:.5px}

/* FOOTER */
.site-footer{background:var(--army-dark);color:#cfd2bd;padding:54px 0 24px}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:36px;margin-bottom:34px}
.site-footer h4{font-family:var(--font-display);color:#fff;letter-spacing:1px;margin-bottom:16px;text-transform:uppercase;font-size:1.02rem}
.site-footer p,.site-footer li{font-size:.93rem;margin-bottom:9px;list-style:none}
.site-footer a:hover{color:var(--gold)}
.foot-brand{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.foot-social{display:flex;gap:10px;margin-top:6px}
.foot-social a{width:38px;height:38px;border-radius:8px;display:grid;place-items:center;background:rgba(255,255,255,.1);color:#fff;font-size:1.1rem;transition:.2s}
.foot-social a:hover{background:var(--gold);color:var(--army-dark)}
.foot-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:20px;text-align:center;font-size:.85rem;color:#9aa085}

/* FLOAT */
.float{position:fixed;right:16px;bottom:18px;z-index:60;display:flex;flex-direction:column;gap:11px}
.float a{width:52px;height:52px;border-radius:50%;display:grid;place-items:center;font-size:1.35rem;color:#fff;box-shadow:0 6px 18px rgba(0,0,0,.3);transition:.2s}
.float a:hover{transform:scale(1.1)}
.f-phone{background:var(--red);animation:pulse 1.8s infinite}
.f-fb{background:#1877f2}.f-tt{background:#000}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(214,40,40,.6)}70%{box-shadow:0 0 0 16px rgba(214,40,40,0)}100%{box-shadow:0 0 0 0 rgba(214,40,40,0)}}

/* MUSIC TOGGLE */
.music-toggle{position:fixed;left:16px;bottom:18px;z-index:60;width:50px;height:50px;border-radius:50%;border:none;cursor:pointer;
  background:var(--army);color:var(--gold);font-size:1.25rem;box-shadow:0 6px 18px rgba(0,0,0,.3);display:grid;place-items:center;transition:background .2s,transform .2s}
.music-toggle:hover{transform:scale(1.1)}
.music-toggle .m-off{display:none}
.music-toggle.paused{background:#6b6f5c;color:#fff}
.music-toggle.paused .m-on{display:none}
.music-toggle.paused .m-off{display:inline}
.music-toggle.playing{animation:music-pulse 1.8s infinite}
@keyframes music-pulse{0%{box-shadow:0 0 0 0 rgba(242,162,0,.55)}70%{box-shadow:0 0 0 14px rgba(242,162,0,0)}100%{box-shadow:0 0 0 0 rgba(242,162,0,0)}}
@media(max-width:480px){.music-toggle{width:44px;height:44px;font-size:1.1rem}}

/* MODAL */
.modal{position:fixed;inset:0;z-index:120;display:none;align-items:center;justify-content:center;padding:20px;background:rgba(20,28,10,.72);backdrop-filter:blur(4px)}
.modal.open{display:flex}
.modal-box{background:#fff;width:min(560px,100%);border-radius:16px;overflow:hidden;box-shadow:0 30px 70px rgba(0,0,0,.4);max-height:92vh;overflow-y:auto;animation:pop .3s ease}
@keyframes pop{from{transform:translateY(20px) scale(.97);opacity:0}to{transform:none;opacity:1}}
.modal-head{background:linear-gradient(135deg,var(--army),var(--army-dark));color:#fff;padding:24px 28px;position:relative}
.modal-head h3{color:#fff;font-size:1.4rem}
.modal-head p{color:var(--khaki);font-size:.9rem;margin-top:4px}
.modal-close{position:absolute;top:16px;right:18px;background:rgba(255,255,255,.15);border:none;color:#fff;width:34px;height:34px;border-radius:50%;font-size:1.2rem;cursor:pointer;line-height:1}
.modal-close:hover{background:var(--red)}
.modal-body{padding:26px 28px}
.field{margin-bottom:16px}
.field label{display:block;font-weight:600;font-size:.9rem;margin-bottom:6px;color:var(--army)}
.field label .req{color:var(--red)}
.field input,.field select,.field textarea{width:100%;padding:12px 14px;border:1.5px solid #dcd8c8;border-radius:10px;font-family:inherit;font-size:.95rem;background:#fbfaf4;transition:.2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--army-mid);background:#fff}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.hp-field{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form-note{font-size:.84rem;color:var(--muted);margin-top:4px}
.modal .btn{width:100%;justify-content:center;margin-top:6px}
.form-success{display:none;text-align:center;padding:30px 10px}
.form-success.show{display:block}
.form-success .check{width:70px;height:70px;border-radius:50%;background:var(--army-mid);color:#fff;display:grid;place-items:center;font-size:2rem;margin:0 auto 16px}
.form-success h3{color:var(--army);margin-bottom:8px}.form-success p{color:var(--muted)}
.thqd-notice{margin:0 0 16px;padding:12px 16px;border-radius:10px;font-size:.92rem}
.thqd-notice--ok{background:#e7f3e0;color:#2f5d1a;border:1px solid #b9d9a6}
.thqd-notice--err{background:#fbe6e6;color:#9a1d1d;border:1px solid #f0b6b6}

/* GENERIC PAGE / SINGLE */
.page-hero{background:linear-gradient(115deg,var(--army-dark),var(--army-mid));color:#fff;padding:54px 0;position:relative}
.page-hero h1{font-size:clamp(1.8rem,4vw,2.8rem)}
.breadcrumb{font-size:.86rem;color:var(--khaki);margin-bottom:10px}
.breadcrumb a:hover{color:var(--gold)}
.entry{max-width:820px;margin:0 auto;padding:50px 0}
.entry h2{color:var(--army);margin:28px 0 12px;font-size:1.5rem}
.entry h3{color:var(--army);margin:22px 0 10px;font-size:1.2rem}
.entry p{margin-bottom:16px}
.entry img{border-radius:var(--radius);margin:18px 0}
.entry ul,.entry ol{margin:0 0 16px 22px}
.entry li{margin-bottom:6px}
.single-course-layout{display:grid;grid-template-columns:1.6fr 1fr;gap:40px;align-items:start;padding:50px 0}
.course-side{position:sticky;top:100px;background:var(--cream);border-radius:var(--radius);padding:26px;border:1px solid var(--line)}
.course-side h3{color:var(--army);font-size:1.2rem;margin-bottom:16px}
.course-side .meta-row{display:flex;gap:10px;padding:10px 0;border-bottom:1px dashed var(--line)}
.course-side .meta-row b{color:var(--army)}
.course-side .price{font-family:var(--font-display);color:var(--red);font-size:1.6rem;margin:14px 0}
.pagination{display:flex;gap:8px;justify-content:center;margin-top:40px}
.pagination .page-numbers{display:inline-grid;place-items:center;min-width:42px;height:42px;padding:0 12px;border-radius:8px;background:var(--cream);color:var(--army);font-family:var(--font-display)}
.pagination .page-numbers.current{background:var(--army);color:#fff}

.reveal{opacity:0;transform:translateY(26px);transition:.7s ease}
.reveal.in{opacity:1;transform:none}
.no-js .reveal{opacity:1;transform:none}

/* RESPONSIVE */
@media(max-width:1040px){
  .menu{gap:14px}.menu a{font-size:.82rem}
  .feat-grid{grid-template-columns:repeat(3,1fr);gap:24px}
}
@media(max-width:880px){
  .topbar{display:none}
  .menu,.nav-phone{display:none}
  .burger{display:flex}
  .nav-actions .btn--primary{display:none}
  .hero-grid,.about-grid,.info-grid,.timeline,.course-grid,.gallery-grid,.foot-grid,.field-row,.single-course-layout{grid-template-columns:1fr}
  .course-side{position:static}
  .hero-photo{order:-1;max-width:440px;margin:0 auto}
  .feat-grid{grid-template-columns:repeat(2,1fr)}
  .stats .grid,.trust-grid{grid-template-columns:repeat(2,1fr)}
  .gallery-grid figure.wide{grid-column:auto}
  .courses-top{flex-direction:column;align-items:flex-start}
  .menu.open{display:flex;position:absolute;top:78px;left:0;right:0;flex-direction:column;background:var(--army-dark);padding:18px 24px;gap:14px;z-index:40}
  .menu.open .sub-menu{position:static;display:flex;background:transparent;padding:4px 0 4px 14px}
}
@media(max-width:480px){
  .hero-info{grid-template-columns:1fr}
  .feat-grid,.stats .grid,.trust-grid{grid-template-columns:1fr}
}
