/* ============================================
   EasySites.ie — Websites made easy
   ============================================ */

:root{
    --sage:#2FA84A;
    --sage-dark:var(--sage);
    --sage-tint:#E4F5E7;
    --cream:#FBF9F4;
    --ink:#242820;
    --ink-soft:#5C6459;
    --line:#DDE3D4;
    --card-bg:#FFFFFF;
    --nav-bg:rgba(251,249,244,.9);
    --footer-bg:#1F7A38;
    color-scheme:light;
}

:root.dark{
    --sage:#3FC85E;
    --sage-dark:#7FDC94;
    --sage-tint:rgba(63,200,94,.14);
    --cream:#1a1d23;
    --ink:#e8eaed;
    --ink-soft:#9aa0a6;
    --line:#2d3139;
    --card-bg:#22262e;
    --nav-bg:rgba(26,29,35,.9);
    --footer-bg:#0d2818;
    color-scheme:dark;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth; scroll-padding-top: 70px;}
body{
    margin:0;
    background:var(--cream);
    color:var(--ink);
    font-family:Arial, Helvetica, sans-serif;
    -webkit-font-smoothing:antialiased;
    transition:background .2s ease, color .2s ease;
}

h1,h2,h3{
    font-family:Arial, Helvetica, sans-serif;
    font-weight:700;
    letter-spacing:-0.01em;
    margin:0;
}

a{color:inherit;}

.wrap{
    max-width:880px;
    margin:0 auto;
    padding:0 24px;
}

/* STICKY TOP BAR */
.site-top{
    position:sticky;
    top:0;
    z-index:50;
    background:var(--nav-bg);
    backdrop-filter:blur(10px);
    -webkit-backdrop-filter:blur(10px);
    border-bottom:1px solid var(--line);
}
.nav-row{
    display:flex;
    align-items:center;
    justify-content:center;
    gap:10px;
    padding:14px 24px;
    flex-wrap:wrap;
}
.nav-links{
    display:flex;
    align-items:center;
    gap:2px;
    background:var(--card-bg);
    border:1px solid var(--line);
    border-radius:8px;
    padding:4px;
}
.nav-links a{
    font-size:13px;
    font-weight:600;
    color:var(--ink-soft);
    text-decoration:none;
    padding:7px 14px;
    border-radius:5px;
    transition:background .15s ease, color .15s ease;
    white-space:nowrap;
}
.nav-links a:hover{
    background:var(--sage-tint);
    color:var(--sage-dark);
}
.nav-links .brand-link{
    font-size:17px;
    font-style:italic;
    font-weight:700;
    color:var(--ink);
    padding:7px 16px 7px 12px;
    margin-right:4px;
    border-right:1px solid var(--line);
    border-radius:0;
}
.nav-links .brand-link:hover{
    background:transparent;
    color:var(--ink);
}
.nav-links .brand-link span{
    color:var(--sage);
}
.theme-toggle{
    width:32px;
    height:32px;
    border-radius:8px;
    border:1px solid var(--line);
    background:var(--card-bg);
    display:flex;
    align-items:center;
    justify-content:center;
    cursor:pointer;
    flex:0 0 auto;
    transition:border-color .15s ease;
}
.theme-toggle:hover{
    border-color:var(--sage);
}
.theme-toggle svg{
    width:16px;
    height:16px;
}
.theme-toggle .moon{ display:none; }
:root.dark .theme-toggle .sun{ display:none; }
:root.dark .theme-toggle .moon{ display:block; }

/* HERO */
.hero{
    padding:64px 0 56px;
    text-align:center;
}
.eyebrow{
    display:inline-flex;
    align-items:center;
    gap:8px;
    font-size:13px;
    font-weight:600;
    letter-spacing:.06em;
    text-transform:uppercase;
    color:var(--sage-dark);
    background:var(--sage-tint);
    padding:6px 14px;
    border-radius:999px;
    margin-bottom:26px;
}
.hero h1{
    font-size:clamp(34px, 5.5vw, 54px);
    line-height:1.08;
    color:var(--ink);
    max-width:720px;
    margin:0 auto;
}
.hero h1 em{
    font-style:italic;
    color:var(--sage);
}
.hero p.lead{
    font-size:18px;
    line-height:1.6;
    color:var(--ink-soft);
    max-width:540px;
    margin:22px auto 0;
}

