/*
Theme Name: Dream Fortune
Theme URI: https://example.com/dream-fortune
Author: Dream Fortune
Author URI: https://example.com
Description: ธีมเว็บทำนายฝันและเลขเด็ด สไตล์มงคลทอง-แดง รองรับปลั๊กอิน Dream Fortune Manager (คลังคำทำนาย หวยลาว ตัวกลับเลข) ปรับสี/เนื้อหาได้จากแอดมิน รองรับมือถือเต็มรูปแบบ
Version: 1.2.0
Requires PHP: 7.2
License: GNU General Public License v2 or later
Text Domain: dream-fortune
Tags: thai, blog, custom-colors, custom-menu, featured-images, threaded-comments
*/

:root{
  --df-primary:#b3122a; --df-primary-d:#7a0c1c;
  --df-gold:#d4af37; --df-gold-d:#a8841f;
  --df-bg:#2a0a10; --df-card:#fffdf6; --df-text:#2b1a12; --df-nav:#3d0b14;
  --df-maxw:1140px;
  --df-shadow:0 14px 40px rgba(0,0,0,.16);
  --df-serif:"Chonburi",serif;
  --df-sub:"Trirong",serif;
  --df-body:"Sarabun",-apple-system,sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--df-body);color:var(--df-text);line-height:1.75;
  background:
    radial-gradient(1200px 600px at 50% -10%, rgba(212,175,55,.10), transparent 60%),
    linear-gradient(180deg,#fbf6ec 0%, #f6efe1 100%);
  -webkit-font-smoothing:antialiased;
}
a{color:var(--df-primary);text-decoration:none}
img{max-width:100%;height:auto;display:block}
.dft-container{max-width:var(--df-maxw);margin:0 auto;padding:0 20px}

