/* ==========================================================================
   cas_editorial — Magazine Editorial Casino Template
   Layer: tokens > reset > utilities > layout > components > pages > responsive
   ========================================================================== */

:root {
    --t-bg:        #fffaf2;
    --t-surface:   #ffffff;
    --t-surface-2: #fdf6e9;
    --t-fg:        #2a1f1a;
    --t-muted:     #7a7068;
    --t-accent:    #c94b3b;
    --t-accent-2:  #1a4a3a;
    --t-accent-3:  #8b6914;
    --t-line:      #e8dfd2;
    --t-line-2:    rgba(201, 75, 59, 0.2);
    --t-font-display: 'Crimson Pro','Noto Serif Thai',Georgia,serif;
    --t-font-body:    'Crimson Pro','Noto Sans Thai',Georgia,serif;
    --t-font-mono:    'Noto Sans Thai',system-ui,sans-serif;
    --t-radius:    0px;
    --t-radius-lg: 0px;
    --t-shadow:      none;
    --t-shadow-hard: none;
    --t-glow:        0 0 0 1px var(--t-accent);
    --t-motion:      300ms ease;
    --t-motion-slow: 600ms ease;
}

*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body { background: var(--t-bg); color: var(--t-fg); font-family: var(--t-font-body); font-size: 16px; line-height: 1.65; -webkit-font-smoothing: antialiased; min-height: 100vh; overflow-x: hidden; }
a { color: inherit; text-decoration: none; transition: color var(--t-motion); }
a:hover { color: var(--t-accent); }
img { max-width: 100%; display: block; }
h1, h2, h3, h4, h5, h6 { margin: 0 0 .5em; font-family: var(--t-font-display); letter-spacing: .02em; }
p { margin: 0 0 1em; }
ul, ol { padding-left: 1.2em; }
button { font: inherit; cursor: pointer; border: 0; background: transparent; color: inherit; }

