/* AI Tools info page styles. Extracted from pages/info/info.aitools.php on 2026-05-10. */

.aitp-wrap { padding: clamp(24px, 4vw, 56px) clamp(12px, 3vw, 36px) clamp(40px, 5vw, 72px); }
.aitp-wrap::before { mask-image: radial-gradient(ellipse 70% 45% at 50% 0%, #000, transparent 75%); }

.aitp-grid{
    position:relative;
    max-width: 1080px;
    margin: 0 auto;
    display:flex;
    flex-direction: column;
    gap: clamp(20px, 3vw, 32px);
}

.aitp-hero{ position:relative; }
.aitp-kicker{
    display:inline-flex; align-items:center; gap:10px;
    font-family:'Fraunces', serif;
    font-size: 12px; letter-spacing:.22em; text-transform:uppercase;
    color: var(--accent); font-weight: 500;
}
.aitp-kicker .dot{
    width:6px; height:6px; border-radius:50%;
    background: var(--accent);
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--bmm-accent) 12%, transparent);
}
.aitp-h1{
    font-family:'Fraunces', serif;
    font-weight: 400;
    font-size: clamp(28px, 4.4vw, 46px);
    line-height: 1.05; letter-spacing: -0.015em;
    margin: 14px 0 12px;
}
.aitp-h1 em{ font-style: italic; font-weight: 400; color: var(--accent); }
.aitp-lede{
    font-size: clamp(15px, 1.6vw, 17px); line-height: 1.6;
    color: var(--ink-soft);
    max-width: 60ch; margin: 0 0 0;
}

.aitp-cta-row{
    display:flex; flex-wrap: wrap; align-items: center; gap: 14px;
    margin-top: clamp(16px, 2.5vw, 22px);
}
.aitp-cta{
    display:inline-flex; align-items:center; gap: 8px;
    font-family:'Fraunces', serif; font-size: 15px; font-weight: 500;
    color: #fff; background: var(--accent);
    text-decoration: none;
    padding: 13px 22px; border-radius: 2px;
    transition: background .2s ease, transform .15s ease, box-shadow .2s ease;
    box-shadow: 0 8px 20px -8px color-mix(in srgb, var(--bmm-accent) 30%, transparent);
}
.aitp-cta:hover{ background: var(--accent-deep); transform: translateY(-1px); }
.aitp-cta-secondary{
    display:inline-flex; align-items:center; gap: 6px;
    font-family:'Fraunces', serif; font-size: 14px;
    color: var(--ink-soft); text-decoration: none;
    border-bottom: 1px solid var(--line);
    padding-bottom: 2px;
    transition: color .15s ease, border-color .15s ease;
}
.aitp-cta-secondary:hover{ color: var(--accent); border-color: var(--accent); }

.aitp-note{
    font-family:'Fraunces', serif; font-style: italic;
    font-size: 13px; color: var(--muted);
    margin-top: 12px;
}

.aitp-cat{
    position:relative;
    border: 1px solid var(--line);
    background: var(--paper);
    padding: clamp(16px, 3vw, 28px);
    border-radius: 2px;
}
.aitp-cat::before, .aitp-cat::after{
    content:""; position:absolute; width:14px; height:14px;
    border: 1px solid var(--accent); opacity:.85;
}
.aitp-cat::before{ top:-1px; left:-1px; border-right:none; border-bottom:none; }
.aitp-cat::after{ bottom:-1px; right:-1px; border-left:none; border-top:none; }

.aitp-cat-head{
    display:flex; align-items:center; justify-content: space-between;
    gap: 14px;
    padding-bottom: clamp(12px, 2vw, 18px);
    margin-bottom: clamp(14px, 2vw, 22px);
    border-bottom: 1px solid var(--line-soft);
}
.aitp-cat-head .left{
    display:flex; align-items:center; gap: 14px;
}
.aitp-cat-head .gly{
    width: 38px; height: 38px;
    display:grid; place-items:center;
    color: var(--accent);
    background: color-mix(in srgb, var(--bmm-accent) 7%, transparent);
    border: 1px solid color-mix(in srgb, var(--bmm-accent) 18%, transparent);
    border-radius: 2px;
}
.aitp-cat-head .gly svg{ width: 18px; height: 18px; }
.aitp-cat-head h2{
    font-family:'Fraunces', serif; font-weight: 500;
    font-size: clamp(18px, 2.4vw, 22px);
    margin: 0; line-height: 1.1; letter-spacing: -0.01em;
}
.aitp-cat-head .kicker{
    display:block;
    font-size: 11px; letter-spacing: .18em; text-transform: uppercase;
    color: var(--muted); font-weight: 500;
    margin-bottom: 4px;
}
.aitp-cat-head .count{
    font-family:'Fraunces', serif; font-size: 13px; font-style: italic;
    color: var(--muted); white-space: nowrap;
}