/* ===== Topbar ===== */
.dft-topbar{background:var(--df-nav);color:#f0d28a;font-size:13px}
.dft-topbar .dft-container{display:flex;justify-content:space-between;align-items:center;height:38px;flex-wrap:wrap;gap:8px}
.dft-topbar a{color:#f0d28a}
.dft-topbar .dft-social a{margin-left:12px;opacity:.85}
.dft-topbar .dft-social a:hover{opacity:1;color:#fff}

/* ===== Header ===== */
.dft-header{
  position:sticky;top:0;z-index:50;
  background:linear-gradient(180deg,var(--df-primary-d),var(--df-primary));
  border-bottom:3px solid var(--df-gold);
  box-shadow:0 4px 18px rgba(122,12,28,.3);
}
.dft-header .dft-container{display:flex;align-items:center;justify-content:space-between;height:74px;gap:16px}
.dft-brand{display:flex;align-items:center;gap:12px;color:#fff;text-decoration:none}
.dft-brand .mark{width:46px;height:46px;border-radius:50%;background:radial-gradient(circle at 30% 30%,var(--df-gold),var(--df-gold-d));display:flex;align-items:center;justify-content:center;font-size:24px;box-shadow:0 3px 10px rgba(0,0,0,.3),inset 0 0 0 2px rgba(255,255,255,.25)}
.dft-brand .name{font-family:var(--df-serif);font-size:24px;color:#fff;letter-spacing:.5px;line-height:1}
.dft-brand .tag{display:block;font-family:var(--df-body);font-size:11px;color:#f0d28a;font-weight:500;margin-top:3px}

.dft-nav{display:flex;align-items:center}
.dft-menu{display:flex;gap:6px;list-style:none;margin:0;padding:0}
.dft-menu li a{display:block;padding:9px 16px;color:#fff;font-weight:600;border-radius:9px;transition:.18s;font-size:15px}
.dft-menu li a:hover,.dft-menu li.current-menu-item a{background:rgba(255,255,255,.14);color:#ffe082}

.dft-burger{display:none;background:none;border:0;cursor:pointer;flex-direction:column;gap:5px;padding:8px}
.dft-burger span{width:26px;height:3px;background:#fff;border-radius:3px;transition:.2s}

/* ===== Hero ===== */
.dft-hero{
  position:relative;color:#fff;text-align:center;overflow:hidden;
  background:
    radial-gradient(900px 400px at 50% 0%, rgba(212,175,55,.22), transparent 60%),
    linear-gradient(160deg,var(--df-nav),var(--df-primary-d) 60%,var(--df-primary));
  padding:64px 20px 78px;
}
.dft-hero::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:60px;background:radial-gradient(60% 100% at 50% 0,transparent 60%, var(--df-gold) 61%, transparent 62%);opacity:.18}
.dft-hero .eyebrow{display:inline-block;font-family:var(--df-sub);letter-spacing:3px;font-size:13px;color:#ffe082;border:1px solid rgba(212,175,55,.5);padding:6px 16px;border-radius:30px;margin-bottom:18px}
.dft-hero h1{font-family:var(--df-serif);font-size:clamp(30px,5vw,52px);line-height:1.25;margin:0 0 14px;text-shadow:0 3px 14px rgba(0,0,0,.35)}
.dft-hero h1 em{font-style:normal;color:#ffe082}
.dft-hero p{max-width:640px;margin:0 auto 26px;font-size:18px;color:#f4e6c8}

/* ===== Sections ===== */
.dft-section{padding:54px 0}
.dft-section.alt{background:linear-gradient(180deg,#fff8ea,#fbf3df)}
.dft-section-head{text-align:center;margin-bottom:30px}
.dft-section-head .kicker{font-family:var(--df-sub);letter-spacing:2px;color:var(--df-gold-d);font-size:14px;font-weight:600}
.dft-section-head h2{font-family:var(--df-serif);font-size:clamp(24px,3.5vw,34px);color:var(--df-primary-d);margin:6px 0 0}
.dft-section-head p{color:#7c6a55;margin:8px auto 0;max-width:560px}

.dft-tools{display:grid;grid-template-columns:1.3fr 1fr;gap:24px;align-items:start}
.dft-tools .full{grid-column:1/-1}

/* ===== Dream grid (archive/home) ===== */
.dft-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:20px}
.dft-card{background:var(--df-card);border:1px solid rgba(212,175,55,.3);border-radius:16px;overflow:hidden;box-shadow:0 8px 22px rgba(43,26,18,.08);transition:.2s;display:flex;flex-direction:column}
.dft-card:hover{transform:translateY(-5px);box-shadow:var(--df-shadow);border-color:var(--df-gold)}
.dft-card .thumb{aspect-ratio:16/10;background:linear-gradient(135deg,var(--df-primary-d),var(--df-primary));display:flex;align-items:center;justify-content:center;font-size:46px}
.dft-card .body{padding:18px;display:flex;flex-direction:column;gap:10px;flex:1}
.dft-card .cat{font-size:12px;color:var(--df-gold-d);font-weight:700;letter-spacing:1px}
.dft-card h3{font-family:var(--df-sub);font-size:20px;margin:0;color:var(--df-primary-d);line-height:1.35}
.dft-card h3 a{color:inherit}
.dft-card p{margin:0;color:#6c5847;font-size:14.5px;flex:1}
.dft-mininums{display:flex;gap:8px;flex-wrap:wrap}
.dft-mininums b{background:linear-gradient(135deg,var(--df-gold),var(--df-gold-d));color:#3d0b14;padding:4px 11px;border-radius:8px;font-size:15px;letter-spacing:1px}
.dft-mininums b.three{background:linear-gradient(135deg,var(--df-primary),var(--df-primary-d));color:#fff}

/* ===== Single ===== */
.dft-single{max-width:820px;margin:40px auto;background:var(--df-card);border-radius:20px;box-shadow:var(--df-shadow);overflow:hidden;border:1px solid rgba(212,175,55,.3)}
.dft-single .banner{background:linear-gradient(135deg,var(--df-nav),var(--df-primary));color:#fff;padding:40px 36px}
.dft-single .banner .cat{color:#ffe082;font-weight:700;letter-spacing:1px;font-size:13px}
.dft-single .banner h1{font-family:var(--df-serif);font-size:clamp(26px,4vw,40px);margin:10px 0 0;line-height:1.3}
.dft-single .content{padding:32px 36px;font-size:17px;color:#43342a}
.dft-single .content p{margin:0 0 16px}

.dft-nums{margin:8px 36px 32px;background:linear-gradient(135deg,#fff8ea,#fdf1d4);border:1px dashed var(--df-gold);border-radius:16px;padding:22px 24px}
.dft-nums-label{display:block;font-family:var(--df-sub);font-weight:700;color:var(--df-primary-d);margin-bottom:12px;font-size:16px}
.dft-chips{display:flex;gap:10px;flex-wrap:wrap}
.dft-chip{display:inline-flex;align-items:center;justify-content:center;min-width:54px;height:50px;padding:0 14px;background:linear-gradient(135deg,var(--df-gold),var(--df-gold-d));color:#3d0b14;border-radius:12px;font-weight:800;font-size:22px;letter-spacing:2px;box-shadow:0 4px 10px rgba(168,132,31,.3)}
.dft-chip.three{background:linear-gradient(135deg,var(--df-primary),var(--df-primary-d));color:#fff}

/* ===== Archive header ===== */
.dft-archive-head{text-align:center;padding:46px 20px;color:#fff;background:linear-gradient(160deg,var(--df-nav),var(--df-primary))}
.dft-archive-head h1{font-family:var(--df-serif);font-size:clamp(26px,4vw,40px);margin:0}
.dft-archive-head p{color:#f4e6c8;margin:8px 0 0}

/* ===== Pagination ===== */
.dft-pagination{display:flex;justify-content:center;gap:8px;margin:36px 0}
.dft-pagination a,.dft-pagination span{padding:9px 15px;border-radius:9px;background:var(--df-card);border:1px solid rgba(212,175,55,.4);color:var(--df-primary-d);font-weight:600}
.dft-pagination .current{background:var(--df-primary);color:#fff;border-color:var(--df-primary)}

/* ===== Buttons ===== */
.dft-btn{display:inline-block;background:linear-gradient(135deg,var(--df-gold),var(--df-gold-d));color:#3d0b14;font-weight:800;padding:13px 28px;border-radius:12px;box-shadow:0 5px 16px rgba(168,132,31,.35);transition:.18s;font-size:16px}
.dft-btn:hover{transform:translateY(-2px);color:#3d0b14}
.dft-btn.ghost{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.6);box-shadow:none}

/* ===== Footer ===== */
.dft-footer{background:linear-gradient(180deg,var(--df-primary-d),var(--df-nav));color:#e9d6b8;margin-top:50px;padding-top:46px}
.dft-footer a{color:#f0d28a}
.dft-footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:30px;padding-bottom:34px;border-bottom:1px solid rgba(212,175,55,.25)}
.dft-footer h4{font-family:var(--df-sub);color:#ffe082;font-size:18px;margin:0 0 14px}
.dft-footer .brand-line{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.dft-footer .brand-line .mark{width:40px;height:40px;border-radius:50%;background:radial-gradient(circle at 30% 30%,var(--df-gold),var(--df-gold-d));display:flex;align-items:center;justify-content:center;font-size:20px}
.dft-footer .brand-line b{font-family:var(--df-serif);font-size:20px;color:#fff}
.dft-footer ul{list-style:none;margin:0;padding:0;line-height:2.1}
.dft-footer .disclaimer{font-size:13px;color:#cdb68f;opacity:.85;margin-top:14px}
.dft-copy{text-align:center;padding:18px;font-size:13px;color:#cdb68f}

/* ===== Reveal animation ===== */
.dft-reveal{opacity:0;transform:translateY(22px);transition:opacity .6s ease,transform .6s ease}
.dft-reveal.in{opacity:1;transform:none}

/* ===== Mobile bottom nav (เปิดใช้ใน mobile.css) ===== */
.dft-bottomnav{display:none}
.dft-overlay{display:none}

/* ===== ไพ่ทาโรต์ (จัดกึ่งกลาง) ===== */
.dft-tarot-wrap{max-width:620px;margin:0 auto}

/* ===== หมวดแนะนำ / ปิดท้าย (SEO) ===== */
.dft-intro{padding-top:50px;padding-bottom:10px}
.dft-intro-h{font-family:"Chonburi",serif;color:var(--df-primary-d,#7a0c1c);font-size:clamp(22px,3.4vw,32px);line-height:1.4;margin:0 0 16px}
.dft-intro-p{color:#5b4636;font-size:16.5px;line-height:1.9;margin:0}
.dft-about-p{color:#5b4636;font-size:16px;line-height:1.95;margin:0;font-style:italic}
.dft-about .dft-container{position:relative}
.dft-about .dft-container::before{content:"❝";display:block;font-size:48px;color:var(--df-gold,#d4af37);line-height:.6;margin-bottom:10px}

/* ===== Customizer: ออปชันเพิ่มเติม ===== */
/* sticky toggle */
body:not(.dft-sticky) .dft-header{position:static}
/* logo */
.dft-brand .custom-logo{max-height:54px;width:auto;display:block}
/* header CTA */
.dft-header-cta{margin-left:10px;background:linear-gradient(135deg,var(--df-gold),var(--df-gold-d));color:#3d0b14;font-weight:800;padding:9px 18px;border-radius:10px;font-size:15px;box-shadow:0 3px 10px rgba(168,132,31,.35);transition:.18s}
.dft-header-cta:hover{transform:translateY(-2px);color:#3d0b14}
/* hero buttons */
.dft-hero-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
/* hero height */
.dft-hero.hero-compact{padding:40px 20px 50px}
.dft-hero.hero-tall{padding:96px 20px 110px}
/* hero align left */
.dft-hero.align-left{text-align:left}
.dft-hero.align-left p{margin-left:0}
.dft-hero.align-left .dft-hero-btns{justify-content:flex-start}
/* hero background image + overlay */
.dft-hero.has-bg{background-size:cover;background-position:center;background-repeat:no-repeat}
.dft-hero.has-bg::before{content:"";position:absolute;inset:0;background:linear-gradient(160deg,var(--df-nav),var(--df-primary-d));opacity:var(--df-hero-overlay,.55)}
.dft-hero.has-bg .dft-container{position:relative;z-index:1}
/* grid columns */
.dft-grid.cols-2{grid-template-columns:repeat(2,1fr)}
.dft-grid.cols-3{grid-template-columns:repeat(3,1fr)}
.dft-grid.cols-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:900px){.dft-grid.cols-2,.dft-grid.cols-3,.dft-grid.cols-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.dft-grid.cols-2,.dft-grid.cols-3,.dft-grid.cols-4{grid-template-columns:1fr}}
/* social list */
.dft-social-list{list-style:none;margin:0;padding:0}
.dft-social-list li a{display:inline-block;padding:3px 0}
