/* ====================================================================
   AI TOOLS — SEO Generator, Thumbnail Maker, Repurpose Content
   ==================================================================== */

/* Shared tool styles */
.seo-tool,.thumb-tool{max-width:750px;margin:0 auto}
.tool-input-section{margin-bottom:var(--space-2xl)}
.tool-description{
    color:var(--text-secondary);font-size:var(--text-base);
    line-height:1.6;margin-bottom:var(--space-xl);
}
.tool-free-note{
    font-size:var(--text-sm);color:var(--text-muted);
    margin-top:var(--space-sm);
}
.btn-generate{
    width:100%;padding:var(--space-md);
    font-size:var(--text-base);font-weight:500;
    display:flex;align-items:center;justify-content:center;gap:var(--space-sm);
}
.btn-generate:disabled{opacity:0.5;cursor:not-allowed}
.btn-loader{
    width:16px;height:16px;border:2px solid rgba(255,255,255,0.3);
    border-top-color:var(--color-ivory);border-radius:50%;
    animation:spin 0.6s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}
.form-hint-inline{
    font-size:var(--text-sm);color:var(--text-muted);
    font-weight:400;
}

/* Login required card */
.tool-login-required{
    text-align:center;padding:var(--space-3xl);
    background:var(--bg-card);border:1px solid var(--border);
    border-radius:var(--radius-lg);
}
.tool-login-required h3{
    font-size:var(--text-xl);margin-bottom:var(--space-md);
}
.tool-login-required p{
    color:var(--text-secondary);margin-bottom:var(--space-xl);
}
.tool-login-required .btn{margin:0 var(--space-sm)}

/* SEO Results */
.tool-results{margin-top:var(--space-2xl)}
.result-card{
    background:var(--bg-card);border:1px solid var(--border);
    border-radius:var(--radius-lg);margin-bottom:var(--space-lg);
    overflow:hidden;transition:border-color 0.2s ease;
}
.result-card:hover{border-color:var(--border-hover)}
.result-header{
    display:flex;align-items:center;justify-content:space-between;
    padding:var(--space-md) var(--space-lg);
    border-bottom:1px solid var(--border);
}
.result-header h3{font-size:var(--text-base);font-weight:500}
.result-hint{font-size:var(--text-xs);color:var(--text-muted)}
.result-body{padding:var(--space-lg)}
.result-text{
    color:var(--text-secondary);font-size:var(--text-sm);
    line-height:1.7;white-space:pre-wrap;word-break:break-word;
    font-family:var(--font);background:none;border:none;margin:0;
}

/* Title options */
.title-option{
    display:flex;align-items:center;gap:var(--space-md);
    padding:var(--space-sm) var(--space-md);
    border-radius:var(--radius-md);
    transition:background 0.15s;
}
.title-option:hover{background:rgba(255,255,255,0.03)}
.title-option + .title-option{margin-top:var(--space-xs)}
.title-number{
    width:24px;height:24px;border-radius:50%;
    background:var(--bg-elevated);border:1px solid var(--border);
    font-size:var(--text-xs);font-weight:500;color:var(--text-muted);
    display:flex;align-items:center;justify-content:center;
    flex-shrink:0;
}
.title-text{flex:1;font-size:var(--text-sm);color:var(--text-primary)}

/* Copy buttons */
.btn-copy,.btn-copy-sm{
    padding:var(--space-xs) var(--space-md);
    background:rgba(255,255,255,0.05);border:1px solid var(--border);
    border-radius:var(--radius-md);color:var(--text-secondary);
    font-size:var(--text-xs);font-weight:500;cursor:pointer;
    transition:all 0.15s;font-family:var(--font);
}
.btn-copy:hover,.btn-copy-sm:hover{
    background:var(--neutral-hover-bg);border-color:var(--neutral-border);
    color:var(--neutral);
}
.btn-copy.copied,.btn-copy-sm.copied{
    background:rgba(52,211,153,0.1);border-color:rgba(52,211,153,0.3);
    color:var(--success);
}
.btn-copy-sm{padding:2px var(--space-sm);font-size:10px}

/* Tags container */
.tags-container{display:flex;flex-wrap:wrap;gap:var(--space-sm)}