.edt-scope { position: relative; }
.edt-bg-grid { position: fixed; inset: 0; z-index: 0; pointer-events: none; background-image: linear-gradient(rgba(0,255,213,.06) 1px, transparent 1px), linear-gradient(90deg, rgba(0,255,213,.06) 1px, transparent 1px); background-size: 44px 44px; mask-image: radial-gradient(ellipse at 50% 0%, #000 40%, transparent 85%); }
.edt-bg-scan { position: fixed; inset: 0; z-index: 0; pointer-events: none; background: linear-gradient(180deg, transparent, rgba(0,255,213,.04) 50%, transparent); background-size: 100% 6px; animation: cyb-scan 8s linear infinite; opacity: .5; }
@keyframes cyb-scan { 0% { background-position: 0 0; } 100% { background-position: 0 400px; } }
.edt-main { position: relative; z-index: 1; }

/* ===== Utilities (u-*) ================================================ */
.u-container { max-width: 1240px; margin: 0 auto; padding: 0 24px; position: relative; z-index: 1; }
.u-flex       { display: flex; }
.u-flex-center  { display: flex; align-items: center; justify-content: center; }
.u-flex-between { display: flex; align-items: center; justify-content: space-between; }
.u-flex-col   { display: flex; flex-direction: column; }
.u-wrap       { flex-wrap: wrap; }
.u-gap-1{gap:4px}.u-gap-2{gap:8px}.u-gap-3{gap:12px}.u-gap-4{gap:16px}.u-gap-5{gap:20px}.u-gap-6{gap:24px}.u-gap-8{gap:32px}.u-gap-10{gap:40px}
.u-grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.u-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.u-grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.u-grid-auto{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px}
.u-p-0{padding:0}.u-p-4{padding:16px}.u-p-6{padding:24px}.u-p-8{padding:32px}
.u-py-10{padding-top:40px;padding-bottom:40px}.u-py-16{padding-top:64px;padding-bottom:64px}.u-py-20{padding-top:80px;padding-bottom:80px}
.u-mt-0{margin-top:0}.u-mt-4{margin-top:16px}.u-mt-8{margin-top:32px}
.u-mb-4{margin-bottom:16px}.u-mb-8{margin-bottom:32px}.u-mb-12{margin-bottom:48px}
.u-text-hero{font-family:var(--t-font-display);font-size:clamp(38px,6vw,76px);font-weight:900;line-height:1.05;letter-spacing:.01em}
.u-text-display{font-family:var(--t-font-display);font-size:clamp(28px,3vw,42px);font-weight:800;line-height:1.15}
.u-text-title{font-family:var(--t-font-display);font-size:22px;font-weight:700}
.u-text-meta{font-family:var(--t-font-mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--t-muted)}
.u-uppercase{text-transform:uppercase}.u-tracking-wide{letter-spacing:.12em}
.u-bg-surface{background:var(--t-surface)}.u-bg-accent{background:var(--t-accent);color:#05060d}.u-fg-muted{color:var(--t-muted)}
.u-rounded-sm{border-radius:6px}.u-rounded-md{border-radius:var(--t-radius)}.u-rounded-lg{border-radius:var(--t-radius-lg)}.u-rounded-full{border-radius:999px}
.u-border{border:1px solid var(--t-line)}
.u-shadow-soft{box-shadow:var(--t-shadow)}.u-shadow-hard{box-shadow:var(--t-shadow-hard)}.u-shadow-glow{box-shadow:var(--t-glow)}
.u-transition{transition:transform var(--t-motion),box-shadow var(--t-motion),border-color var(--t-motion),color var(--t-motion)}
.u-hover-lift:hover{transform:translateY(-4px)}.u-hover-glow:hover{box-shadow:var(--t-glow);border-color:var(--t-accent)}
.u-section{padding:72px 0;position:relative}.u-section--tight{padding:48px 0}

/* ===== Components (cyb-*) ============================================= */
.edt-nav{position:sticky;top:0;z-index:40;background:rgba(13,16,36,.65);backdrop-filter:blur(12px) saturate(160%);-webkit-backdrop-filter:blur(12px) saturate(160%);border-bottom:1px solid var(--t-line)}
.edt-nav__inner{display:flex;align-items:center;justify-content:space-between;height:72px}
.edt-nav__logo{display:flex;align-items:center;gap:10px;font-family:var(--t-font-display);font-weight:800;letter-spacing:.1em}
.edt-nav__logo img,.edt-nav__logo mip-img{height:36px;width:auto}
.edt-nav__list{display:flex;align-items:center;gap:28px;list-style:none;margin:0;padding:0}
.edt-nav__link{position:relative;padding:8px 2px;font-family:var(--t-font-mono);font-size:13px;letter-spacing:.12em;text-transform:uppercase;color:var(--t-muted)}
.edt-nav__link::after{content:'';position:absolute;left:0;bottom:0;height:2px;width:0;background:linear-gradient(90deg,var(--t-accent),var(--t-accent-2));box-shadow:0 0 12px var(--t-accent);transition:width var(--t-motion)}
.edt-nav__link:hover,.edt-nav__link.is-active{color:var(--t-fg)}
.edt-nav__link:hover::after,.edt-nav__link.is-active::after{width:100%}
.edt-nav__toggle{display:none;width:44px;height:44px;border:1px solid var(--t-line);border-radius:var(--t-radius)}
.edt-nav__toggle span,.edt-nav__toggle span::before,.edt-nav__toggle span::after{display:block;width:20px;height:2px;background:var(--t-accent);position:relative}
.edt-nav__toggle span{margin:auto}.edt-nav__toggle span::before{content:'';position:absolute;top:-6px;left:0}.edt-nav__toggle span::after{content:'';position:absolute;top:6px;left:0;background:var(--t-accent-2)}
.edt-drawer{position:fixed;inset:0 30% 0 0;background:var(--t-surface);border-right:1px solid var(--t-line);transform:translateX(-100%);transition:transform var(--t-motion-slow);z-index:60;overflow-y:auto}
.edt-drawer.is-open{transform:translateX(0)}
.edt-drawer__head{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--t-line)}
.edt-drawer__list{list-style:none;margin:0;padding:12px 0}
.edt-drawer__list li a{display:block;padding:14px 24px;border-bottom:1px dashed rgba(142,160,189,.15);font-family:var(--t-font-mono);letter-spacing:.08em;text-transform:uppercase;font-size:13px}
.edt-drawer__list li a.is-active,.edt-drawer__list li a:hover{color:var(--t-accent);background:rgba(0,255,213,.05)}
.edt-drawer__cta{padding:24px;display:grid;gap:12px}
.edt-overlay{position:fixed;inset:0;background:rgba(5,6,13,.7);opacity:0;pointer-events:none;transition:opacity var(--t-motion);z-index:50}
.edt-overlay.is-open{opacity:1;pointer-events:auto}

.edt-btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:14px 26px;border-radius:var(--t-radius);font-family:var(--t-font-mono);font-size:13px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;transition:all var(--t-motion);cursor:pointer;border:1px solid transparent}
.edt-btn--primary{background:linear-gradient(135deg,var(--t-accent),var(--t-accent-3));color:#05060d}
.edt-btn--primary:hover{box-shadow:0 0 30px rgba(0,255,213,.6);transform:translateY(-2px);color:#05060d}
.edt-btn--ghost{border-color:var(--t-line);color:var(--t-fg)}
.edt-btn--ghost:hover{border-color:var(--t-accent);color:var(--t-accent)}
.edt-btn--pink{background:linear-gradient(135deg,var(--t-accent-2),var(--t-accent-3));color:#fff}
.edt-btn--pink:hover{box-shadow:0 0 30px rgba(255,46,175,.6);transform:translateY(-2px)}
.edt-btn--lg{padding:16px 32px;font-size:14px}

.edt-hero{padding:96px 0 72px;position:relative}
.edt-hero__badge{display:inline-flex;align-items:center;gap:10px;padding:8px 18px;border-radius:999px;background:rgba(0,255,213,.08);border:1px solid var(--t-line);font-family:var(--t-font-mono);font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--t-accent)}
.edt-hero__title{margin-top:24px;font-family:var(--t-font-display);font-size:clamp(38px,6vw,72px);font-weight:900;line-height:1.06;background:linear-gradient(90deg,#e6f4ff 0%,var(--t-accent) 50%,var(--t-accent-2) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.edt-hero__lead{max-width:720px;margin-top:18px;color:var(--t-muted);font-size:17px;line-height:1.8}
.edt-hero__cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:32px}

.edt-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:48px}
.edt-stat{position:relative;padding:22px 20px;background:linear-gradient(160deg,rgba(0,255,213,.06),rgba(255,46,175,.03));border:1px solid var(--t-line);border-radius:var(--t-radius-lg);overflow:hidden}
.edt-stat::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent,rgba(0,255,213,.05) 50%,transparent);background-size:100% 4px;animation:cyb-scan 4s linear infinite;pointer-events:none}
.edt-stat__label{font-family:var(--t-font-mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--t-muted)}
.edt-stat__value{display:block;margin-top:10px;font-family:var(--t-font-display);font-size:36px;font-weight:800;color:var(--t-accent)}
.edt-stat__note{font-size:12px;color:var(--t-muted)}

.edt-section-title{text-align:center;margin-bottom:56px}
.edt-section-title__eyebrow{font-family:var(--t-font-mono);font-size:12px;letter-spacing:.3em;text-transform:uppercase;color:var(--t-accent)}
.edt-section-title__h{font-family:var(--t-font-display);font-size:clamp(28px,3.5vw,44px);font-weight:800;margin:12px 0 10px}
.edt-section-title__p{color:var(--t-muted);max-width:640px;margin:0 auto}

.edt-card{position:relative;padding:28px;background:var(--t-surface);border:1px solid var(--t-line);border-radius:var(--t-radius-lg);transition:transform var(--t-motion),box-shadow var(--t-motion),border-color var(--t-motion);overflow:hidden}
.edt-card:hover{transform:translateY(-6px);border-color:var(--t-accent);box-shadow:var(--t-glow)}
.edt-card__icon{width:56px;height:56px;border-radius:14px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,rgba(0,255,213,.15),rgba(255,46,175,.15));border:1px solid var(--t-line);font-size:26px;margin-bottom:18px}
.edt-card__title{font-family:var(--t-font-display);font-size:20px;font-weight:700;margin-bottom:10px}
.edt-card__text{color:var(--t-muted);font-size:14px;line-height:1.75}

