/* ---------- RESET ---------- */
*,*::before,*::after{box-sizing:border-box;}
body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"SF Pro Text","Segoe UI",Roboto,Inter,Helvetica,Arial,sans-serif;
  -webkit-font-smoothing:antialiased;font-size:16px;line-height:1.58;color:#1d2733;background:#f0f3f7;}
img{max-width:100%;display:block;height:auto;}
a{text-decoration:none;color:#105fb4;}
a:hover,a:focus-visible{text-decoration:underline;}
button{font:inherit;cursor:pointer;border:none;background:none;padding:0;}
:focus-visible{outline:2px solid #177dff;outline-offset:2px;}
body,header,footer{padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right);}

/* ---------- TOKENS ---------- */
:root{
  --c-bg:#f0f3f7;
  --c-surface:#ffffff;
  --c-border:#e1e6ec;
  --c-border-soft:#eef2f6;
  --c-text:#1d2733;
  --c-text-soft:#5c6d7e;
  --c-primary:#177dff;
  --c-primary-alt:#0e60c4;
  --c-accent:#12b886;
  --c-danger:#e54848;
  --c-gradient:linear-gradient(135deg,#177dff,#12b886);
  --radius-xs:4px;
  --radius-sm:8px;
  --radius-md:14px;
  --radius-xl:46px;
  --shadow-sm:0 2px 4px -1px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.06);
  --shadow-md:0 4px 12px -2px rgba(0,0,0,.12),0 2px 4px rgba(0,0,0,.08);
  --shadow-hover:0 6px 18px -3px rgba(0,0,0,.18),0 3px 6px rgba(0,0,0,.10);
  --transition:0.28s cubic-bezier(.4,.2,.2,1);
  --content-max:1160px;
  --mobile-pad:10px;
  --mobile-pad-tight:8px;
}

/* ---------- GLOBAL WRAP ---------- */
.site-wrap{max-width:var(--content-max);margin:0 auto;padding:0 24px;transition:padding .25s;}
@media (max-width:900px){.site-wrap{padding:0 18px;}}
@media (max-width:640px){.site-wrap{padding:0 var(--mobile-pad);}}

/* ---------- LAYOUT ---------- */
main{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:50px;margin-top:34px;align-items:start;}
@media (max-width:1150px){main{gap:42px;}}
@media (max-width:1080px){
  main{grid-template-columns:100%;gap:40px;align-items:stretch;}
  .sidebar{width:100%;}
  .side-widget{width:100%;}
}
@media (max-width:640px){main{margin-top:26px;gap:34px;}}


.site-header{
  background:#ffffff;
  backdrop-filter:saturate(180%) blur(12px);
  box-shadow:0 1px 0 var(--c-border-soft);

}
.navbar{display:flex;align-items:center;justify-content:space-between;min-height:66px;gap:24px;padding:0;}
.brand{display:flex;align-items:center;gap:10px;font-size:1.1rem;font-weight:600;color:var(--c-text);}
.brand svg{width:40px;height:40px;}
.primary-nav{display:flex;gap:30px;font-size:.92rem;font-weight:500;}
.primary-nav a{color:var(--c-text-soft);position:relative;padding:4px 0;transition:color var(--transition);}
.primary-nav a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:2px;background:var(--c-primary);border-radius:2px;transition:width var(--transition);}
.primary-nav a:hover,
.primary-nav a:focus-visible{color:var(--c-text);}
.primary-nav a:hover::after,
.primary-nav a:focus-visible::after{width:100%;}
.primary-nav a.is-active{color:var(--c-text);}
.primary-nav a.is-active::after{width:100%;}

/* menu button */
.menu-toggle{display:none;width:44px;height:44px;border-radius:50%;background:var(--c-primary);color:#fff;
  align-items:center;justify-content:center;font-size:1.3rem;box-shadow:var(--shadow-sm);transition:background var(--transition),transform var(--transition);}
.menu-toggle:hover{background:var(--c-primary-alt);}
.menu-toggle:active{transform:scale(.94);}
@media (max-width:880px){
  .primary-nav{display:none;}
  .menu-toggle{display:flex;}
}