.hero-cta{
    margin-top:34px;
    display:flex;
    justify-content:center;
    gap:14px;
    flex-wrap:wrap;
}
.btn-primary{
    background:var(--sage);
    color:#fff;
    text-decoration:none;
    font-weight:600;
    font-size:15.5px;
    padding:14px 28px;
    border-radius:999px;
    position:relative;
    display:inline-block;
    transition:background .15s ease, transform .15s ease;
}
.btn-primary:hover{
    background:var(--sage-dark);
    transform:translateY(-1px);
}

/* cursor motif */
.cursor-nudge{
    position:relative;
    display:inline-flex;
}
.cursor-nudge svg{
    position:absolute;
    right:-22px;
    bottom:-14px;
    width:22px;
    height:22px;
    animation:click-nudge 2.2s ease-in-out infinite;
}
@keyframes click-nudge{
    0%,100%{ transform:translate(0,0) rotate(0deg); }
    50%{ transform:translate(-4px,-4px) rotate(-6deg); }
}
@media (prefers-reduced-motion: reduce){
    .cursor-nudge svg{ animation:none; }
}

/* SERVICES */
.services{
    padding:72px 0 12px;
}
.services .kicker{
    font-size:14px;
    font-weight:600;
    color:var(--ink-soft);
    text-transform:uppercase;
    letter-spacing:.06em;
    margin-bottom:12px;
    text-align:center;
}
.services h2{
    font-size:clamp(26px, 4vw, 34px);
    text-align:center;
    margin-bottom:40px;
}
.service-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:20px;
}
.service-card{
    background:var(--card-bg);
    border:1.5px solid var(--line);
    border-radius:16px;
    padding:28px 24px;
    text-align:left;
    transition:border-color .15s ease, transform .15s ease;
}
.service-card:hover{
    border-color:var(--sage);
    transform:translateY(-2px);
}
.service-card .icon{
    width:38px;
    height:38px;
    border-radius:10px;
    background:var(--sage-tint);
    display:flex;
    align-items:center;
    justify-content:center;
    margin-bottom:16px;
}
.service-card .icon svg{
    width:19px;
    height:19px;
}
.service-card h3{
    font-family:Arial, Helvetica, sans-serif;
    font-size:17px;
    font-weight:600;
    margin-bottom:8px;
}
.service-card p{
    font-size:14.5px;
    color:var(--ink-soft);
    line-height:1.55;
    margin:0;
}

/* WHY CHOOSE US */
.why{
    padding:72px 0;
    background:var(--sage-tint);
}
.why .kicker{
    font-size:14px;
    font-weight:600;
    color:var(--sage-dark);
    text-transform:uppercase;
    letter-spacing:.06em;
    margin-bottom:12px;
    text-align:center;
}
.why h2{
    font-size:clamp(26px, 4vw, 34px);
    text-align:center;
    margin-bottom:14px;
}
.why > .wrap > p{
    text-align:center;
    color:var(--ink-soft);
    font-size:15.5px;
    max-width:520px;
    margin:0 auto 40px;
    line-height:1.6;
}
.why-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:18px;
}
.why-card{
    background:var(--card-bg);
    border-radius:16px;
    padding:26px 24px;
    text-align:left;
}
.why-card .icon{
    width:38px;
    height:38px;
    border-radius:10px;
    background:var(--sage-tint);
    display:flex;
    align-items:center;
    justify-content:center;
    margin-bottom:16px;
}
.why-card .icon svg{
    width:19px;
    height:19px;
}
.why-card h3{
    font-family:Arial, Helvetica, sans-serif;
    font-size:16.5px;
    font-weight:600;
    margin-bottom:8px;
}
.why-card p{
    font-size:14px;
    color:var(--ink-soft);
    line-height:1.55;
    margin:0;
}