.edt-game{position:relative;background:var(--t-surface);border:1px solid var(--t-line);border-radius:var(--t-radius-lg);overflow:hidden;transition:transform var(--t-motion),border-color var(--t-motion),box-shadow var(--t-motion)}
.edt-game::before{content:'';position:absolute;top:0;left:0;right:0;height:28px;background:var(--t-surface-2);border-bottom:1px solid var(--t-line)}
.edt-game::after{content:'\25CF \25CF \25CF';position:absolute;top:6px;left:12px;color:var(--t-accent);font-size:10px;letter-spacing:4px}
.edt-game__media{margin-top:28px;aspect-ratio:16/10;overflow:hidden}
.edt-game__media img,.edt-game__media mip-img{width:100%;height:100%;object-fit:cover;transition:transform var(--t-motion-slow)}
.edt-game:hover .edt-game__media img{transform:scale(1.08)}
.edt-game:hover{transform:translateY(-6px);border-color:var(--t-accent);box-shadow:var(--t-glow)}
.edt-game__body{padding:20px 22px 24px}
.edt-game__title{font-family:var(--t-font-display);font-size:18px;font-weight:700;margin-bottom:8px}
.edt-game__title a:hover{color:var(--t-accent)}
.edt-game__text{color:var(--t-muted);font-size:13px;line-height:1.7}

