/* PHANTASO CMS — Frontend (Tailwind-compatible utilities) */
*,::after,::before{box-sizing:border-box}
body.phantaso-body{margin:0;font-family:var(--phantaso-font-body,Inter),system-ui,sans-serif;background:var(--phantaso-bg,#fff);color:var(--phantaso-primary,#0f172a);-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
.phantaso-container{max-width:80rem;margin:0 auto;padding:0 1rem}
.phantaso-header{border-bottom:1px solid #e2e8f0;background:#fff;position:sticky;top:0;z-index:40}
.phantaso-header__inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 0}
.phantaso-site-title{font-size:1.25rem;font-weight:700}
.phantaso-nav__list{display:none;list-style:none;margin:0;padding:0;gap:1.5rem;align-items:center}
@media(min-width:768px){.phantaso-nav__list{display:flex}}
.phantaso-nav__list a{font-size:.875rem;font-weight:500;color:#334155}
.phantaso-nav__list a:hover{color:#2563eb}
.phantaso-header--02 .phantaso-header__inner{flex-wrap:wrap;align-items:flex-start}
.phantaso-header--02 .phantaso-nav__list{flex-wrap:wrap;gap:.5rem 1rem;row-gap:.35rem}
.phantaso-header--02 .phantaso-nav__list a{font-size:.8125rem}
.phantaso-home-categories .phantaso-post-grid{padding:0}
.phantaso-breaking-band{background:#dc2626;color:#fff;font-size:.8125rem}
.phantaso-breaking-band__inner{display:flex;align-items:center;gap:.75rem;padding:.45rem 1rem;overflow:hidden}
.phantaso-breaking-band__label{font-size:.6875rem;letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;background:rgba(0,0,0,.15);padding:.2rem .5rem;border-radius:.25rem}
.phantaso-breaking-band__viewport{flex:1;overflow:hidden}
.phantaso-breaking-band__track{display:inline-flex;gap:2rem;white-space:nowrap}
.phantaso-breaking-band__track a{color:#fff;font-weight:500}
.phantaso-breaking-band__track a:hover{text-decoration:underline}
.phantaso-mobile-drawer{position:fixed;inset:0;z-index:100;pointer-events:none;visibility:hidden}
.phantaso-mobile-drawer.is-open{pointer-events:auto;visibility:visible}
.phantaso-mobile-drawer__backdrop{position:absolute;inset:0;background:rgba(15,23,42,.55);opacity:0;transition:opacity .2s}
.phantaso-mobile-drawer.is-open .phantaso-mobile-drawer__backdrop{opacity:1}
.phantaso-mobile-drawer__panel{position:absolute;top:0;right:0;height:100%;width:min(20rem,88vw);background:#fff;transform:translateX(100%);transition:transform .25s ease;padding:1.25rem 1rem;overflow-y:auto;box-shadow:-4px 0 24px rgba(0,0,0,.12)}
.phantaso-mobile-drawer.is-open .phantaso-mobile-drawer__panel{transform:translateX(0)}
.phantaso-mobile-drawer__close{position:absolute;top:.75rem;right:.75rem;background:none;border:0;font-size:1.75rem;line-height:1;cursor:pointer;color:#64748b}
.phantaso-mobile-drawer__list{list-style:none;margin:2rem 0 0;padding:0;display:flex;flex-direction:column;gap:.25rem}
.phantaso-mobile-drawer__list a{display:block;padding:.65rem .5rem;border-radius:.375rem;font-size:.9375rem;font-weight:500;color:#0f172a}
.phantaso-mobile-drawer__list a:hover{background:#f1f5f9;color:var(--phantaso-link,#2563eb)}
body.phantaso-drawer-open{overflow:hidden}
.phantaso-nav--desktop{display:none}
@media(min-width:1024px){.phantaso-nav--desktop{display:block}.phantaso-mobile-toggle{display:none!important}}
.phantaso-footer--02{background:#0f172a;color:#cbd5e1;margin-top:0}
.phantaso-footer__widgets{display:grid;gap:1.5rem;padding:2.5rem 1rem 1.5rem}
@media(min-width:768px){.phantaso-footer__widgets{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.phantaso-footer__widgets{grid-template-columns:repeat(4,1fr)}}
.phantaso-footer--02 .phantaso-footer-widget-title{color:#fff;font-size:.875rem;margin:0 0 .75rem}
.phantaso-footer--02 a{color:#93c5fd}
.phantaso-footer__bottom{border-top:1px solid rgba(255,255,255,.08);padding:1.25rem 1rem}
.phantaso-footer__bottom-inner{display:flex;flex-direction:column;align-items:center;gap:.75rem;text-align:center;font-size:.8125rem}
.phantaso-footer-nav{display:flex;flex-wrap:wrap;justify-content:center;gap:.75rem 1.25rem;list-style:none;margin:0;padding:0}
.phantaso-footer__brand{font-weight:600;color:#fff;margin:0}
.phantaso-footer__copy{margin:0;opacity:.7;font-size:.75rem}
.phantaso-nav.is-open .phantaso-nav__list{display:flex;flex-direction:column;position:absolute;top:100%;left:0;right:0;background:#fff;padding:1rem;border-bottom:1px solid #e2e8f0}
.phantaso-mobile-toggle{display:flex;flex-direction:column;gap:.375rem;padding:.5rem;background:none;border:0;cursor:pointer}
@media(min-width:768px){.phantaso-mobile-toggle{display:none}}
.phantaso-mobile-toggle span{display:block;height:2px;width:1.5rem;background:#1e293b}
.phantaso-main{padding:1.5rem 0}
.phantaso-post-grid{display:grid;gap:1.5rem;padding:2rem 0}
@media(min-width:640px){.phantaso-post-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.phantaso-post-grid{grid-template-columns:repeat(3,1fr)}}
.phantaso-card{border:1px solid #e2e8f0;border-radius:.75rem;overflow:hidden;background:#fff;box-shadow:0 1px 2px rgba(0,0,0,.05);transition:box-shadow .2s}
.phantaso-card:hover{box-shadow:0 4px 12px rgba(0,0,0,.08)}
.phantaso-card__thumb img{width:100%;height:12rem;object-fit:cover}
.phantaso-card__body{padding:1rem}
.phantaso-card__title{font-size:1.125rem;font-weight:600;line-height:1.375}
.phantaso-card__title a:hover{color:#2563eb}
.phantaso-card__excerpt{color:#64748b;font-size:.875rem}
.phantaso-card__date{font-size:.75rem;color:#94a3b8}
.phantaso-article__title{font-size:2rem;font-weight:700;line-height:1.2}
@media(min-width:768px){.phantaso-article__title{font-size:2.25rem}}
.phantaso-article__meta{display:flex;flex-wrap:wrap;gap:.75rem;font-size:.875rem;color:#64748b;margin-top:.75rem}
.phantaso-article__featured{margin:1.5rem 0;border-radius:.75rem;overflow:hidden}
.phantaso-article__content{line-height:1.75;margin-top:2rem}
.phantaso-breadcrumb{font-size:.875rem;color:#64748b;margin-bottom:1rem}
.phantaso-breadcrumb-sep{margin:0 .5rem;color:#cbd5e1}
.phantaso-toc{border:1px solid #e2e8f0;background:#f8fafc;border-radius:.5rem;padding:1rem;margin-bottom:2rem}
.phantaso-toc ol{margin:.5rem 0 0 1.25rem;padding:0}
.phantaso-author-box{display:flex;gap:1rem;padding:1.5rem;margin-top:2.5rem;border-radius:.75rem;background:#f8fafc;border:1px solid #e2e8f0}
.phantaso-author-box img{border-radius:50%}
.phantaso-footer{border-top:1px solid #e2e8f0;background:#f8fafc;margin-top:3rem;padding:2rem 0}
.phantaso-footer__bottom{display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem;font-size:.875rem;color:#64748b}
.phantaso-footer-nav{display:flex;gap:1rem;list-style:none;margin:0;padding:0}
.phantaso-btn{display:inline-flex;align-items:center;justify-content:center;border-radius:.5rem;background:#2563eb;color:#fff;padding:.5rem 1rem;font-size:.875rem;font-weight:500;border:0;cursor:pointer}
.phantaso-btn:hover{background:#1d4ed8}
.phantaso-calculator{border:1px solid #e2e8f0;border-radius:.75rem;padding:1.5rem;margin:1.5rem 0}
.phantaso-calc-form label{display:block;font-size:.875rem;font-weight:500;margin-bottom:1rem}
.phantaso-calc-form input{margin-top:.25rem;width:100%;border:1px solid #cbd5e1;border-radius:.5rem;padding:.5rem .75rem}
.phantaso-calc-result{margin-top:1rem;font-weight:600;color:#0f172a}
.phantaso-hero-card{position:relative;border-radius:1rem;overflow:hidden}
.phantaso-hero-card__body{position:absolute;bottom:0;left:0;right:0;padding:2rem;background:linear-gradient(transparent,rgba(0,0,0,.8));color:#fff}
.phantaso-hero-card__body h2{font-size:1.75rem;margin:0 0 .5rem}
.phantaso-sidebar{padding:1.5rem 0}
.phantaso-widget{margin-bottom:1.5rem}
.phantaso-widget-title{font-size:1rem;font-weight:600;margin:0 0 .75rem}
.phantaso-widget-list{list-style:none;margin:0;padding:0}
.phantaso-widget-list__item{display:flex;gap:.75rem;margin-bottom:.75rem}
.phantaso-news-ticker{overflow:hidden;white-space:nowrap}
.phantaso-news-ticker__track{display:inline-flex;gap:2rem}
@keyframes phantaso-ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}
html.phantaso-dark{color-scheme:dark}
html.phantaso-dark body{background:#0f172a;color:#e2e8f0}
html.phantaso-dark .phantaso-header{background:#1e293b;border-color:#334155}
html.phantaso-dark .phantaso-card,html.phantaso-dark .phantaso-widget{background:#1e293b;border-color:#334155}
html.phantaso-dark a{color:#93c5fd}

/* Homepage portal layout */
.phantaso-homepage--10{background:#f8fafc}
.phantaso-homepage__inner{padding:1.5rem 1rem 2.5rem;display:flex;flex-direction:column;gap:1.5rem}
.phantaso-homepage__grid{display:grid;grid-template-columns:1fr;gap:1.5rem}
@media(min-width:1024px){.phantaso-homepage__grid{grid-template-columns:1fr 2fr 1fr;align-items:start}}
.phantaso-home-zone{background:#fff;border:1px solid #e2e8f0;border-radius:.875rem;padding:1rem}
.phantaso-home-zone--top,.phantaso-home-zone--middle,.phantaso-home-zone--bottom{background:transparent;border:0;padding:0}
.phantaso-home-zone .phantaso-widget{margin-bottom:1rem}
.phantaso-home-zone .phantaso-widget:last-child{margin-bottom:0}
.phantaso-home-categories{margin-top:.5rem;padding-top:1.5rem;border-top:1px solid #e2e8f0}
.phantaso-home-cat-strip{margin-bottom:2rem}
.phantaso-home-cat-strip__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;gap:1rem}
.phantaso-home-cat-strip__more{font-size:.8125rem;color:var(--phantaso-link,#2563eb);white-space:nowrap;font-weight:500}
.phantaso-home-categories__title{font-size:1.125rem;font-weight:700;margin:0;padding-bottom:.35rem;border-bottom:2px solid var(--phantaso-primary,#2563eb);display:inline-block}
.phantaso-home-categories__title a{color:inherit}
.phantaso-headline{border-radius:.75rem;overflow:hidden}
.phantaso-headline__hero img{border-radius:.75rem}
.phantaso-widget-title{position:relative;padding-left:.75rem}
.phantaso-widget-title::before{content:"";position:absolute;left:0;top:.15em;bottom:.15em;width:3px;border-radius:2px;background:var(--phantaso-primary,#2563eb)}
.phantaso-card__title{font-size:1.0625rem;line-height:1.35}
.phantaso-card__thumb img{height:11rem;transition:transform .3s}
.phantaso-card:hover .phantaso-card__thumb img{transform:scale(1.03)}
.phantaso-hero-card{border-radius:1rem;box-shadow:0 8px 24px rgba(0,0,0,.12)}
.phantaso-hero-card img{min-height:320px;object-fit:cover}
.phantaso-news-ticker{background:#0f172a;color:#fff;border-radius:.5rem;padding:.5rem .75rem;font-size:.8125rem}
.phantaso-news-ticker__track a{color:#fff}
.phantaso-news-ticker__track a:hover{color:#93c5fd}
