/* ================================================================
   TSS Creator Blueprint — Master Stylesheet
   Place at: public_html/assets/style.css
   ================================================================ */

/* RESET */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
    font-family:"Poppins",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
    background:#fff;color:#0f172a;line-height:1.6;
}

/* LAYOUT */
.container{width:100%;max-width:1120px;margin:0 auto;padding:0 1.25rem}
img{max-width:100%;height:auto;display:block}

/* ——— HEADER & NAV ——————————————————————————————————————————————— */
.site-header{position:sticky;top:0;z-index:100;background:#fff;box-shadow:0 1px 4px rgba(15,23,42,.08)}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:.9rem 1.25rem}
.logo-wrapper{display:flex;align-items:center;text-decoration:none;color:#0f172a}
.site-logo{height:44px;width:auto;border-radius:6px}
.logo-text{margin-left:.6rem;font-weight:600;font-size:1.1rem}

.main-nav ul{list-style:none;display:flex;gap:1.1rem}
.nav-link{
    position:relative;text-decoration:none;font-size:.95rem;color:#374151;
    padding:.25rem 0;transition:color .2s ease,transform .2s ease;
}
.nav-link::after{
    content:"";position:absolute;left:0;bottom:-4px;width:0;height:2px;
    background:#1a73e8;transition:width .25s ease;
}
.nav-link:hover{color:#1a73e8;transform:translateY(-1px)}
.nav-link:hover::after{width:100%}
.nav-link-active{color:#1a73e8;font-weight:600}
.nav-link-active::after{width:100%}

/* Mobile toggle */
.nav-toggle{display:none}
.nav-toggle-label{display:none;cursor:pointer}
.nav-toggle-label span,
.nav-toggle-label span::before,
.nav-toggle-label span::after{
    display:block;width:22px;height:2px;background:#111827;
    border-radius:999px;position:relative;transition:transform .2s ease,opacity .2s ease;
}
.nav-toggle-label span::before,.nav-toggle-label span::after{content:"";position:absolute;left:0}
.nav-toggle-label span::before{top:-7px}
.nav-toggle-label span::after{top:7px}

/* ——— HERO —————————————————————————————————————————————————————— */
.site-main{padding-bottom:0}
.hero{background:radial-gradient(circle at top left,#e0f2fe 0,#fff 55%);padding:3.5rem 0 3rem}
.hero-grid{display:grid;grid-template-columns:minmax(0,2fr) minmax(0,1.5fr);gap:2.5rem;align-items:center}
.hero-text h1{font-size:2.4rem;line-height:1.2;margin-bottom:1rem}
.hero-text p{max-width:32rem;color:#4b5563;margin-bottom:1.75rem}
.hero-btns{display:flex;gap:.75rem;flex-wrap:wrap}
.hero-panel{display:flex;justify-content:flex-end}
.hero-card{
    background:#fff;border-radius:1rem;padding:1.6rem 1.5rem;
    box-shadow:0 18px 40px rgba(15,23,42,.14);border:1px solid rgba(148,163,184,.3);
}
.hero-card h2{font-size:1.1rem;margin-bottom:.7rem}
.home-logo{max-width:220px;margin:0 auto;border-radius:12px}

/* ——— BUTTONS ——————————————————————————————————————————————————— */
.btn-primary,.btn-outline{
    display:inline-flex;align-items:center;justify-content:center;
    padding:.7rem 1.4rem;border-radius:999px;border:1px solid transparent;
    font-size:.95rem;font-weight:500;text-decoration:none;cursor:pointer;
    transition:background .2s ease,color .2s ease,box-shadow .2s ease,transform .15s ease;
}
.btn-primary{background:linear-gradient(135deg,#1a73e8,#2563eb);color:#fff;box-shadow:0 10px 30px rgba(37,99,235,.35)}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 14px 36px rgba(37,99,235,.45)}
.btn-outline{background:#fff;color:#1a73e8;border-color:#1a73e8}
.btn-outline:hover{background:#1a73e8;color:#fff}

/* ——— SECTIONS —————————————————————————————————————————————————— */
.section{padding:3rem 0}
.section-light{background:#fff}
.section-muted{background:#f3f4f6}
.section h2{font-size:1.6rem;margin-bottom:.9rem}
.section p{color:#4b5563;margin-bottom:.8rem}

.split{display:grid;grid-template-columns:minmax(0,2.2fr) minmax(0,1.3fr);gap:2rem;align-items:flex-start}
.cards-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:2.2rem}
.cards-3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1.5rem}

.feature-card{
    background:#fff;border-radius:.9rem;padding:1.4rem 1.25rem;
    box-shadow:0 8px 24px rgba(15,23,42,.08);border:1px solid rgba(148,163,184,.2);
}
.feature-card h3{margin-bottom:.5rem;font-size:1.05rem}

.info-card{
    background:#fff;border-radius:.9rem;padding:1.4rem 1.25rem;
    box-shadow:0 8px 24px rgba(15,23,42,.12);border:1px solid rgba(148,163,184,.35);
}
.info-card h3{margin-bottom:.5rem}

.bullet-list{list-style:disc;margin-left:1.1rem;margin-bottom:.6rem;color:#4b5563}
.bullet-list li{margin-bottom:.35rem}
.numbered{list-style:decimal}

/* ——— CONTACT FORM —————————————————————————————————————————————— */
.contact-form{margin-top:1rem}
.form-row{margin-bottom:1rem}
.form-row label{display:block;font-weight:500;margin-bottom:.3rem;font-size:.92rem}
.form-row input[type="text"],
.form-row input[type="email"],
.form-row textarea{
    width:100%;padding:.6rem .75rem;border:1px solid #cbd5e1;border-radius:8px;
    font-family:inherit;font-size:.92rem;transition:border-color .2s ease,box-shadow .2s ease;
}
.form-row input:focus,
.form-row textarea:focus{outline:none;border-color:#1a73e8;box-shadow:0 0 0 3px rgba(26,115,232,.15)}
.form-row textarea{resize:vertical}

.form-row-half{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.req{color:#dc2626}

/* Checkbox */
.checkbox-row{margin-top:.5rem}
.checkbox-label{display:flex;align-items:flex-start;gap:.5rem;font-size:.88rem;color:#4b5563;cursor:pointer}
.checkbox-label input{margin-top:3px;accent-color:#1a73e8}

/* CAPTCHA */
.captcha-row{margin-top:.75rem}
.captcha-box{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}
.captcha-code{
    display:inline-block;padding:.5rem 1rem;background:#0f172a;color:#facc15;
    font-size:1.4rem;font-weight:700;letter-spacing:6px;border-radius:6px;
    font-family:"Courier New",monospace;user-select:none;
}
.captcha-box input{max-width:200px}

/* Alerts */
.alert{padding:1rem 1.25rem;border-radius:8px;margin-bottom:1.25rem;font-size:.92rem}
.alert-success{background:#dcfce7;border:1px solid #86efac;color:#166534}
.alert-error{background:#fee2e2;border:1px solid #fca5a5;color:#991b1b}
.alert ul{margin:.25rem 0 0 1rem}

.form-note{margin-top:1.25rem;font-size:.82rem;color:#6b7280;line-height:1.5}

/* ——— FOOTER ——————————————————————————————————————————————————— */
.site-footer-wrapper{
    background:linear-gradient(135deg,#1a73e8,#1d4ed8);
    color:#ffffff;
    margin-top:2rem;padding:1.7rem 0 1.9rem;font-size:.85rem;text-align:center;
}
.site-footer-wrapper *{color:#ffffff}
.site-footer-wrapper a{color:#ffffff;text-decoration:none;transition:opacity .2s ease}
.site-footer-wrapper a:hover{color:#ffffff;opacity:.8;text-decoration:underline}
.site-footer-wrapper strong{color:#ffffff}
.site-footer-wrapper em{color:#ffffff}

/* ——— RESPONSIVE ——————————————————————————————————————————————— */
@media(max-width:900px){
    .hero-grid,.split,.cards-2,.cards-3{grid-template-columns:1fr}
    .hero{padding-top:3rem}
    .hero-text h1{font-size:2rem}
}

@media(max-width:720px){
    .header-inner{gap:.75rem}
    .nav-toggle-label{display:block}
    .main-nav{
        position:absolute;top:100%;right:0;left:0;background:#fff;
        box-shadow:0 6px 16px rgba(15,23,42,.12);
        opacity:0;visibility:hidden;transform:translateY(-10px);
        transition:opacity .2s ease,transform .2s ease,visibility .2s ease;
    }
    .main-nav ul{flex-direction:column;padding:.75rem 1.25rem 1rem;gap:.4rem}
    .nav-link{display:block}
    .nav-toggle:checked ~ .nav-toggle-label span{transform:rotate(45deg)}
    .nav-toggle:checked ~ .nav-toggle-label span::before{transform:rotate(90deg);top:0}
    .nav-toggle:checked ~ .nav-toggle-label span::after{opacity:0}
    .nav-toggle:checked ~ .main-nav{opacity:1;visibility:visible;transform:translateY(0)}
    .btn-primary,.btn-outline{width:100%;justify-content:center}
    .form-row-half{grid-template-columns:1fr}
    .captcha-box{flex-direction:column;align-items:flex-start}
    .captcha-box input{max-width:100%}
}