/* ---------- MOBILE NAV (SLIDE-IN) ---------- */
.m-menu{position:fixed;inset:0;z-index:500;font-family:inherit;}
.m-menu[hidden]{display:none !important;}
.m-menu__overlay{
  position:absolute;inset:0;
  background:#0d1722;
  opacity:0;
  transition:opacity .32s ease;
}
.m-menu__panel{
  position:absolute;top:0;right:0;height:100%;
  width:78%;max-width:360px;
  background:#162735;color:#fff;
  display:flex;flex-direction:column;
  gap:4px;
  padding:70px 30px 40px;
  box-shadow:-6px 0 28px -8px rgba(0,0,0,.55);
  transform:translateX(100%);
  transition:transform .42s cubic-bezier(.65,.05,.36,1);
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
}
.m-menu.is-open .m-menu__overlay{opacity:1;}
.m-menu.is-open .m-menu__panel{transform:translateX(0);}
.m-menu__close{
  position:absolute;top:14px;right:14px;
  width:46px;height:46px;border-radius:50%;
  background:#fff;color:#162735;border:none;
  display:flex;align-items:center;justify-content:center;
  font-size:1.25rem;box-shadow:var(--shadow-sm);cursor:pointer;
}
.m-menu__list{display:flex;flex-direction:column;margin:0;padding:0;list-style:none;gap:6px;}
.m-menu__list a{
  display:block;
  font-size:1.06rem;
  font-weight:600;
  padding:12px 14px 12px 14px;
  border-radius:16px;
  color:#d6e6f3;
  letter-spacing:.4px;
  position:relative;
  transition:background .25s,color .25s;
  text-decoration:none;
  outline:0;
}
.m-menu__list a:hover,
.m-menu__list a:focus-visible{background:#1f394b;color:#fff;}
.m-menu__list a:active{background:#255068;}
.m-menu__list a.is-active{
  background:#1f394b;
  color:#fff;
}
.no-scroll{overflow:hidden;touch-action:none;}
@media (prefers-reduced-motion:reduce){
  .m-menu__overlay,.m-menu__panel{transition:none !important;}
}

/* ---------- BREADCRUMB ---------- */
.breadcrumb{margin:26px auto 4px;max-width:var(--content-max);padding:0 24px;font-size:.75rem;font-weight:500;letter-spacing:.45px;
  color:var(--c-text-soft);display:flex;flex-wrap:wrap;gap:4px;line-height:1.15;}
.breadcrumb a{color:var(--c-primary);}
@media (max-width:640px){.breadcrumb{padding:0 var(--mobile-pad);margin:18px 0 2px;gap:2px;}}

/* ---------- ARTICLE ---------- */
.article{background:var(--c-surface);padding:40px 44px 46px;border-radius:18px;box-shadow:var(--shadow-sm);
  position:relative;overflow:hidden;user-select:text;-webkit-user-select:text;}
.article::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 88% 12%,rgba(23,125,255,.08),transparent 60%);
  pointer-events:none;}