.edt-news{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}
.edt-news__item{background:var(--t-surface);border:1px solid var(--t-line);border-radius:var(--t-radius-lg);overflow:hidden;transition:border-color var(--t-motion),transform var(--t-motion),box-shadow var(--t-motion);display:flex;flex-direction:column}
.edt-news__item:hover{border-color:var(--t-accent-2);transform:translateY(-4px);box-shadow:0 0 30px rgba(255,46,175,.25)}
.edt-news__media{aspect-ratio:16/9;overflow:hidden;position:relative}
.edt-news__media::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(5,6,13,.7) 100%)}
.edt-news__body{padding:20px 22px;display:flex;flex-direction:column;flex:1}
.edt-news__title{font-family:var(--t-font-display);font-size:17px;font-weight:700;margin-bottom:10px;line-height:1.4}
.edt-news__excerpt{color:var(--t-muted);font-size:13px;line-height:1.7;margin-bottom:16px;flex:1}
.edt-news__meta{display:flex;justify-content:space-between;color:var(--t-muted);font-family:var(--t-font-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;border-top:1px dashed rgba(142,160,189,.2);padding-top:12px}

.edt-longform{background:linear-gradient(160deg,rgba(13,16,36,.9),rgba(18,22,52,.9));border:1px solid var(--t-line);border-radius:var(--t-radius-lg);padding:56px clamp(24px,4vw,64px)}
.edt-longform h2{font-size:clamp(26px,3vw,38px);color:var(--t-accent);margin-bottom:18px}
.edt-longform h3{font-size:22px;color:var(--t-accent-2);margin:28px 0 12px}
.edt-longform p{color:var(--t-muted);line-height:1.85}
.edt-longform ul{color:var(--t-muted)}.edt-longform li{margin-bottom:10px}

.edt-faq{display:grid;gap:14px}
.edt-faq__item{background:var(--t-surface);border:1px solid var(--t-line);border-radius:var(--t-radius);padding:20px 24px;transition:border-color var(--t-motion)}
.edt-faq__item:hover{border-color:var(--t-accent)}
.edt-faq__q{display:flex;justify-content:space-between;align-items:center;font-family:var(--t-font-mono);color:var(--t-accent);letter-spacing:.08em}
.edt-faq__q::before{content:'>';color:var(--t-accent-2);margin-right:10px}
.edt-faq__a{margin-top:10px;color:var(--t-muted);font-size:14px;line-height:1.8;padding-left:18px;border-left:1px dashed var(--t-line)}

.edt-footer{position:relative;z-index:1;margin-top:80px;background:var(--t-surface);border-top:1px solid var(--t-line);padding:64px 0 24px}
.edt-footer__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:40px;margin-bottom:40px}
.edt-footer__title{font-family:var(--t-font-display);color:var(--t-accent);font-size:15px;letter-spacing:.1em;text-transform:uppercase;margin-bottom:18px}
.edt-footer__links{display:flex;flex-wrap:wrap;gap:10px 18px}
.edt-footer__links a{color:var(--t-muted);font-size:14px;transition:color var(--t-motion)}
.edt-footer__links a:hover{color:var(--t-accent)}
.edt-footer__bottom{border-top:1px solid var(--t-line);padding-top:24px;display:flex;flex-wrap:wrap;justify-content:space-between;gap:12px;color:var(--t-muted);font-family:var(--t-font-mono);font-size:12px;letter-spacing:.08em}

