/* ============================================================
   CreativeDesignIT - Premium Style v3
   Reference: Blue gradient navbar, card shadows, premium look
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700;800;900&display=swap');

:root {
    /* Brand */
    --accent:        #4f6ef7;
    --accent-2:      #7c3aed;
    --accent-grad:   linear-gradient(135deg, #4f6ef7 0%, #7c3aed 100%);
    --accent-hover:  linear-gradient(135deg, #3b5bdb 0%, #6d28d9 100%);
    --accent-glow:   0 8px 24px rgba(79,110,247,0.35);

    /* Surfaces — uniform clean background */
    --bg:            #f5f6fa;
    --surface:       #ffffff;
    --card:          #ffffff;
    --border:        #e4e6ef;
    --border-light:  #eeeff5;

    /* Text */
    --text:          #0f1133;
    --muted:         #6b7280;
    --muted-light:   #9ca3af;

    /* Shadows — premium depth */
    --shadow-xs:     0 1px 4px rgba(15,17,51,0.06);
    --shadow-sm:     0 2px 8px rgba(15,17,51,0.08);
    --shadow-md:     0 6px 24px rgba(15,17,51,0.10);
    --shadow-lg:     0 16px 48px rgba(15,17,51,0.14);
    --shadow-xl:     0 24px 64px rgba(15,17,51,0.18);
    --card-shadow:   0 4px 20px rgba(79,110,247,0.08), 0 1px 4px rgba(0,0,0,0.06);
    --card-hover:    0 12px 40px rgba(79,110,247,0.18), 0 2px 8px rgba(0,0,0,0.08);

    /* Radii */
    --r-sm:  8px;
    --r-md:  14px;
    --r-lg:  20px;
    --r-xl:  28px;
    --r-2xl: 36px;

    /* Misc */
    --font:        'Poppins', sans-serif;
    --transition:  0.22s cubic-bezier(0.4,0,0.2,1);
    --navbar-h:    68px;
    --max-w:       1180px;
}

/* ---- Reset ---- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{font-family:var(--font);background:var(--bg);color:var(--text);font-size:16px;line-height:1.65;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
ul{list-style:none}
button{cursor:pointer;font-family:inherit}

/* ---- Layout ---- */
.container{max-width:var(--max-w);margin:0 auto;padding:0 28px;width:100%}
.section{padding:72px 0}
.section-sm{padding:48px 0}
.text-center{text-align:center}

/* ================================================================
   BUTTONS
   ================================================================ */
.btn{
    display:inline-flex;align-items:center;gap:8px;
    padding:10px 22px;border-radius:var(--r-md);
    font-size:0.85rem;font-weight:600;font-family:var(--font);
    transition:var(--transition);border:none;cursor:pointer;
    text-decoration:none;white-space:nowrap;
}
/* Primary — gradient */
.btn-primary{
    background:var(--accent-grad);
    color:#fff;
    box-shadow:var(--accent-glow);
}
.btn-primary:hover{
    background:var(--accent-hover);
    transform:translateY(-2px);
    box-shadow:0 12px 32px rgba(79,110,247,0.45);
}

/* Outline */
.btn-outline{
    background:#fff;color:var(--text);
    border:1.5px solid var(--border);
    box-shadow:var(--shadow-xs);
}
.btn-outline:hover{
    border-color:var(--accent);color:var(--accent);
    box-shadow:var(--shadow-sm);transform:translateY(-1px);
}

/* Share button */
.btn-share{
    background:linear-gradient(135deg,#10b981,#059669);
    color:#fff;
    box-shadow:0 6px 20px rgba(16,185,129,0.3);
}
.btn-share:hover{
    background:linear-gradient(135deg,#059669,#047857);
    transform:translateY(-2px);
    box-shadow:0 10px 28px rgba(16,185,129,0.4);
}
.btn-share.shared{background:linear-gradient(135deg,#6366f1,#4f46e5)}

/* Dark */
.btn-dark{background:var(--text);color:#fff}
.btn-dark:hover{background:#1e2044;transform:translateY(-1px)}

/* Small */
.btn-sm{padding:7px 15px;font-size:0.78rem;border-radius:var(--r-sm)}

/* Tags */
.tag{display:inline-block;padding:3px 11px;border-radius:999px;font-size:0.7rem;font-weight:600;background:rgba(79,110,247,0.1);color:var(--accent);letter-spacing:0.02em}
.tag-trending{background:linear-gradient(135deg,#f59e0b,#ef4444);color:#fff;font-size:0.66rem;font-weight:700;padding:2px 9px;border-radius:999px}

/* ================================================================
   SECTION LABELS
   ================================================================ */
.section-label{font-size:0.7rem;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--accent);margin-bottom:8px}
.section-title{font-size:clamp(1.55rem,2.8vw,2.3rem);font-weight:800;line-height:1.2;color:var(--text)}
.section-sub{font-size:0.95rem;color:var(--muted);margin-top:10px;max-width:520px;line-height:1.7}
.section-header-row{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:30px;flex-wrap:wrap;gap:14px}

/* ================================================================
   NAVBAR — gradient background, premium look
   ================================================================ */
.navbar{
    position:sticky;top:0;z-index:100;
    height:var(--navbar-h);
    background:linear-gradient(135deg, #1e2d8f 0%, #4f6ef7 50%, #7c3aed 100%);
    box-shadow:0 4px 24px rgba(79,110,247,0.4);
    transition:var(--transition);
}
.navbar.scrolled{
    background:linear-gradient(135deg,#1a2680 0%,#4460e0 50%,#6d28d9 100%);
    box-shadow:0 6px 32px rgba(79,110,247,0.5);
}
.nav-inner{
    display:flex;align-items:center;justify-content:space-between;
    height:var(--navbar-h);max-width:var(--max-w);
    margin:0 auto;padding:0 28px;
}
.logo{
    display:flex;align-items:center;gap:10px;
    font-family:var(--font);font-weight:800;font-size:1.15rem;color:#fff;
}
.logo-icon{
    width:34px;height:34px;border-radius:10px;
    background:rgba(255,255,255,0.2);
    display:flex;align-items:center;justify-content:center;
    font-size:1rem;backdrop-filter:blur(4px);
    border:1px solid rgba(255,255,255,0.25);
}
.logo-text{color:#fff;font-weight:800}
.nav-links{display:flex;align-items:center;gap:2px}
.nav-link{
    padding:7px 13px;border-radius:var(--r-sm);
    font-size:0.82rem;font-weight:500;color:rgba(255,255,255,0.82);
    transition:var(--transition);
}
.nav-link:hover,.nav-link.active{
    background:rgba(255,255,255,0.15);
    color:#fff;
}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:6px;cursor:pointer}
.nav-toggle span{display:block;width:22px;height:2px;background:#fff;border-radius:2px;transition:var(--transition)}

/* ================================================================
   HERO — gradient background
   ================================================================ */
.hero{
    padding:64px 0 60px;
    background:#f5f6fa;
    position:relative;overflow:hidden;
    border-bottom:1px solid var(--border-light);
}
.hero::before{content:none}
.hero::after{content:none}
.hero-content{max-width:620px;position:relative;z-index:1}
.hero-badge{
    display:inline-flex;align-items:center;gap:6px;
    background:linear-gradient(135deg,rgba(79,110,247,0.12),rgba(124,58,237,0.1));
    color:var(--accent);padding:6px 16px;border-radius:999px;
    font-size:0.72rem;font-weight:700;letter-spacing:0.06em;
    margin-bottom:18px;border:1px solid rgba(79,110,247,0.2);
}
.hero-title{
    font-size:clamp(2rem,4vw,3.4rem);font-weight:800;
    line-height:1.12;color:var(--text);
}
.hero-title .accent{
    background:var(--accent-grad);
    -webkit-background-clip:text;-webkit-text-fill-color:transparent;
    background-clip:text;
}
.hero-sub{
    font-size:1rem;color:var(--muted);
    margin:16px 0 28px;line-height:1.75;max-width:500px;
}

/* Search bar */
.search-bar{
    display:flex;border-radius:var(--r-lg);
    overflow:hidden;
    box-shadow:0 8px 32px rgba(79,110,247,0.2),0 2px 8px rgba(0,0,0,0.08);
    border:1.5px solid rgba(79,110,247,0.2);
    background:#fff;max-width:520px;
}
.search-bar input{
    flex:1;padding:14px 20px;border:none;outline:none;
    font-size:0.9rem;font-family:var(--font);background:transparent;
    color:var(--text);
}
.search-bar input::placeholder{color:var(--muted-light)}
.search-bar button{
    padding:14px 26px;
    background:var(--accent-grad);
    color:#fff;border:none;
    font-weight:600;font-size:0.88rem;font-family:var(--font);
    transition:var(--transition);white-space:nowrap;
}
.search-bar button:hover{background:var(--accent-hover)}

/* ================================================================
   CATEGORY GRID
   ================================================================ */
.cat-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.cat-card{
    background:var(--surface);border:1.5px solid var(--border-light);
    border-radius:var(--r-lg);padding:26px 14px;text-align:center;
    transition:var(--transition);cursor:pointer;
    text-decoration:none;color:var(--text);display:block;
    box-shadow:var(--card-shadow);
}
.cat-card:hover{
    border-color:var(--accent);
    background:linear-gradient(135deg,#f5f7ff,#faf5ff);
    transform:translateY(-5px);
    box-shadow:var(--card-hover);
}
.cat-card .cat-emoji{font-size:2.2rem;margin-bottom:11px}
.cat-card h3{font-size:0.88rem;font-weight:700;color:var(--text)}
.cat-card p{font-size:0.72rem;color:var(--muted);margin-top:4px}

/* ================================================================
   TRENDING CARDS
   ================================================================ */
.trending-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}

.tcard{
    background:var(--card);
    border:1px solid var(--border-light);
    border-radius:var(--r-lg);
    overflow:hidden;
    display:flex;flex-direction:column;
    transition:var(--transition);
    box-shadow:var(--card-shadow);
    min-width:0;
}
.tcard:hover{
    box-shadow:var(--card-hover);
    transform:translateY(-5px);
    border-color:rgba(79,110,247,0.2);
}
.tcard-img-link{
    display:block;flex-shrink:0;
    width:100%;height:200px;
    overflow:hidden;background:#eef1ff;
}
.tcard-img{
    width:100%;height:100%;
    object-fit:cover;object-position:center;
    display:block;transition:transform 0.4s ease;
}
.tcard:hover .tcard-img{transform:scale(1.04)}
.tcard-img-ph{
    width:100%;height:200px;
    background:linear-gradient(135deg,#eef1ff 0%,#f5f0ff 100%);
    display:flex;align-items:center;justify-content:center;
    font-size:2.6rem;color:rgba(79,110,247,0.2);
}
.tcard-body{padding:16px;flex:1;display:flex;flex-direction:column;min-width:0}
.tcard-meta{display:flex;align-items:center;gap:7px;margin-bottom:8px;flex-wrap:wrap;min-width:0}
.tcard-cat{font-size:0.66rem;font-weight:700;text-transform:uppercase;letter-spacing:0.08em;color:var(--accent);white-space:nowrap}
.tcard-title{font-size:0.93rem;font-weight:700;line-height:1.35;margin-bottom:7px;word-break:break-word}
.tcard-title a{color:var(--text);text-decoration:none}
.tcard-title a:hover{color:var(--accent)}
.tcard-desc{font-size:0.79rem;color:var(--muted);line-height:1.65;flex:1;word-break:break-word}
.tcard-actions{display:flex;gap:7px;margin-top:14px}
.tcard-actions .btn{flex:1;justify-content:center;font-size:0.76rem;padding:8px 10px}
.mcount{margin-left:auto;font-size:0.72rem;color:var(--muted-light);font-weight:500}

/* ================================================================
   PROMPT CARDS (category pages)
   ================================================================ */
.prompts-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.prompt-card{
    background:var(--card);border:1px solid var(--border-light);
    border-radius:var(--r-lg);overflow:hidden;
    transition:var(--transition);display:flex;flex-direction:column;
    text-decoration:none;color:inherit;
    box-shadow:var(--card-shadow);min-width:0;
}
.prompt-card:hover{
    box-shadow:var(--card-hover);
    transform:translateY(-5px);
    border-color:rgba(79,110,247,0.2);
}
.prompt-card-img-wrap{
    width:100%;height:190px;
    overflow:hidden;background:#eef1ff;flex-shrink:0;
}
.prompt-card-img{
    width:100%;height:100%;
    object-fit:cover;object-position:center;
    display:block;transition:transform 0.4s;
}
.prompt-card:hover .prompt-card-img{transform:scale(1.04)}
.prompt-card-img-placeholder{
    width:100%;height:190px;
    background:linear-gradient(135deg,#eef1ff 0%,#f5f0ff 100%);
    display:flex;align-items:center;justify-content:center;
    font-size:2.6rem;color:rgba(79,110,247,0.15);
    flex-shrink:0;
}
.prompt-card-body{padding:17px;flex:1;display:flex;flex-direction:column;min-width:0}
.prompt-card-top{display:flex;align-items:center;gap:6px;margin-bottom:7px;flex-wrap:wrap}
.prompt-card-cat{font-size:0.66rem;font-weight:700;text-transform:uppercase;letter-spacing:0.08em;color:var(--accent)}
.prompt-card-title{font-size:0.93rem;font-weight:700;margin-bottom:7px;line-height:1.35;word-break:break-word}
.prompt-card-desc{font-size:0.8rem;color:var(--muted);flex:1;line-height:1.65;word-break:break-word}
.prompt-card-actions{display:flex;gap:7px;margin-top:13px}
.prompt-card-actions .btn{flex:1;justify-content:center;font-size:0.76rem;padding:8px 10px}

/* ================================================================
   SINGLE PROMPT PAGE
   ================================================================ */
.prompt-box{
    background:linear-gradient(135deg,#0f1133,#1a1f4e);
    color:#e8ecff;border-radius:var(--r-md);padding:24px;
    position:relative;font-family:'Courier New',monospace;
    font-size:0.87rem;line-height:1.85;white-space:pre-wrap;
    word-break:break-word;
    box-shadow:0 8px 32px rgba(15,17,51,0.25);
}
.copy-btn-box{
    position:absolute;top:12px;right:12px;
    background:var(--accent-grad);color:#fff;
    border:none;border-radius:var(--r-sm);
    padding:6px 13px;font-size:0.76rem;font-weight:600;
    cursor:pointer;transition:var(--transition);font-family:var(--font);
    box-shadow:var(--accent-glow);
}
.copy-btn-box:hover{transform:translateY(-1px);box-shadow:0 8px 24px rgba(79,110,247,0.45)}
.copy-btn-box.copied{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 6px 20px rgba(16,185,129,0.35)}

/* ================================================================
   BLOG CARDS
   ================================================================ */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.blog-card{
    background:var(--card);border-radius:var(--r-lg);
    border:1px solid var(--border-light);overflow:hidden;
    transition:var(--transition);display:flex;flex-direction:column;
    text-decoration:none;color:inherit;
    box-shadow:var(--card-shadow);
}
.blog-card:hover{box-shadow:var(--card-hover);transform:translateY(-5px);border-color:rgba(79,110,247,0.15)}
.blog-card-img-wrap{
    width:100%;height:210px;
    overflow:hidden;background:#eef1ff;flex-shrink:0;
}
.blog-card-img{
    width:100%;height:100%;
    object-fit:cover;object-position:center;
    display:block;transition:transform 0.4s;
}
.blog-card:hover .blog-card-img{transform:scale(1.04)}
.blog-card-img-placeholder{
    width:100%;height:210px;
    background:linear-gradient(135deg,#eef1ff 0%,#f0fff4 100%);
    display:flex;align-items:center;justify-content:center;
    font-size:2.6rem;flex-shrink:0;
}
.blog-card-body{padding:18px;flex:1;display:flex;flex-direction:column}
.blog-card-date{font-size:0.72rem;color:var(--muted);margin-bottom:7px}
.blog-card-title{font-size:0.95rem;font-weight:700;line-height:1.35;margin-bottom:9px}
.blog-card-title a:hover{color:var(--accent)}
.blog-card-excerpt{font-size:0.8rem;color:var(--muted);line-height:1.6;flex:1}
.blog-card-body .btn{margin-top:13px;width:fit-content}

/* Single post */
.post-hero-img-wrap{
    width:100%;height:380px;
    overflow:hidden;border-radius:var(--r-lg);
    margin-bottom:30px;box-shadow:var(--shadow-lg);
    background:#eef1ff;
}
.post-hero-img{
    width:100%;height:100%;
    object-fit:cover;object-position:center top;
    display:block;
}
.post-meta{display:flex;gap:13px;align-items:center;flex-wrap:wrap;margin-bottom:18px}
.post-meta .date{font-size:0.8rem;color:var(--muted)}
.post-content h2{font-size:1.35rem;font-weight:700;margin:26px 0 11px;color:var(--text)}
.post-content h3{font-size:1.1rem;font-weight:700;margin:20px 0 9px}
.post-content p{margin-bottom:15px;line-height:1.85;font-size:0.95rem}
.post-content ul,.post-content ol{margin:11px 0 15px 22px}
.post-content li{margin-bottom:6px;font-size:0.93rem}
.post-content strong{font-weight:600}
.post-content img{border-radius:var(--r-md);box-shadow:var(--shadow-md);margin:16px 0}

/* ================================================================
   INFO BOXES & SEO BLOCK
   ================================================================ */
.info-box{
    background:linear-gradient(135deg,#f5f7ff,#faf5ff);
    border:1px solid rgba(79,110,247,0.15);
    border-left:4px solid var(--accent);
    border-radius:var(--r-md);padding:20px;margin:16px 0;
}
.info-box h3{font-size:0.97rem;font-weight:700;margin-bottom:9px}
.seo-block{
    background:var(--surface);
    border:1px solid var(--border-light);
    border-radius:var(--r-lg);
    padding:34px 40px;
    box-shadow:var(--card-shadow);
}
.seo-block h2{font-size:1.25rem;font-weight:700;margin-bottom:13px}
.seo-block p{color:var(--muted);margin-bottom:11px;line-height:1.8;font-size:0.93rem}
.seo-block ul{color:var(--muted);padding-left:18px}
.seo-block li{margin-bottom:7px;font-size:0.93rem}

/* ================================================================
   PAGE HERO (inner pages)
   ================================================================ */
.page-hero{
    background:#f5f6fa;
    padding:50px 0 42px;border-bottom:1px solid var(--border);
}
.page-hero h1{font-size:clamp(1.7rem,3.2vw,2.6rem);font-weight:800;color:var(--text)}
.page-hero p{color:var(--muted);font-size:0.97rem;margin-top:9px;max-width:540px}
.breadcrumb{font-size:0.75rem;color:var(--muted);margin-bottom:9px}
.breadcrumb a:hover{color:var(--accent)}
.breadcrumb span{margin:0 5px}

/* ================================================================
   FORMS
   ================================================================ */
.form-group{margin-bottom:17px}
.form-group label{display:block;font-weight:600;font-size:0.86rem;margin-bottom:6px;color:var(--text)}
.form-control{
    width:100%;padding:11px 15px;
    border:1.5px solid var(--border);border-radius:var(--r-md);
    font-family:var(--font);font-size:0.9rem;
    transition:var(--transition);background:#fff;outline:none;color:var(--text);
}
.form-control:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(79,110,247,0.1)}
textarea.form-control{resize:vertical;min-height:120px}
.alert{padding:12px 17px;border-radius:var(--r-md);font-size:0.86rem;margin-bottom:17px}
.alert-success{background:#ecfdf5;color:#065f46;border:1px solid #a7f3d0}
.alert-error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}

/* ================================================================
   LAYOUT WITH SIDEBAR
   ================================================================ */
.layout-with-sidebar{display:grid;grid-template-columns:1fr 290px;gap:34px;align-items:start}
.sidebar{position:sticky;top:86px}
.sidebar-widget{
    background:var(--surface);border:1px solid var(--border-light);
    border-radius:var(--r-lg);padding:20px;margin-bottom:16px;
    box-shadow:var(--card-shadow);
}
.sidebar-widget h4{font-weight:700;margin-bottom:13px;font-size:0.92rem;color:var(--text)}
.sidebar-prompt-item{padding:9px 0;border-bottom:1px solid var(--border-light)}
.sidebar-prompt-item:last-child{border-bottom:none}
.sidebar-prompt-item .title{font-size:0.81rem;font-weight:600;line-height:1.3}
.sidebar-prompt-item .title a:hover{color:var(--accent)}
.sidebar-prompt-item .cat{font-size:0.68rem;color:var(--muted);margin-top:2px}

/* ================================================================
   PAGINATION
   ================================================================ */
.pagination{display:flex;justify-content:center;gap:7px;margin-top:42px;flex-wrap:wrap}
.pagination a,.pagination span{
    display:inline-flex;align-items:center;justify-content:center;
    width:37px;height:37px;border-radius:var(--r-sm);
    font-size:0.86rem;font-weight:600;
    border:1.5px solid var(--border);transition:var(--transition);
    background:#fff;box-shadow:var(--shadow-xs);
}
.pagination a:hover{border-color:var(--accent);color:var(--accent);box-shadow:var(--shadow-sm)}
.pagination .active{background:var(--accent-grad);color:#fff;border-color:transparent;box-shadow:var(--accent-glow)}

/* ================================================================
   LEGAL
   ================================================================ */
.legal-content h2{font-size:1.15rem;font-weight:700;margin:24px 0 9px;color:var(--text)}
.legal-content p{color:var(--muted);margin-bottom:12px;line-height:1.8;font-size:0.93rem}
.legal-content ul{color:var(--muted);padding-left:18px;margin-bottom:12px}
.legal-content li{margin-bottom:6px;font-size:0.92rem}

/* ================================================================
   EMPTY STATE
   ================================================================ */
.empty-state{text-align:center;padding:80px 20px;color:var(--muted)}
.empty-state .icon{font-size:3.5rem;margin-bottom:14px}
.empty-state h3{font-size:1.25rem;font-weight:700;color:var(--text)}
.empty-state p{font-size:0.9rem;margin-top:6px}

/* ================================================================
   FOOTER
   ================================================================ */
.footer{
    background:linear-gradient(135deg,#0f1133 0%,#1a1f4e 100%);
    color:rgba(255,255,255,0.7);padding:58px 0 0;
}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:34px;margin-bottom:42px}
.footer-brand .logo{margin-bottom:13px}
.footer-brand .logo-text{color:#fff}
.footer-brand .logo-icon{background:rgba(255,255,255,0.1)}
.footer-brand p{font-size:0.83rem;line-height:1.7;color:rgba(255,255,255,0.48)}
.footer-col h4{font-size:0.8rem;font-weight:700;color:#fff;margin-bottom:13px;text-transform:uppercase;letter-spacing:0.08em}
.footer-col ul li{margin-bottom:8px}
.footer-col ul li a{font-size:0.83rem;color:rgba(255,255,255,0.48);transition:var(--transition)}
.footer-col ul li a:hover{color:var(--accent)}
.admin-link{font-size:0.72rem !important;opacity:0.3}
.admin-link:hover{opacity:1 !important}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.07);padding:17px 0;text-align:center;font-size:0.78rem;color:rgba(255,255,255,0.28)}

/* ================================================================
   SCROLL TO TOP
   ================================================================ */
.scroll-top{
    position:fixed;bottom:22px;right:22px;
    width:42px;height:42px;
    background:var(--accent-grad);color:#fff;
    border-radius:50%;border:none;
    display:flex;align-items:center;justify-content:center;
    font-size:1.1rem;cursor:pointer;
    opacity:0;pointer-events:none;
    transition:var(--transition);z-index:200;
    box-shadow:var(--accent-glow);
}
.scroll-top.visible{opacity:1;pointer-events:all}
.scroll-top:hover{transform:translateY(-2px);box-shadow:0 12px 32px rgba(79,110,247,0.45)}

/* ================================================================
   CATEGORY MODAL
   ================================================================ */
.modal-overlay{position:fixed;inset:0;background:rgba(15,17,51,0.6);z-index:500;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:0.25s;backdrop-filter:blur(4px)}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal-box{background:#fff;border-radius:var(--r-xl);padding:34px;max-width:500px;width:100%;transform:translateY(20px);transition:0.3s;box-shadow:var(--shadow-xl)}
.modal-overlay.open .modal-box{transform:translateY(0)}
.modal-box h3{font-size:1.15rem;font-weight:700;margin-bottom:5px;color:var(--text)}
.modal-box p{font-size:0.85rem;color:var(--muted);margin-bottom:20px}
.modal-cat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.modal-cat-btn{
    display:flex;align-items:center;gap:11px;
    padding:13px 15px;border-radius:var(--r-md);
    border:1.5px solid var(--border);background:#fff;
    cursor:pointer;transition:var(--transition);
    font-family:var(--font);font-size:0.88rem;font-weight:600;
    text-decoration:none;color:var(--text);
    box-shadow:var(--shadow-xs);
}
.modal-cat-btn:hover{border-color:var(--accent);color:var(--accent);background:#f5f7ff;transform:translateY(-1px);box-shadow:var(--shadow-sm)}
.modal-cat-btn .emoji{font-size:1.3rem}
.modal-close{background:none;border:none;cursor:pointer;font-size:1.3rem;color:var(--muted);float:right;line-height:1;transition:var(--transition)}
.modal-close:hover{color:var(--text)}

/* ================================================================
   ANIMATIONS
   ================================================================ */
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.fade-up{animation:fadeUp 0.55s ease forwards}
.delay-1{animation-delay:0.1s;opacity:0}
.delay-2{animation-delay:0.2s;opacity:0}

/* ================================================================
   RESPONSIVE
   ================================================================ */
@media(max-width:1024px){
    .cat-grid{grid-template-columns:repeat(3,1fr)}
    .trending-grid{grid-template-columns:repeat(2,1fr)}
    .prompts-grid{grid-template-columns:repeat(2,1fr)}
    .blog-grid{grid-template-columns:repeat(2,1fr)}
    .footer-grid{grid-template-columns:1fr 1fr}
    .layout-with-sidebar{grid-template-columns:1fr}
    .sidebar{position:static}
}
@media(max-width:768px){
    .nav-links{
        display:none;flex-direction:column;
        position:fixed;top:var(--navbar-h);left:0;right:0;
        background:linear-gradient(135deg,#1e2d8f,#4f6ef7);
        padding:14px 18px;
        box-shadow:0 16px 40px rgba(79,110,247,0.3);
        gap:4px;
    }
    .nav-links.open{display:flex}
    .nav-toggle{display:flex}
    .cat-grid{grid-template-columns:repeat(2,1fr)}
    .trending-grid{grid-template-columns:1fr}
    .prompts-grid{grid-template-columns:1fr}
    .blog-grid{grid-template-columns:1fr}
    .footer-grid{grid-template-columns:1fr;gap:22px}
    .hero{padding:46px 0 40px}
    .section{padding:46px 0}
    .seo-block{padding:22px 18px}
    .modal-cat-grid{grid-template-columns:1fr}
    .section-header-row{flex-direction:column;align-items:flex-start}
}
@media(max-width:480px){
    .cat-grid{grid-template-columns:repeat(2,1fr)}
    .tcard-actions{flex-direction:column}
    .hero-title{font-size:1.85rem}
}


/* ================================================================
   SECTION DIVIDERS — reference style: white cards on grey bg
   ================================================================ */

/* All sections share the same body bg (#f5f6fa) */
/* White card wrapper gives visual separation like the reference */
.section-card{
    background:#fff;
    border-radius:var(--r-xl);
    border:1px solid var(--border-light);
    box-shadow:0 2px 16px rgba(79,110,247,0.05),0 1px 4px rgba(0,0,0,0.04);
    padding:40px;
    margin-bottom:0;
}

/* Hero search bar clean white */
.search-bar{
    background:#fff !important;
}

/* Category section white card */
.cat-section-wrap{
    background:#fff;
    border-radius:var(--r-xl);
    border:1px solid var(--border-light);
    box-shadow:0 2px 16px rgba(79,110,247,0.05);
    padding:40px;
}

/* Trending section white card */
.trending-section-wrap{
    background:#fff;
    border-radius:var(--r-xl);
    border:1px solid var(--border-light);
    box-shadow:0 2px 16px rgba(79,110,247,0.05);
    padding:40px;
}

/* SEO block — already has card style, just clean it up */
.seo-block{
    background:#fff !important;
    border:1px solid var(--border-light) !important;
    box-shadow:0 2px 16px rgba(79,110,247,0.05) !important;
}

/* Blog section white card */
.blog-section-wrap{
    background:#fff;
    border-radius:var(--r-xl);
    border:1px solid var(--border-light);
    box-shadow:0 2px 16px rgba(79,110,247,0.05);
    padding:40px;
}

/* Hero area — same bg as body, just clean padding */
.hero-content{
    max-width:640px;
    position:relative;z-index:1;
}

/* Hero badge adjusted for clean bg */
.hero-badge{
    background:rgba(79,110,247,0.08) !important;
    border:1px solid rgba(79,110,247,0.15) !important;
}

/* Search bar on hero — elevated card look */
.search-bar{
    box-shadow:0 4px 24px rgba(79,110,247,0.12),0 2px 8px rgba(0,0,0,0.06) !important;
    border:1.5px solid rgba(79,110,247,0.15) !important;
}

@media(max-width:768px){
    .cat-section-wrap,.trending-section-wrap,.blog-section-wrap{padding:24px 18px}
    .section-card{padding:24px 18px}
}

.post-hero-img{width:100%;max-height:380px;height:100%;object-fit:cover;object-position:center top;display:block}