/* Tool loading animation */
.tool-loading{text-align:center;padding:var(--space-3xl) 0;color:var(--text-muted)}
.tool-loading p{margin-top:var(--space-md);font-size:var(--text-sm)}
.tool-loading-dot{
    display:inline-block;width:8px;height:8px;border-radius:50%;
    background:var(--color-gold);margin:0 3px;
    animation:dotPulse 1.4s ease-in-out infinite;
}
.tool-loading-dot:nth-child(2){animation-delay:0.2s}
.tool-loading-dot:nth-child(3){animation-delay:0.4s}
@keyframes dotPulse{
    0%,80%,100%{opacity:0.3;transform:scale(0.8)}
    40%{opacity:1;transform:scale(1)}
}

/* SEO CTA */
.seo-cta{
    text-align:center;padding:var(--space-2xl);
    background:var(--bg-card);border:1px solid var(--border);
    border-radius:var(--radius-lg);margin-top:var(--space-xl);
}
.seo-cta p{color:var(--text-secondary);margin-bottom:var(--space-lg);font-size:var(--text-lg)}
/* btn-large defined in buttons section above */

/* Signup modal */
.modal-overlay{
    position:fixed;inset:0;background:rgba(0,0,0,0.7);
    backdrop-filter:blur(4px);
    display:flex;align-items:center;justify-content:center;
    z-index:3000;
}
.modal-box{
    background:var(--bg-card);border:1px solid var(--border);
    border-radius:var(--radius-xl);padding:var(--space-2xl);
    max-width:420px;width:90%;text-align:center;
}
.modal-box h3{font-size:var(--text-xl);margin-bottom:var(--space-md)}
.modal-box p{color:var(--text-secondary);margin-bottom:var(--space-xl);line-height:1.6}
.modal-actions{display:flex;gap:var(--space-md);justify-content:center}

/* ===== Thumbnail Maker ===== */
.thumb-loading{text-align:center;padding:var(--space-2xl) 0}
.thumb-loading-grid{
    display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md);
    max-width:600px;margin:0 auto var(--space-lg);
}
.thumb-skeleton{
    aspect-ratio:16/9;border-radius:var(--radius-md);
    background:linear-gradient(90deg,var(--bg-card) 25%,var(--bg-elevated) 50%,var(--bg-card) 75%);
    background-size:200% 100%;animation:shimmer 1.5s infinite;
}
@keyframes shimmer{
    from{background-position:200% 0}
    to{background-position:-200% 0}
}
.thumb-loading-text{color:var(--text-secondary);font-size:var(--text-sm)}

.thumb-results-title{
    font-size:var(--text-xl);font-weight:500;
    margin-bottom:var(--space-lg);
}
.thumb-grid{
    display:grid;grid-template-columns:1fr 1fr;gap:var(--space-lg);
    margin-bottom:var(--space-xl);
}
.thumb-card{
    background:var(--bg-card);border:1px solid var(--border);
    border-radius:var(--radius-lg);overflow:hidden;
    transition:all 0.2s;
}
.thumb-card:hover{
    border-color:var(--border-hover);transform:translateY(-2px);
}
.thumb-preview{aspect-ratio:16/9;overflow:hidden}
.thumb-preview img{width:100%;height:100%;object-fit:cover;display:block}
.thumb-card-footer{
    display:flex;align-items:center;justify-content:space-between;
    padding:var(--space-sm) var(--space-md);
}
.thumb-layout-name{font-size:var(--text-xs);color:var(--text-muted)}
.btn-sm{
    padding:var(--space-xs) var(--space-md);font-size:var(--text-xs);
    font-weight:500;border-radius:var(--radius-md);
}
.btn-accent{
    background:var(--color-gold);color:var(--color-black-deep);border:none;
    cursor:pointer;transition:all 0.15s;font-family:var(--font);
}
.btn-accent:hover{background:var(--accent-hover)}

/* ===== Promote Video ===== */
.promote-tool{max-width:750px;margin:0 auto}