.aitp-cards{
    display:grid;
    grid-template-columns: 1fr;
    gap: 10px;
}
@media (min-width: 640px){ .aitp-cards{ grid-template-columns: 1fr 1fr; gap: 14px; } }
@media (min-width: 1000px){ .aitp-cards{ grid-template-columns: repeat(3, 1fr); } }

.aitp-card{
    position:relative;
    display:flex; flex-direction: column;
    gap: 8px;
    padding: 16px 18px 18px;
    background: var(--paper);
    border: 1px solid var(--line);
    border-radius: 2px;
    text-decoration: none;
    color: inherit;
    transition: border-color .2s ease, box-shadow .2s ease, background .2s ease;
    min-height: 96px;
}
.aitp-card::after{
    content:""; position:absolute; right: 16px; top: 18px;
    width: 14px; height: 14px;
    background: linear-gradient(135deg, transparent 50%, color-mix(in srgb, var(--bmm-accent) 30%, transparent) 50%);
    transition: background .2s ease;
}
.aitp-card:hover{
    border-color: var(--accent);
    background: var(--paper-tint);
    box-shadow: 0 12px 30px -20px color-mix(in srgb, var(--bmm-accent) 40%, transparent);
}
.aitp-card:hover::after{ background: linear-gradient(135deg, transparent 50%, var(--accent) 50%); }
.aitp-card h3{
    font-family:'Fraunces', serif;
    font-weight: 500;
    font-size: 16px; line-height: 1.25;
    margin: 0; padding-right: 22px;
    color: var(--ink);
    letter-spacing: -0.005em;
}
.aitp-card p{
    font-size: 13px; line-height: 1.5;
    color: var(--ink-soft);
    margin: 0;
}

.aitp-foot{
    position: relative;
    text-align: center;
    background: color-mix(in srgb, var(--bmm-accent) 5%, transparent);
    border: 1px solid color-mix(in srgb, var(--bmm-accent) 25%, transparent);
    padding: clamp(20px, 3vw, 32px);
    border-radius: 2px;
}
.aitp-foot::before, .aitp-foot::after{
    content:""; position:absolute; width:14px; height:14px;
    border: 1px solid var(--accent); opacity:.85;
}
.aitp-foot::before{ top:-1px; left:-1px; border-right:none; border-bottom:none; }
.aitp-foot::after{ bottom:-1px; right:-1px; border-left:none; border-top:none; }
.aitp-foot h2{
    font-family:'Fraunces', serif; font-weight: 500;
    font-size: clamp(20px, 2.6vw, 24px);
    margin: 0 0 10px; letter-spacing: -0.01em;
}
.aitp-foot h2 em{ font-style: italic; color: var(--accent); font-weight: 400; }
.aitp-foot p{
    font-size: 14px; color: var(--ink-soft); line-height: 1.6;
    max-width: 50ch; margin: 0 auto 18px;
}

.aitp-wrap .rv{ opacity: 0; transform: translateY(8px); animation: aitp-rise .6s cubic-bezier(.2,.7,.25,1) forwards; }
.rv.d1{ animation-delay: .04s; } .rv.d2{ animation-delay: .12s; }
.rv.d3{ animation-delay: .20s; } .rv.d4{ animation-delay: .28s; }
.rv.d5{ animation-delay: .36s; } .rv.d6{ animation-delay: .44s; }
@keyframes aitp-rise{ to{ opacity:1; transform: none; } }
@media (prefers-reduced-motion: reduce){ .aitp-wrap .rv{ animation:none; opacity:1; transform: none; } }

@media (max-width: 540px){
    .aitp-cat-head{ flex-direction: column; align-items: flex-start; }
    .aitp-cat-head .count{ font-size: 12px; }
    .aitp-card{ padding: 14px 16px 16px; min-height: 0; }
    .aitp-card h3{ font-size: 15px; }
    .aitp-cta{ width: 100%; justify-content: center; }
}