.edt-article-hero{padding:80px 0 40px}
.edt-article-hero h1{font-family:var(--t-font-display);font-size:clamp(30px,4vw,52px);background:linear-gradient(90deg,var(--t-accent),var(--t-accent-2));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.edt-meta-row{display:flex;flex-wrap:wrap;gap:18px;color:var(--t-muted);font-family:var(--t-font-mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;margin-bottom:28px}
.edt-article-cover{border-radius:var(--t-radius-lg);overflow:hidden;border:1px solid var(--t-line);margin-bottom:36px}
.edt-article-body{color:#c9d5e6;font-size:16px;line-height:1.9}
.edt-article-body h2{color:var(--t-accent);font-size:28px;margin:32px 0 12px}
.edt-article-body h3{color:var(--t-accent-2);font-size:22px;margin:24px 0 10px}
.edt-article-body img{border-radius:var(--t-radius);margin:16px 0;border:1px solid var(--t-line)}
.edt-tag{display:inline-flex;align-items:center;padding:6px 14px;border-radius:999px;background:rgba(0,255,213,.08);color:var(--t-accent);font-family:var(--t-font-mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;border:1px solid var(--t-line);margin:6px 6px 0 0;transition:all var(--t-motion)}
.edt-tag:hover{background:var(--t-accent);color:#05060d;box-shadow:0 0 18px var(--t-accent)}

.edt-pagerow{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin:40px 0}
.edt-pagerow a{padding:20px;border:1px solid var(--t-line);border-radius:var(--t-radius);display:flex;gap:16px;align-items:center;color:var(--t-muted);transition:all var(--t-motion)}
.edt-pagerow a:hover{border-color:var(--t-accent);color:var(--t-fg);transform:translateY(-2px)}
.edt-pagerow a.edt-pagerow__next{justify-content:flex-end;text-align:right}
.edt-pagerow small{font-family:var(--t-font-mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--t-accent)}
.edt-pagerow p{margin:4px 0 0;color:var(--t-fg);font-family:var(--t-font-display);font-weight:700}

.edt-pagination ul{display:inline-flex;gap:10px;list-style:none;padding:0;margin:40px 0}
.edt-pagination li a,.edt-pagination li span{display:block;padding:10px 16px;border-radius:var(--t-radius);background:var(--t-surface);border:1px solid var(--t-line);color:var(--t-muted);font-family:var(--t-font-mono);font-size:12px;letter-spacing:.1em;transition:all var(--t-motion)}
.edt-pagination li a:hover,.edt-pagination li.active span{border-color:var(--t-accent);color:var(--t-accent);box-shadow:0 0 16px rgba(0,255,213,.35)}

.edt-sidebar{margin-top:60px;padding:36px;border:1px solid var(--t-line);border-radius:var(--t-radius-lg);background:var(--t-surface)}
.edt-sidebar h3{font-family:var(--t-font-display);color:var(--t-accent);font-size:22px;margin-bottom:24px}
.edt-hot__item{display:flex;gap:14px;padding:14px;border:1px solid transparent;border-radius:var(--t-radius);transition:all var(--t-motion);margin-bottom:10px}
.edt-hot__item:hover{border-color:var(--t-accent);background:rgba(0,255,213,.05);transform:translateX(6px)}
.edt-hot__num{flex-shrink:0;width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,var(--t-accent),var(--t-accent-3));color:#05060d;display:inline-flex;align-items:center;justify-content:center;font-family:var(--t-font-display);font-weight:800}
.edt-hot__title{font-size:14px;color:var(--t-fg);margin-bottom:4px;line-height:1.4}
.edt-hot__date{font-family:var(--t-font-mono);font-size:11px;color:var(--t-muted);letter-spacing:.08em}

.edt-404{min-height:72vh;display:flex;align-items:center;justify-content:center;padding:80px 0}
.edt-404__inner{text-align:center;max-width:720px}
.edt-404__code{font-family:var(--t-font-display);font-size:clamp(100px,18vw,220px);font-weight:900;line-height:1;background:linear-gradient(90deg,var(--t-accent),var(--t-accent-2));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;position:relative;animation:cyb-glitch 2.5s infinite}
@keyframes cyb-glitch{0%,100%{text-shadow:0 0 0 transparent;transform:translate(0,0)}20%{text-shadow:3px 0 var(--t-accent-2),-3px 0 var(--t-accent);transform:translate(-1px,1px)}40%{text-shadow:-2px 0 var(--t-accent-2),2px 0 var(--t-accent);transform:translate(1px,-1px)}60%{text-shadow:2px 2px var(--t-accent-3);transform:translate(0,0)}}
.edt-404 h1{font-size:clamp(22px,3vw,34px);margin-top:12px;color:var(--t-fg)}
.edt-404 p{color:var(--t-muted);margin:12px 0 28px}

@media(max-width:1024px){.u-grid-3{grid-template-columns:repeat(2,1fr)}.u-grid-4{grid-template-columns:repeat(2,1fr)}.edt-stats{grid-template-columns:repeat(2,1fr)}}
@media(max-width:768px){.u-grid-2,.u-grid-3,.u-grid-4{grid-template-columns:1fr}.edt-stats{grid-template-columns:repeat(2,1fr)}.edt-nav__list{display:none}.edt-nav__toggle{display:inline-flex;align-items:center;justify-content:center}.edt-hero{padding:56px 0 40px}.edt-pagerow{grid-template-columns:1fr}.u-section{padding:48px 0}.edt-longform{padding:32px 20px}}