/* Video player */
.promote-video-wrap{
    margin-bottom:var(--space-lg);
    background:var(--bg-card);border:1px solid var(--border);
    border-radius:var(--radius-lg);overflow:hidden;
}
.promote-video-wrap video{
    width:100%;display:block;max-height:420px;
    background:#000;
}
.promote-video-meta{
    padding:var(--space-sm) var(--space-lg);
    font-size:var(--text-sm);color:var(--text-secondary);
    border-top:1px solid var(--border);
}

/* No video fallback */
.promote-no-video{
    padding:var(--space-xl);text-align:center;
    background:var(--bg-card);border:1px solid var(--border);
    border-radius:var(--radius-lg);margin-bottom:var(--space-lg);
}
.promote-no-video p{color:var(--text-muted);font-size:var(--text-sm)}

/* Tag pills */
.tag-pill{
    display:inline-block;padding:var(--space-xs) var(--space-md);
    background:rgba(255,255,255,0.04);border:1px solid var(--border);
    border-radius:var(--radius-full,20px);font-size:var(--text-xs);
    color:var(--text-secondary);
}

/* Hashtags */
.promote-hashtags{
    color:var(--color-gold) !important;
    font-size:var(--text-sm) !important;
    line-height:1.8 !important;
    word-spacing:var(--space-sm);
}

/* ============================================================
   FREE-TOOL PAGE LAYER — cinematic hero band, elevated input
   card, how-it-works steps, FAQ. Shared by all public tool
   pages. Per page, swap only: hero <img>, badge, headline,
   subtitle, feature pills, and the step/FAQ copy.
   ============================================================ */

/* --- Cinematic banner: short, full-width, centred. Badge + title +
       feature pills only; the input sits in its own card just below. --- */