/* PRICING */
.pricing{
    padding:72px 0;
    text-align:center;
}
.pricing .kicker{
    font-size:14px;
    font-weight:600;
    color:var(--ink-soft);
    text-transform:uppercase;
    letter-spacing:.06em;
    margin-bottom:12px;
}
.pricing h2{
    font-size:clamp(26px, 4vw, 34px);
    margin-bottom:36px;
}
.price-card{
    max-width:380px;
    margin:0 auto;
    background:var(--card-bg);
    border:1.5px solid var(--line);
    border-radius:20px;
    padding:40px 32px;
    box-shadow:0 12px 30px -18px rgba(36,40,32,.18);
}
.price-card .amount{
    font-family:Arial, Helvetica, sans-serif;
    font-size:56px;
    color:var(--ink);
    line-height:1;
}
.price-card .amount sup{
    font-size:20px;
    font-family:Arial, Helvetica, sans-serif;
    font-weight:600;
    top:-1.6em;
    position:relative;
}
.price-card .amount .per{
    font-size:16px;
    font-family:Arial, Helvetica, sans-serif;
    color:var(--ink-soft);
    font-weight:500;
}
.price-card ul{
    list-style:none;
    padding:0;
    margin:26px 0 30px;
    text-align:left;
    display:inline-block;
}
.price-card li{
    font-size:14.5px;
    color:var(--ink-soft);
    padding:7px 0;
    padding-left:26px;
    position:relative;
}
.price-card li::before{
    content:"";
    position:absolute;
    left:0;
    top:12px;
    width:8px;
    height:8px;
    border-radius:50%;
    background:var(--sage-tint);
    border:1.5px solid var(--sage);
}
.price-card .btn-primary{
    display:block;
    width:100%;
}

/* CONTACT FORM */
.contact-form{
    padding:76px 0;
}
.contact-form .head{
    text-align:center;
    margin-bottom:44px;
}
.contact-form .head p{
    color:var(--ink-soft);
    font-size:15.5px;
    max-width:460px;
    margin:16px auto 0;
    line-height:1.6;
}
.contact-grid{
    display:grid;
    grid-template-columns:1.4fr 1fr;
    gap:24px;
    align-items:start;
}
.field{
    margin-bottom:20px;
}
.field label{
    display:block;
    font-size:13.5px;
    font-weight:600;
    margin-bottom:8px;
}
.field input,
.field textarea{
    width:100%;
    border:1.5px solid var(--line);
    border-radius:10px;
    padding:12px 14px;
    font-family:Arial, Helvetica, sans-serif;
    font-size:14.5px;
    color:var(--ink);
    background:var(--card-bg);
    outline:none;
    transition:border-color .15s ease;
}
.field input:focus,
.field textarea:focus{
    border-color:var(--sage);
}
.field textarea{
    min-height:120px;
    resize:vertical;
}
.contact-form form .btn-primary{
    border:none;
    cursor:pointer;
    font-family:Arial, Helvetica, sans-serif;
}
.contact-info{
    background:var(--sage-tint);
    border-radius:16px;
    padding:28px 24px;
}
.contact-info .row{
    display:flex;
    align-items:center;
    gap:12px;
    padding:11px 0;
    font-size:14.5px;
    color:var(--ink);
}
.contact-info .row svg{
    width:18px;
    height:18px;
    flex:0 0 auto;
}

/* Form feedback */
.form-feedback {
    font-size: 14px;
    font-weight: 500;
    min-height: 24px;
    margin-top: 12px;
}
.form-feedback.success {
    color: var(--sage);
}
.form-feedback.error {
    color: #ef4444;
}

/* FOOTER */
footer{
    background:var(--footer-bg);
    padding:22px 0;
    text-align:center;
}
footer .fine{
    font-size:12.5px;
    color:#CFDDC7;
    letter-spacing:.02em;
}

/* RESPONSIVE */
@media (max-width:640px){
    .nav-row {
        gap: 8px;
        padding: 10px 12px;
    }
    .nav-links {
        flex-wrap: wrap;
        justify-content: center;
    }
    .nav-links a {
        font-size: 12px;
        padding: 6px 10px;
    }
    .nav-links .brand-link {
        font-size: 15px;
        padding: 6px 12px 6px 10px;
        width: 100%;
        border-right: none;
        border-bottom: 1px solid var(--line);
        text-align: center;
        margin-right: 0;
        margin-bottom: 2px;
    }
    .service-grid{
        grid-template-columns:1fr;
    }
    .why-grid{
        grid-template-columns:1fr;
    }
    .contact-grid{
        grid-template-columns:1fr;
    }
    .hero h1 {
        font-size: clamp(28px, 7vw, 34px);
    }
    .hero p.lead {
        font-size: 16px;
    }
    .price-card .amount {
        font-size: 44px;
    }
}