@media (max-width:860px){.article{padding:36px 36px 40px;}}
@media (max-width:640px){
  .article{padding:30px var(--mobile-pad-tight) 36px;border-radius:14px;}
}
.article h1{margin:0 0 16px;font-size:2.2rem;line-height:1.15;font-weight:700;letter-spacing:.5px;}
@media (max-width:640px){.article h1{font-size:1.85rem;margin-bottom:14px;}}
.meta{display:flex;flex-wrap:wrap;gap:12px;font-size:.74rem;text-transform:uppercase;letter-spacing:.13em;color:var(--c-text-soft);font-weight:600;margin:0 0 22px;}
.article p{margin:0 0 20px;font-size:1.02rem;color:#27323d;}
.article p + h2{margin-top:34px;}
.article h2{font-size:1.45rem;margin:0 0 14px;line-height:1.28;position:relative;}
.article h2::after{content:"";position:absolute;left:0;bottom:-6px;width:56px;height:3px;border-radius:3px;
  background:linear-gradient(90deg,var(--c-primary),var(--c-accent));pointer-events:none;}

/* ---------- AUTHOR BOX ---------- */
.author-box{margin-top:40px;background:var(--c-surface);border:2px solid var(--c-border);padding:22px 26px;border-radius:var(--radius-xl);
 display:flex;align-items:center;gap:24px;box-shadow:var(--shadow-sm);position:relative;}
.author-avatar{width:90px;height:90px;border-radius:50%;object-fit:cover;box-shadow:0 0 0 4px #fff,0 0 0 6px var(--c-primary);}
.author-details h3{margin:0 0 4px;font-size:1.05rem;}
.author-details p{margin:0;font-size:.85rem;line-height:1.45;color:var(--c-text-soft);}
@media (max-width:560px){
  .author-box{flex-direction:column;align-items:flex-start;padding:24px 22px 26px;border-radius:28px;}
  .author-avatar{width:80px;height:80px;}
}

/* ---------- SINGLE RECOMMENDED TEXT LINK ---------- */
.reco-single{margin-top:32px;background:var(--c-surface);padding:16px 20px;border-left:5px solid var(--c-primary);border-radius:12px;
  box-shadow:var(--shadow-sm);}
.reco-single a{font-weight:600;font-size:.95rem;display:inline-block;}

/* ---------- PAGINATION NOTICE ---------- */
.pagination-notice{margin-top:32px;background:#fff8e6;border:1px solid #ffe2a8;padding:14px 18px;border-radius:12px;
  font-size:.82rem;line-height:1.45;box-shadow:var(--shadow-sm);}

/* ---------- PAGINATION (ENHANCED BUTTON) ---------- */
.page-nav-wrap{margin-top:18px;display:flex;justify-content:flex-end;}
.page-nav{display:flex;gap:16px;}
.page-nav a{
  --btn-bg-top:#1e8dff;
  --btn-bg-bottom:#0f65d4;
  background:linear-gradient(var(--btn-bg-top),var(--btn-bg-bottom));
  color:#fff;
  font-weight:700;
  font-size:1rem;
  letter-spacing:.05em;
  padding:16px 52px;
  border-radius:56px;
  min-height:56px;
  min-width:240px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  position:relative;
  box-shadow:0 4px 0 #0d56b5,0 8px 18px -6px rgba(0,0,0,.4),0 0 0 1px rgba(255,255,255,.08) inset;
  transition:transform .25s var(--transition),box-shadow .25s var(--transition),filter .25s var(--transition),background .4s;
  text-decoration:none;
}
.page-nav a::after{content:"";position:absolute;inset:2px;border-radius:inherit;background:linear-gradient(145deg,rgba(255,255,255,.25),rgba(255,255,255,0));mix-blend-mode:overlay;pointer-events:none;}
.page-nav a:hover{filter:brightness(1.05);box-shadow:0 5px 0 #0d56b5,0 14px 28px -10px rgba(0,0,0,.45),0 0 0 1px rgba(255,255,255,.12) inset;text-decoration:none;}
.page-nav a:active{transform:translateY(3px);box-shadow:0 2px 0 #0d56b5,0 6px 14px -6px rgba(0,0,0,.5),0 0 0 1px rgba(255,255,255,.15) inset;}
.page-nav a:focus-visible{outline:3px solid #fff;outline-offset:4px;}
@media (max-width:640px){
  .page-nav-wrap{justify-content:center;}
  .page-nav{width:100%;justify-content:center;}
  .page-nav a{width:100%;max-width:440px;font-size:1.08rem;padding:18px 24px;min-height:60px;}
}

/* ---------- SHARE SECTION ---------- */
.share-section{margin-top:46px;background:var(--c-surface);padding:26px 26px 28px;border-radius:18px;box-shadow:var(--shadow-sm);position:relative;}
.share-section h2{margin:0 0 18px;font-size:1.25rem;letter-spacing:.4px;}
.share-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;}
@media (max-width:640px){
  .share-section{padding:20px var(--mobile-pad-tight) 20px;border-radius:14px;}
  .share-section h2{font-size:1rem;margin-bottom:10px;}
  .share-grid{display:flex;overflow-x:auto;gap:8px;scroll-snap-type:x mandatory;padding-bottom:2px;-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;}
  .share-grid::-webkit-scrollbar{height:5px;}
  .share-grid::-webkit-scrollbar-thumb{background:#c3ced8;border-radius:3px;}
  .share-btn{flex:0 0 auto;min-width:138px;padding:8px 12px;border-radius:14px;font-size:.72rem;gap:8px;scroll-snap-align:start;}
  .share-btn svg{width:18px;height:18px;}
}
.share-btn{--_bg:#fff;--_color:#1d2733;display:flex;align-items:center;gap:12px;padding:10px 16px;border:1px solid var(--c-border);
  background:var(--_bg);color:var(--_color);border-radius:16px;font-weight:600;font-size:.82rem;position:relative;overflow:hidden;
  transition:background var(--transition),box-shadow var(--transition),transform var(--transition);line-height:1.12;}
.share-btn svg{width:24px;height:24px;flex:0 0 24px;}
.share-btn::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,rgba(23,125,255,.12),rgba(18,184,134,.12));opacity:0;transition:opacity var(--transition);pointer-events:none;}
.share-btn:hover{box-shadow:var(--shadow-md);transform:translateY(-3px);text-decoration:none;}
.share-btn:hover::after{opacity:1;}
.share-btn:active{transform:translateY(-1px);}
.share-btn.copy.copied{border-color:var(--c-accent);}
.copy-status{margin-left:auto;font-size:.55rem;font-weight:700;letter-spacing:.15em;color:var(--c-accent);opacity:0;transition:opacity .25s;}
.share-btn.copy.copied .copy-status{opacity:1;}
.share-btn::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;border-radius:16px 0 0 16px;background:var(--c-primary);opacity:.85;pointer-events:none;}
.share-btn[data-platform="facebook"]::before{background:#1877f2;}
.share-btn[data-platform="x"]::before{background:#000;}
.share-btn[data-platform="linkedin"]::before{background:#0a66c2;}
.share-btn[data-platform="reddit"]::before{background:#ff4500;}
.share-btn[data-platform="whatsapp"]::before{background:#25d366;}
.share-btn[data-platform="telegram"]::before{background:#229ed9;}
.share-btn[data-platform="pinterest"]::before{background:#bd081c;}
.share-btn.copy::before{background:linear-gradient(180deg,#177dff,#12b886);}

/* ---------- SUBSCRIBE BOX ---------- */
.subscribe-box{margin-top:46px;background:var(--c-gradient);color:#fff;padding:40px 40px 44px;border-radius:18px;
  position:relative;overflow:hidden;box-shadow:var(--shadow-sm);}
.subscribe-box::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 78% 18%,rgba(255,255,255,.22),transparent 60%);pointer-events:none;}
.subscribe-box h2{margin:0 0 10px;font-size:1.65rem;line-height:1.18;}
.subscribe-box p.desc{margin:0 0 24px;font-size:.98rem;max-width:620px;}
.subscribe-form{display:flex;flex-wrap:wrap;gap:12px;align-items:center;}
.subscribe-form input{flex:1 1 240px;min-width:0;padding:12px 16px;border:none;border-radius:14px;font-size:.95rem;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.45);background:rgba(255,255,255,.16);color:#fff;}
.subscribe-form input::placeholder{color:rgba(255,255,255,.75);}
.subscribe-form input:focus-visible{box-shadow:0 0 0 3px rgba(255,255,255,.55);}
.subscribe-form button{background:#fff;color:#12304d;font-weight:700;padding:12px 26px;border-radius:14px;letter-spacing:.08em;
  font-size:.75rem;box-shadow:var(--shadow-sm);transition:background var(--transition),color var(--transition),transform var(--transition);}
.subscribe-form button:hover{background:#eef6ff;}
.subscribe-form button:active{transform:translateY(1px);}
#subscribeMsg{margin:10px 0 0;font-size:.68rem;font-weight:600;letter-spacing:.12em;}
#subscribeMsg.success{color:#c2ffd6;}
#subscribeMsg.error{color:#ffe5d6;}
@media (max-width:640px){
  .subscribe-box{padding:30px var(--mobile-pad-tight) 34px;border-radius:14px;}
  .subscribe-box h2{font-size:1.4rem;}
}

/* ---------- RECOMMENDED CARDS ---------- */
.recommend-cards{margin-top:46px;background:var(--c-surface);padding:28px 30px 34px;border-radius:18px;box-shadow:var(--shadow-sm);}
.recommend-cards h2{margin:0 0 20px;font-size:1.3rem;letter-spacing:.4px;}
.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:20px;}
.card-grid a{display:block;}
.card{background:#fff;border:1px solid var(--c-border);border-radius:16px;overflow:hidden;position:relative;
  transition:box-shadow var(--transition),transform var(--transition);display:flex;flex-direction:column;height:100%;}
.card:hover{box-shadow:var(--shadow-hover);transform:translateY(-5px);text-decoration:none;}
.card img{width:100%;height:220px;object-fit:cover;}
@media (max-width:900px){.card img{height:200px;}}
@media (max-width:640px){
  .recommend-cards{padding:24px var(--mobile-pad-tight) 28px;border-radius:14px;}
  .card img{height:210px;}
}
.card h3{font-size:1.08rem;line-height:1.28;margin:14px 14px 8px;color:var(--c-text);font-weight:600;}
.card p{margin:0 14px 16px;font-size:.72rem;line-height:1.3;color:var(--c-text-soft);}

/* ---------- COMMENTS ---------- */
.comments{margin-top:46px;background:var(--c-surface);padding:30px 32px 38px;border-radius:18px;box-shadow:var(--shadow-sm);}
.comments h2{margin:0 0 22px;font-size:1.3rem;}
.comment-item{padding:14px 0;border-bottom:1px solid var(--c-border-soft);}
.comment-item:last-child{border-bottom:none;}
.comment-item .c-head{font-size:.68rem;font-weight:600;letter-spacing:.1em;color:var(--c-text-soft);margin:0 0 4px;}
.comment-item .c-body{margin:0;font-size:.9rem;color:var(--c-text);}
.comment-form{margin-top:34px;}
.comment-form h3{margin:0 0 14px;font-size:1.05rem;}
.comment-form .form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:14px;}
.comment-form input,.comment-form textarea{width:100%;padding:12px 14px;border:1px solid var(--c-border);border-radius:12px;
  font-size:.9rem;background:#fff;transition:border-color var(--transition),box-shadow var(--transition);}
.comment-form textarea{min-height:140px;resize:vertical;grid-column:1/-1;}
.comment-form input:focus-visible,.comment-form textarea:focus-visible{border-color:var(--c-primary);box-shadow:0 0 0 3px rgba(23,125,255,.25);}
.comment-form button{background:var(--c-primary);color:#fff;font-weight:600;padding:12px 24px;border-radius:14px;font-size:.75rem;
  letter-spacing:.08em;transition:background var(--transition),transform var(--transition);box-shadow:var(--shadow-sm);}
.comment-form button:hover{background:var(--c-primary-alt);}
.comment-form button:active{transform:translateY(1px);}
#commentMsg{margin:12px 0 0;font-size:.62rem;font-weight:700;letter-spacing:.12em;}
#commentMsg.success{color:var(--c-accent);}
#commentMsg.error{color:var(--c-danger);}
@media (max-width:680px){.comment-form .form-grid{grid-template-columns:1fr;}}
@media (max-width:640px){.comments{padding:26px var(--mobile-pad-tight) 32px;border-radius:14px;}}

/* ---------- SIDEBAR ---------- */
.sidebar{display:flex;flex-direction:column;gap:40px;}
.side-widget{background:var(--c-surface);padding:26px 24px 30px;border-radius:18px;box-shadow:var(--shadow-sm);position:relative;}
.side-widget h2{margin:0 0 16px;font-size:.95rem;letter-spacing:.15em;font-weight:700;color:var(--c-text-soft);}
.popular-list{display:grid;grid-template-columns:1fr;gap:16px;}
.popular-item{display:block;border:1px solid var(--c-border);border-radius:14px;overflow:hidden;background:#fff;
  transition:transform var(--transition),box-shadow var(--transition);}
.popular-item:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);text-decoration:none;}
.popular-item img{width:100%;height:160px;object-fit:cover;}
@media (max-width:1100px){.popular-item img{height:180px;}}
@media (max-width:640px){
  .sidebar{flex-direction:column;gap:34px;overflow:visible;}
  .side-widget{min-width:0;padding:24px var(--mobile-pad-tight) 26px;border-radius:14px;}
  .popular-item img{height:200px;}
  .popular-item h3{font-size:.95rem;margin:10px 12px 6px;}
}
.popular-item h3{margin:12px 14px 8px;font-size:1rem;line-height:1.32;color:var(--c-text);font-weight:600;}
.popular-item p{margin:0 14px 14px;font-size:.62rem;letter-spacing:.05em;text-transform:uppercase;font-weight:600;color:var(--c-text-soft);}
@media (max-width:1100px){
  .sidebar{flex-direction:row;overflow-x:auto;padding-bottom:4px;scroll-snap-type:x mandatory;gap:20px;}
  .side-widget{min-width:280px;scroll-snap-align:start;}
}

/* ---------- FOOTER ---------- */
footer{margin-top:70px;background:#101a24;color:#d9e2ec;padding:60px 0 66px;position:relative;}
footer::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 72% 18%,rgba(23,125,255,.28),transparent 70%);pointer-events:none;}
.footer-inner{max-width:var(--content-max);margin:0 auto;padding:0 24px;display:flex;flex-direction:column;align-items:center;gap:34px;}
@media (max-width:640px){.footer-inner{padding:0 var(--mobile-pad);gap:28px;}}
.footer-brand{display:flex;align-items:center;gap:12px;font-size:1.15rem;font-weight:600;color:#fff;}
.footer-brand svg{width:48px;height:48px;}
.footer-subscribe form{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;}
.footer-subscribe input{padding:12px 16px;border-radius:14px;border:1px solid rgba(255,255,255,.4);background:rgba(255,255,255,.10);
  color:#fff;min-width:240px;font-size:.9rem;}
.footer-subscribe input::placeholder{color:rgba(255,255,255,.6);}
.footer-subscribe input:focus-visible{border-color:#fff;box-shadow:0 0 0 3px rgba(255,255,255,.45);}
.footer-subscribe button{background:#fff;color:#13283a;font-weight:700;padding:12px 24px;border-radius:14px;font-size:.72rem;letter-spacing:.08em;
  transition:background var(--transition),transform var(--transition);}
.footer-subscribe button:hover{background:#e6f1ff;}
.footer-subscribe button:active{transform:translateY(1px);}
#footerSubMsg{margin-top:6px;font-size:.58rem;font-weight:700;letter-spacing:.12em;}
#footerSubMsg.success{color:#9cf7c6;}
#footerSubMsg.error{color:#ffc9c9;}
.footer-links{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;max-width:980px;}
.footer-links a{font-size:0.8em;letter-spacing:.09em;text-transform:uppercase;font-weight:600;color:#d0ddea;position:relative;padding:4px 4px;}
.footer-links a:hover{color:#fff;text-decoration:none;}

/* ---------- DECORATIVE SAFEGUARD ---------- */
.article::before,
.author-box::after,
.share-btn::after,
.share-btn::before,
.footer::before,
.recommend-cards::before,
.subscribe-box::after,
.share-section::before,
.card::before{pointer-events:none;}

/* ---------- ACCESSIBILITY & MOTION ---------- */
.visually-hidden{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden;}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none !important;transition:none !important;scroll-behavior:auto !important;}
}

/* ---------- OPTIONAL AD SLOT ---------- */
.ad-slot{margin:40px 0 0;background:#ffffff;border:1px dashed var(--c-border);border-radius:14px;padding:20px;text-align:center;font-size:.7rem;
  letter-spacing:.12em;color:#5c6d7e;}
.ad-slot .label{display:inline-block;font-weight:700;margin-bottom:4px;color:#677b8f;}



.hero-section{
  background:var(--c-gradient);
  color:#fff;
  padding:60px 40px 70px;
  border-radius:18px;
  position:relative;
  overflow:hidden;
  box-shadow:var(--shadow-sm);
  margin-bottom:50px;
}
.hero-section::after{
  content:"";
  position:absolute;
  inset:0;
  background:radial-gradient(circle at 78% 18%,rgba(255,255,255,.22),transparent 60%);
  pointer-events:none;
}
.hero-content{
  max-width:800px;
  position:relative;
  z-index:1;
}
.hero-section h1{
  font-size:3.2rem;
  line-height:1.1;
  margin:0 0 20px;
  font-weight:800;
}
.hero-section p{
  font-size:1.2rem;
  margin:0 0 30px;
  opacity:0.95;
  max-width:600px;
}
.hero-cta{
  display:inline-flex;
  align-items:center;
  gap:12px;
  background:#fff;
  color:#12304d;
  font-weight:700;
  padding:16px 32px;
  border-radius:50px;
  font-size:1rem;
  letter-spacing:.05em;
  box-shadow:var(--shadow-md);
  transition:all var(--transition);
}
.hero-cta:hover{
  background:#eef6ff;
  transform:translateY(-2px);
  box-shadow:var(--shadow-hover);
  text-decoration:none;
}

.search-section{
  background:var(--c-surface);
  padding:40px;
  border-radius:18px;
  box-shadow:var(--shadow-sm);
  margin-bottom:50px;
}
.search-section h2{
  margin:0 0 20px;
  font-size:1.8rem;
  text-align:center;
}
.search-form{
  display:flex;
  gap:12px;
  max-width:600px;
  margin:0 auto;
}
.search-form input{
  flex:1;
  padding:16px 20px;
  border:2px solid var(--c-border);
  border-radius:50px;
  font-size:1rem;
  transition:border-color var(--transition);
}
.search-form input:focus{
  border-color:var(--c-primary);
  outline:none;
}
.search-form button{
  background:var(--c-primary);
  color:#fff;
  padding:16px 30px;
  border-radius:50px;
  font-weight:600;
  font-size:1rem;
  transition:background var(--transition);
}
.search-form button:hover{
  background:var(--c-primary-alt);
}

.featured-section{
  background:var(--c-surface);
  padding:40px;
  border-radius:18px;
  box-shadow:var(--shadow-sm);
  margin-bottom:50px;
}
.featured-section h2{
  margin:0 0 30px;
  font-size:2rem;
  text-align:center;
}
.featured-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(300px,1fr));
  gap:30px;
}
.featured-card{
  background:#fff;
  border:1px solid var(--c-border);
  border-radius:16px;
  overflow:hidden;
  transition:all var(--transition);
}
.featured-card:hover{
  transform:translateY(-8px);
  box-shadow:var(--shadow-hover);
  text-decoration:none;
}
.featured-card img{
  width:100%;
  height:200px;
  object-fit:cover;
}
.featured-card-content{
  padding:20px;
}
.featured-card h3{
  margin:0 0 10px;
  font-size:1.3rem;
  color:var(--c-text);
}
.featured-card p{
  margin:0 0 15px;
  color:var(--c-text-soft);
  font-size:0.95rem;
  line-height:1.5;
}
.featured-card .meta{
  font-size:0.8rem;
  color:var(--c-text-soft);
  margin:0;
}

.categories-section{
  background:var(--c-surface);
  padding:40px;
  border-radius:18px;
  box-shadow:var(--shadow-sm);
  margin-bottom:50px;
}
.categories-section h2{
  margin:0 0 30px;
  font-size:2rem;
  text-align:center;
}
.categories-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
  gap:20px;
}
.category-card{
  background:var(--c-gradient);
  color:#fff;
  padding:30px 20px;
  border-radius:16px;
  text-align:center;
  transition:all var(--transition);
  position:relative;
  overflow:hidden;
}
.category-card::before{
  content:"";
  position:absolute;
  inset:0;
  background:radial-gradient(circle at 50% 50%,rgba(255,255,255,.15),transparent 70%);
  pointer-events:none;
}
.category-card:hover{
  transform:translateY(-5px);
  box-shadow:var(--shadow-hover);
  text-decoration:none;
}
.category-card h3{
  margin:0 0 10px;
  font-size:1.4rem;
  position:relative;
  z-index:1;
}
.category-card p{
  margin:0;
  opacity:0.9;
  position:relative;
  z-index:1;
}

.latest-section{
  background:var(--c-surface);
  padding:40px;
  border-radius:18px;
  box-shadow:var(--shadow-sm);
  margin-bottom:50px;
}
.latest-section h2{
  margin:0 0 30px;
  font-size:2rem;
  text-align:center;
}
.latest-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:25px;
}
.latest-card{
  display:flex;
  background:#fff;
  border:1px solid var(--c-border);
  border-radius:12px;
  overflow:hidden;
  transition:all var(--transition);
}
.latest-card:hover{
  transform:translateY(-3px);
  box-shadow:var(--shadow-md);
  text-decoration:none;
}
.latest-card img{
  width:120px;
  height:100px;
  object-fit:cover;
  flex-shrink:0;
}
.latest-card-content{
  padding:15px;
  flex:1;
}
.latest-card h3{
  margin:0 0 8px;
  font-size:1rem;
  color:var(--c-text);
  line-height:1.3;
}
.latest-card p{
  margin:0;
  font-size:0.8rem;
  color:var(--c-text-soft);
}

@media (max-width:640px){
  .hero-section{
    padding:40px var(--mobile-pad) 50px;
    margin-bottom:40px;
  }
  .hero-section h1{
    font-size:2.2rem;
  }
  .hero-section p{
    font-size:1rem;
  }
  .search-section, .featured-section, .categories-section, .latest-section{
    padding:30px var(--mobile-pad);
    margin-bottom:40px;
  }
  .search-form{
    flex-direction:column;
  }
  .featured-grid{
    grid-template-columns:1fr;
    gap:20px;
  }
  .categories-grid{
    grid-template-columns:repeat(auto-fit,minmax(150px,1fr));
    gap:15px;
  }
  .latest-card{
    flex-direction:column;
  }
  .latest-card img{
    width:100%;
    height:150px;
  }
}






.keyboard-nav *:focus {
  outline: 2px solid #46b3ff !important;
  outline-offset: 2px !important;
}

.skip-link:focus {
  top: 6px !important;
}



.dark-theme {
  --c-bg: #0f172a;
  --c-surface: #1e293b;
  --c-text: #f1f5f9;
  --c-text-soft: #cbd5e1;
  --c-border: #334155;
}

.dark-theme .hero-section {
  background: linear-gradient(135deg, #1e293b 0%, #334155 100%);
}

.dark-theme .featured-card,
.dark-theme .latest-card {
  background: var(--c-surface);
  border-color: var(--c-border);
}

.dark-theme .featured-card h3,
.dark-theme .latest-card h3 {
  color: var(--c-text);
}



@media (max-width: 480px) {
  .hero-section h1 {
    font-size: 1.8rem;
  }
  
  .hero-section p {
    font-size: 0.9rem;
  }
  
  .hero-cta {
    padding: 12px 24px;
    font-size: 0.9rem;
  }
  
  .categories-grid {
    grid-template-columns: 1fr;
  }
  
  .latest-grid {
    grid-template-columns: 1fr;
  }
}



@media print {
  .site-header,
  .m-menu,
  .sidebar,
  footer,
  .hero-cta,
  .subscribe-box,
  .search-section {
    display: none !important;
  }
  
  .site-wrap {
    max-width: none;
    padding: 0;
  }
  
  .hero-section {
    background: none !important;
    color: #000 !important;
    box-shadow: none !important;
  }
  
  a {
    color: #000 !important;
    text-decoration: underline !important;
  }
  
  .featured-card,
  .latest-card {
    break-inside: avoid;
    border: 1px solid #ccc !important;
    box-shadow: none !important;
  }
}