.tool-hero{
    position:relative;display:flex;flex-direction:column;
    align-items:center;justify-content:center;text-align:center;
    padding:26px 28px 22px;overflow:hidden;
    border-radius:var(--radius-lg);
    background:var(--color-black-deep,#0c0c0c);
    margin-bottom:var(--space-lg);
}
.tool-hero-bg{position:absolute;inset:0;z-index:0}
.tool-hero-img{width:100%;height:100%;object-fit:cover;object-position:center 45%}
.tool-hero-overlay{
    position:absolute;inset:0;
    background:
        linear-gradient(180deg,rgba(11,11,15,.52) 0%,rgba(11,11,15,.72) 50%,rgba(11,11,15,.90) 100%),
        radial-gradient(ellipse at center 40%,rgba(184,151,46,.14) 0%,transparent 60%);
}
.tool-hero-grain{
    position:absolute;inset:0;opacity:.05;pointer-events:none;
    background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23g)'/%3E%3C/svg%3E");
    background-size:180px 180px;
}
.tool-hero-brackets{position:absolute;inset:16px;pointer-events:none;z-index:1}
.tool-hero-brackets::before,.tool-hero-brackets::after{
    content:'';position:absolute;width:22px;height:22px;
    border-color:var(--color-gold-dim);border-style:solid;opacity:.4;
}
.tool-hero-brackets::before{top:0;left:0;border-width:1px 0 0 1px}
.tool-hero-brackets::after{bottom:0;right:0;border-width:0 1px 1px 0}
.tool-hero-content{
    position:relative;z-index:2;display:flex;flex-direction:column;
    align-items:center;max-width:900px;
    animation:tool-hero-in .8s cubic-bezier(.16,1,.3,1) .1s both;
}
@keyframes tool-hero-in{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.tool-hero-badge{
    display:inline-flex;align-items:center;gap:6px;
    padding:5px 14px;font-size:.7rem;font-weight:600;letter-spacing:.12em;
    text-transform:uppercase;color:var(--color-gold);
    background:rgba(184,151,46,.08);border:1px solid var(--color-gold-faint);
    border-radius:20px;margin-bottom:var(--space-sm);
}
.tool-hero-title{
    font-size:clamp(1.45rem,2.8vw,2rem);font-weight:800;
    color:var(--color-ivory);letter-spacing:-.02em;line-height:1.15;
    margin:0 0 var(--space-md);
}
.tool-hero-features{
    display:flex;align-items:center;justify-content:center;flex-wrap:wrap;
    gap:10px 14px;
}
.tool-hero-feature{
    display:flex;align-items:center;gap:6px;
    font-size:.78rem;color:var(--text-muted);letter-spacing:.02em;
}
.tool-hero-feature svg{color:var(--color-gold);flex-shrink:0}
.tool-hero-feature-dot{width:3px;height:3px;border-radius:50%;background:var(--color-gold-dim)}

/* Tool + results read in a wide, centred column */
.tool-body{max-width:1040px;margin:0 auto}

/* Input — the generous focal-point card directly under the banner */
.tool-input{
    position:relative;
    background:linear-gradient(180deg,rgba(255,255,255,.025) 0%,rgba(255,255,255,0) 55%),var(--bg-card);
    border:1px solid var(--border);
    border-radius:var(--radius-lg);
    padding:var(--space-xl) var(--space-2xl) var(--space-2xl);
    margin-bottom:var(--space-2xl);
    box-shadow:0 28px 80px rgba(0,0,0,.45),inset 0 1px 0 rgba(255,255,255,.05);
    animation:tool-hero-in .8s cubic-bezier(.16,1,.3,1) .2s both;
}
.tool-input .form-group{margin-bottom:var(--space-lg)}
.tool-input .form-label{font-size:var(--text-base);margin-bottom:var(--space-sm)}
.tool-input .form-textarea{min-height:220px;font-size:var(--text-base)}

/* Per-tool input sizing (page-specific, by id — leaves other tools untouched) */
#seoTopicInput{min-height:264px}
#thumbTitleInput,#thumbTopicInput{min-height:88px}
#hookTopicInput{min-height:150px}
#scriptTopicInput{min-height:150px}
#ideasTopicInput{min-height:150px}

/* Tool pages span wide — drop inner padding so the banner is full-width */
.tool-page .content-area{padding:0}

/* Warm ambient glow behind the banner + tool for depth */
.tool-stage{position:relative}
.tool-stage::before{
    content:'';position:absolute;z-index:0;pointer-events:none;
    top:60px;left:50%;transform:translateX(-50%);
    width:1100px;max-width:96%;height:620px;
    background:radial-gradient(ellipse at center top,rgba(184,151,46,.08) 0%,transparent 66%);
}
.tool-hero,.tool-body,.tool-faq{position:relative;z-index:1}

/* --- Section heading (FAQ) --- */
.tool-section-head{text-align:center;margin-bottom:var(--space-xl)}
.tool-section-head h2{font-size:var(--text-2xl);font-weight:700;letter-spacing:-.01em}
.tool-section-head p{color:var(--text-muted);font-size:var(--text-sm);margin-top:var(--space-xs)}

/* --- FAQ --- */
.tool-faq{margin-top:5rem}
.tool-faq-list{max-width:680px;margin:0 auto}
.tool-faq-item{
    border:1px solid var(--border);border-radius:var(--radius-md);
    margin-bottom:var(--space-sm);overflow:hidden;background:var(--bg-card);
    transition:border-color .2s ease;
}
.tool-faq-item[open]{border-color:var(--border-hover)}
.tool-faq-item summary{
    list-style:none;cursor:pointer;padding:var(--space-md) var(--space-lg);
    font-size:var(--text-sm);font-weight:600;color:var(--text-primary);
    display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);
}
.tool-faq-item summary::-webkit-details-marker{display:none}
.tool-faq-item summary::after{
    content:'+';font-size:1.25rem;font-weight:300;color:var(--color-gold);
    line-height:1;transition:transform .2s ease;
}
.tool-faq-item[open] summary::after{transform:rotate(45deg)}
.tool-faq-a{
    padding:0 var(--space-lg) var(--space-md);
    color:var(--text-secondary);font-size:var(--text-sm);line-height:1.7;
}
.tool-faq-a a{color:var(--color-gold)}

/* ===== AI Tools responsive ===== */
@media(max-width:768px){
    .thumb-grid{grid-template-columns:1fr}
    .thumb-loading-grid{grid-template-columns:1fr}
    .title-option{flex-wrap:wrap}
    .modal-actions{flex-direction:column}
    .tool-hero{padding:34px 20px 30px}
    .tool-hero-brackets{display:none}
    .tool-input{padding:var(--space-lg)}
}

