
/* Moroka Modikoe Trading - Static Stylesheet */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap');

:root{
  --background:#ffffff; --foreground:#1a1a1a;
  --primary:#008080; --primary-fg:#ffffff;
  --secondary:#2f5959; --accent:#00b3b3;
  --muted:#f5f8f8; --muted-fg:#5b6b73;
  --border:#e2e8f0; --surface-dark:#1a1a1a;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;color:var(--foreground);background:var(--background);line-height:1.5;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}

.container{max-width:1400px;margin:0 auto;padding:0 1rem}
@media(min-width:768px){.container{padding:0 2rem}}
.section{padding:5rem 1rem}
@media(min-width:768px){.section{padding:7rem 2rem}}

/* Header / Navbar */
.header{position:fixed;top:0;left:0;right:0;z-index:50;background:rgba(255,255,255,.95);backdrop-filter:blur(6px);border-bottom:1px solid var(--border)}
.nav{display:flex;align-items:center;justify-content:space-between;height:64px;max-width:1400px;margin:0 auto;padding:0 1rem}
@media(min-width:768px){.nav{padding:0 2rem}}
.logo img{height:48px;width:auto;object-fit:contain}
@media(min-width:768px){.logo img{height:56px}}
.nav-links{display:none;gap:2rem;align-items:center}
@media(min-width:1024px){.nav-links{display:flex}}
.nav-links a{font-size:.875rem;font-weight:500;text-transform:uppercase;letter-spacing:.1em;transition:color .2s}
.nav-links a:hover,.nav-links a.active{color:var(--primary)}
.nav-cta{display:none;gap:1rem;align-items:center}
@media(min-width:1024px){.nav-cta{display:flex}}
.nav-phone{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--muted-fg);transition:color .2s}
.nav-phone:hover{color:var(--primary)}
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.875rem 2rem;font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;cursor:pointer;border:none;transition:all .2s;text-align:center;justify-content:center}
.btn-primary{background:var(--primary);color:var(--primary-fg)}
.btn-primary:hover{background:var(--secondary)}
.btn-outline{background:transparent;color:var(--primary-fg);border:1px solid rgba(255,255,255,.3)}
.btn-outline:hover{background:rgba(255,255,255,.1)}
.btn-dark{background:var(--surface-dark);color:var(--primary-fg)}
.btn-dark:hover{background:#000}

.menu-toggle{display:block;background:none;border:none;cursor:pointer;padding:.5rem;color:var(--foreground)}
@media(min-width:1024px){.menu-toggle{display:none}}
.menu-toggle svg{width:24px;height:24px}
.mobile-menu{display:none;background:var(--background);border-top:1px solid var(--border)}
.mobile-menu.open{display:block}
.mobile-menu nav{display:flex;flex-direction:column;padding:1rem;gap:.25rem}
.mobile-menu a{padding:.875rem 1rem;font-size:.875rem;font-weight:500;text-transform:uppercase;letter-spacing:.08em;transition:background .2s}
.mobile-menu a:hover,.mobile-menu a.active{background:var(--muted);color:var(--primary)}
.mobile-menu .btn{margin-top:.5rem}

main{padding-top:0}

/* Hero */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden;color:#fff;text-align:center}
.hero-bg{position:absolute;inset:0}
.hero-bg img{width:100%;height:100%;object-fit:cover}
.hero-bg::after{content:"";position:absolute;inset:0;background:rgba(26,26,26,.8)}
.hero-content{position:relative;z-index:2;padding:0 1rem;max-width:1100px}
.eyebrow{font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.3em;color:var(--primary);margin-bottom:1.5rem}
.hero h1{font-size:clamp(2.25rem,5vw,4.5rem);font-weight:700;line-height:1.1;letter-spacing:-.02em}
.hero p.lead{margin-top:1.5rem;font-size:1.125rem;opacity:.8;max-width:640px;margin-left:auto;margin-right:auto}
@media(min-width:768px){.hero p.lead{font-size:1.25rem}}
.hero-buttons{margin-top:2.5rem;display:flex;flex-direction:column;gap:1rem;align-items:center;justify-content:center}
@media(min-width:640px){.hero-buttons{flex-direction:row}}

/* Page hero */
.page-hero{background:var(--surface-dark);color:#fff;padding:8rem 1rem 5rem}
@media(min-width:768px){.page-hero{padding:8rem 2rem 5rem}}
.page-hero .eyebrow{margin-bottom:1rem}
.page-hero h1{font-size:clamp(2.25rem,5vw,3.75rem);font-weight:700;letter-spacing:-.02em;line-height:1.1}
.page-hero p{margin-top:1rem;font-size:1.125rem;color:var(--muted-fg);max-width:640px}

/* Section heads */
.section-head{text-align:center;margin-bottom:4rem}
.section-head h2{font-size:clamp(1.875rem,4vw,3rem);font-weight:700;letter-spacing:-.02em}
.section-head p{margin-top:1rem;color:var(--muted-fg);max-width:640px;margin-left:auto;margin-right:auto}

/* Grid utilities */
.grid{display:grid;gap:1.5rem}
.grid-2{grid-template-columns:1fr}
.grid-3{grid-template-columns:1fr}
.grid-4{grid-template-columns:1fr}
@media(min-width:640px){.grid-4{grid-template-columns:repeat(2,1fr)}}
@media(min-width:768px){.grid-2{grid-template-columns:repeat(2,1fr)} .grid-3{grid-template-columns:repeat(3,1fr)}}
@media(min-width:1024px){.grid-4{grid-template-columns:repeat(4,1fr)}}

/* Service card */
.service-card{display:block;border:1px solid var(--border);transition:border-color .2s;height:100%;background:#fff}
.service-card:hover{border-color:var(--primary)}
.service-card .img{aspect-ratio:4/3;overflow:hidden}
.service-card .img img{width:100%;height:100%;object-fit:cover;transition:transform .5s,filter .5s;filter:saturate(.8)}
.service-card:hover .img img{filter:saturate(1);transform:scale(1.05)}
.service-card .body{padding:1.5rem}
.service-card .meta{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}
.service-card .meta .num{font-family:monospace;font-size:.75rem;color:var(--muted-fg)}
.service-card h3{font-size:1.125rem;font-weight:600;margin-bottom:.5rem;transition:color .2s}
.service-card:hover h3{color:var(--primary)}
.service-card p{font-size:.875rem;color:var(--muted-fg);line-height:1.6}

.icon{width:20px;height:20px;color:var(--primary);flex-shrink:0}
.icon-lg{width:32px;height:32px;color:var(--primary)}

/* About / Two-col */
.two-col{display:grid;gap:4rem;align-items:center;grid-template-columns:1fr}
@media(min-width:1024px){.two-col{grid-template-columns:1fr 1fr}}
.two-col h2{font-size:clamp(1.875rem,3.5vw,2.5rem);font-weight:700;letter-spacing:-.02em;margin-bottom:1.5rem}
.two-col p{color:var(--muted-fg);line-height:1.7;margin-bottom:1rem}
.image-stat{position:relative}
.image-stat .badge{position:absolute;bottom:-1.5rem;right:-1.5rem;background:var(--primary);color:#fff;padding:1.5rem;display:none}
@media(min-width:768px){.image-stat .badge{display:block}}
.image-stat .badge .v{font-size:1.875rem;font-weight:700}
.image-stat .badge .l{font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;margin-top:.25rem}

.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:2rem}
.stat{border-left:2px solid var(--primary);padding-left:1rem}
.stat .v{font-size:1.5rem;font-weight:700;color:var(--primary)}
.stat .l{font-size:.75rem;color:var(--muted-fg);text-transform:uppercase;letter-spacing:.08em}

.bg-muted{background:var(--muted)}
.bg-dark{background:var(--surface-dark);color:#fff}
.bg-dark .muted-fg,.bg-dark p{color:rgba(255,255,255,.8)}
.bg-primary{background:var(--primary);color:#fff}

.check-list{display:grid;gap:1rem}
.check-list li{display:flex;align-items:flex-start;gap:.75rem;font-size:.875rem}
.check-list svg{flex-shrink:0;margin-top:2px}

.stats-boxes{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}
.stat-box{border:1px solid rgba(0,179,179,.2);padding:2rem}
.stat-box.featured{background:var(--primary);color:#fff}
.stat-box .v{font-size:1.875rem;font-weight:700;margin-bottom:.5rem}
.stat-box .l{font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;opacity:.7}

/* Cards (values, contact) */
.card{border:1px solid var(--border);padding:2rem;background:#fff;height:100%;transition:border-color .2s}
.card:hover{border-color:var(--primary)}
.card h3{font-size:1.125rem;font-weight:600;margin:.75rem 0}
.card p{font-size:.875rem;color:var(--muted-fg);line-height:1.6}
.card-lg{padding:2.5rem}
.card-lg .head{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem}
.card-lg h3{font-size:1.25rem;margin:0}
.card-lg p{font-size:1rem}

/* Services detail */
.service-detail{display:grid;gap:4rem;align-items:center;grid-template-columns:1fr}
@media(min-width:1024px){.service-detail{grid-template-columns:1fr 1fr}}
.service-detail.reverse .img-col{order:0}
@media(min-width:1024px){.service-detail.reverse .img-col{order:2}}
.service-detail img{width:100%;transition:transform .5s}
.service-detail .img-wrap{overflow:hidden}
.service-detail img:hover{transform:scale(1.05)}
.service-detail .num{font-family:monospace;font-size:.75rem;color:var(--muted-fg);margin-bottom:.75rem}
.service-detail h2{font-size:clamp(1.875rem,3.5vw,2.5rem);font-weight:700;letter-spacing:-.02em;margin-bottom:1rem}
.service-detail .desc{color:var(--muted-fg);margin-bottom:2rem;line-height:1.7}
.feature-list{display:grid;gap:.75rem;margin-bottom:2rem}
.feature-list li{display:flex;align-items:flex-start;gap:.75rem;font-size:.875rem;color:var(--muted-fg)}
.feature-list li::before{content:"";width:6px;height:6px;background:var(--primary);border-radius:50%;margin-top:.6rem;flex-shrink:0}

/* Gallery */
.gallery-tabs{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-bottom:3rem}
.tab{padding:.625rem 1.25rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;background:var(--muted);color:var(--muted-fg);border:none;cursor:pointer;transition:all .2s}
.tab:hover{color:var(--foreground)}
.tab.active{background:var(--primary);color:#fff}
.gallery-grid{display:grid;grid-template-columns:1fr;gap:1rem}
@media(min-width:640px){.gallery-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.gallery-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:1280px){.gallery-grid{grid-template-columns:repeat(4,1fr)}}
.g-item{position:relative;overflow:hidden;aspect-ratio:4/3}
.g-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s,filter .5s;filter:saturate(.8)}
.g-item:hover img{transform:scale(1.05);filter:saturate(1)}
.g-overlay{position:absolute;inset:0;background:rgba(26,26,26,0);transition:background .3s;display:flex;align-items:flex-end}
.g-item:hover .g-overlay{background:rgba(26,26,26,.6)}
.g-overlay .t{padding:1rem;transform:translateY(100%);transition:transform .3s}
.g-item:hover .g-overlay .t{transform:translateY(0)}
.g-overlay .cat{font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:var(--accent)}
.g-overlay .name{font-size:.875rem;font-weight:600;color:#fff;margin-top:.25rem}

/* Contact */
.contact-info-grid{display:grid;grid-template-columns:1fr;gap:1.5rem;margin-bottom:5rem}
@media(min-width:768px){.contact-info-grid{grid-template-columns:repeat(3,1fr)}}
.contact-card{border:1px solid var(--border);padding:2rem;text-align:center;transition:border-color .2s}
.contact-card:hover{border-color:var(--primary)}
.contact-card .icon-lg{margin:0 auto 1rem;display:block}
.contact-card h3{font-size:1.125rem;font-weight:600;margin-bottom:.75rem}
.contact-card p{font-size:.875rem;color:var(--muted-fg);margin-bottom:.25rem}
.contact-card a{transition:color .2s}
.contact-card a:hover{color:var(--primary)}

.contact-grid{display:grid;gap:3rem;grid-template-columns:1fr}
@media(min-width:1024px){.contact-grid{grid-template-columns:1fr 1fr}}
.form-grid{display:grid;gap:1.25rem}
label{display:block;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;margin-bottom:.5rem;color:var(--muted-fg)}
input,textarea{width:100%;border:1px solid var(--border);background:#fff;padding:.875rem 1rem;font-size:.875rem;font-family:inherit;transition:border-color .2s}
input:focus,textarea:focus{outline:none;border-color:var(--primary)}
textarea{resize:none;min-height:140px}
.form-msg{padding:1rem;font-size:.875rem;margin-bottom:1rem;display:none}
.form-msg.success{display:block;background:#d1fae5;color:#065f46;border:1px solid #6ee7b7}
.form-msg.error{display:block;background:#fee2e2;color:#991b1b;border:1px solid #fca5a5}
.map-wrap{height:100%;min-height:400px}
.map-wrap iframe{width:100%;height:100%;min-height:400px;border:0}

/* Footer */
.footer{background:var(--surface-dark);color:#fff}
.footer .grid-4{padding:5rem 1rem 2rem;gap:3rem}
@media(min-width:768px){.footer .grid-4{padding:7rem 2rem 2rem}}
.footer img.logo-img{height:96px;width:auto;margin-bottom:1.5rem;filter:brightness(2)}
.footer p{font-size:.875rem;opacity:.7;line-height:1.7}
.footer h4{font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.12em;margin-bottom:1.5rem;color:var(--accent)}
.footer .links{display:flex;flex-direction:column;gap:.75rem}
.footer .links a,.footer .contact-block a,.footer .contact-block div{font-size:.875rem;opacity:.7;transition:all .2s;display:flex;align-items:flex-start;gap:.75rem}
.footer .links a:hover{opacity:1;color:var(--accent)}
.footer .contact-block{display:flex;flex-direction:column;gap:1rem}
.footer .contact-block svg{color:var(--accent);flex-shrink:0;margin-top:2px}
.footer-bottom{border-top:1px solid rgba(0,179,179,.2);padding:1.5rem 1rem;text-align:center;display:flex;flex-direction:column;gap:1rem;align-items:center}
.footer-bottom p{font-size:.75rem;opacity:.5}
.footer-bottom a:hover{color:var(--accent);text-decoration:underline}

/* WhatsApp */
.whatsapp{position:fixed;bottom:20px;right:20px;z-index:50;width:56px;height:56px;border-radius:50%;background:#25D366;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px rgba(0,0,0,.2);transition:transform .2s}
.whatsapp:hover{transform:scale(1.1)}
.whatsapp svg{width:28px;height:28px;color:#fff}

/* Reveal animation */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .6s ease, transform .6s ease}
.reveal.in{opacity:1;transform:translateY(0)}

/* 404 */
.notfound{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--muted);text-align:center;padding:2rem}
.notfound h1{font-size:2.5rem;font-weight:700;margin-bottom:1rem}
.notfound p{font-size:1.25rem;color:var(--muted-fg);margin-bottom:1rem}
.notfound a{color:var(--primary);text-decoration:underline}
