:root{
    --shadow-soft:0 30px 80px rgba(33, 24, 9, .12);
    --shadow-card:0 18px 40px rgba(44, 32, 12, .10);
    --radius-xl:32px;
    --radius-lg:24px;
    --radius-md:18px;
    --radius-sm:14px;
    --card-media-ratio:4/3;
    --gallery-media-ratio:4/3;
    --feature-media-ratio:16/9;
    --hero-media-ratio:4/3;
    --rich-media-ratio:16/10;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
    margin:0;
    font-family:var(--font-family);
    color:var(--text);
    line-height:1.7;
    background:
        radial-gradient(circle at top left, rgba(216,154,29,.16), transparent 28%),
        radial-gradient(circle at right 20%, rgba(41,64,30,.12), transparent 24%),
        linear-gradient(180deg, #fffaf0 0%, var(--bg) 42%, #f4ecdd 100%);
    -webkit-font-smoothing:antialiased;
    text-rendering:optimizeLegibility;
}
body::before{
    content:"";
    position:fixed;
    inset:0;
    background-image:
        linear-gradient(90deg, rgba(92,59,18,.018) 1px, transparent 1px),
        linear-gradient(rgba(92,59,18,.018) 1px, transparent 1px);
    background-size:36px 36px;
    pointer-events:none;
    z-index:-1;
}
body.lightbox-open{overflow:hidden}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
button,input,select,textarea{font:inherit}
iframe{width:100%;border:0}
:focus-visible{outline:3px solid rgba(216,154,29,.8);outline-offset:3px}
.skip-link{
    position:absolute;
    left:1rem;
    top:1rem;
    padding:.85rem 1rem;
    border-radius:999px;
    background:var(--primary);
    color:#fff;
    transform:translateY(-170%);
    z-index:120;
}
.skip-link:focus{transform:translateY(0)}
.container{width:min(1180px,calc(100% - 2rem));margin:0 auto}
.site-shell{min-height:100vh}
.whatsapp-float{
    position:fixed;
    right:max(1rem, calc(env(safe-area-inset-right, 0px) + 1rem));
    bottom:max(1rem, calc(env(safe-area-inset-bottom, 0px) + 1rem));
    z-index:85;
    display:inline-flex;
    align-items:center;
    gap:.7rem;
    padding:.85rem 1rem .85rem .85rem;
    border-radius:999px;
    background:linear-gradient(135deg, #25d366, #128c7e);
    color:#fff;
    border:1px solid rgba(255,255,255,.18);
    box-shadow:0 20px 45px rgba(18,140,126,.28);
    transition:transform .2s ease, box-shadow .2s ease;
}
.whatsapp-float:hover,
.whatsapp-float:focus-visible{
    transform:translateY(-2px);
    box-shadow:0 24px 52px rgba(18,140,126,.32);
}
.whatsapp-float--icon-only{
    justify-content:center;
    width:4rem;
    height:4rem;
    padding:0;
}
.whatsapp-float__icon{
    display:grid;
    place-items:center;
    width:2.3rem;
    height:2.3rem;
    border-radius:50%;
    background:rgba(255,255,255,.16);
    font-size:1.5rem;
    flex-shrink:0;
}
.whatsapp-float__text{
    font-size:.95rem;
    font-weight:800;
    letter-spacing:.01em;
    white-space:nowrap;
}

.site-header{
    position:sticky;
    top:0;
    z-index:80;
    backdrop-filter:blur(20px);
    background:color-mix(in srgb, var(--header-menu-bg) 86%, white 14%);
    border-bottom:1px solid rgba(92,59,18,.10);
}
.header-ribbon{
    background:linear-gradient(90deg, color-mix(in srgb, var(--header-topbar-bg) 92%, black 8%), var(--header-topbar-bg));
    color:#f7f1df;
    border-bottom:1px solid rgba(255,255,255,.08);
}
.header-ribbon__inner{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:1rem 2rem;
    padding:.7rem 0;
    flex-wrap:wrap;
}
.header-ribbon__lead{
    display:flex;
    align-items:center;
    gap:.85rem;
    flex-wrap:wrap;
}
.header-ribbon__lead p{
    margin:0;
    color:rgba(247,241,223,.84);
    font-size:.95rem;
}
.header-ribbon__eyebrow{
    display:inline-flex;
    align-items:center;
    padding:.35rem .75rem;
    border-radius:999px;
    background:rgba(255,255,255,.12);
    font-size:.72rem;
    font-weight:800;
    letter-spacing:.08em;
    text-transform:uppercase;
}
.header-ribbon__meta{
    display:flex;
    align-items:center;
    gap:.8rem 1rem;
    flex-wrap:wrap;
}
.header-ribbon__meta a{
    display:inline-flex;
    align-items:center;
    gap:.45rem;
    color:#fff4d9;
    font-size:.95rem;
}
.header-ribbon__icon{
    justify-content:center;
    width:2rem;
    height:2rem;
    border-radius:50%;
    background:rgba(255,255,255,.12);
}

.header-shell{
    display:grid;
    grid-template-columns:minmax(220px,1fr) minmax(0,1.2fr) auto;
    align-items:center;
    gap:1.25rem;
    padding:1rem 0;
}
.site-brand{
    display:flex;
    align-items:center;
    gap:1rem;
    min-width:0;
}
.site-brand__mark{
    display:grid;
    place-items:center;
    width:70px;
    height:70px;
    border-radius:22px;
    background:
        linear-gradient(135deg, rgba(255,255,255,.9), rgba(255,249,238,.65)),
        linear-gradient(135deg, rgba(216,154,29,.18), rgba(41,64,30,.10));
    border:1px solid rgba(92,59,18,.12);
    box-shadow:var(--shadow-card);
    flex-shrink:0;
}
.site-brand__mark img{
    width:52px;
    height:52px;
    object-fit:contain;
}
.site-brand__copy{
    display:grid;
    gap:.2rem;
    min-width:0;
}
.site-brand__copy strong,
.site-brand__copy small{
    overflow:hidden;
    text-overflow:ellipsis;
}
.site-brand__copy strong{
    font-family:var(--font-display);
    font-size:1.35rem;
    font-weight:700;
    color:var(--primary);
}
.site-brand__copy small{
    color:var(--text-muted);
    font-size:.9rem;
}

.site-nav{min-width:0}
.site-menu,.site-submenu{list-style:none;margin:0;padding:0}
.site-menu{
    display:flex;
    align-items:center;
    justify-content:center;
    gap:.35rem;
    flex-wrap:wrap;
}
.site-menu > li{position:relative}
.menu-link-row{display:flex;align-items:center;gap:.25rem;position:relative}
.site-menu > li > .menu-link-row > a{
    display:inline-flex;
    align-items:center;
    gap:.4rem;
    padding:.8rem .95rem;
    border-radius:999px;
    font-weight:700;
    color:var(--text);
    transition:background .2s ease,color .2s ease,transform .2s ease;
}
.site-menu > li.is-current > .menu-link-row > a,
.site-menu > li > .menu-link-row > a:hover,
.site-menu > li > .menu-link-row > a:focus-visible{
    background:rgba(92,59,18,.08);
    color:var(--primary);
}
.menu-caret{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:1rem;
    height:1rem;
    color:var(--primary);
    pointer-events:none;
}
.menu-caret::before{
    content:"";
    width:.48rem;
    height:.48rem;
    border-right:2px solid currentColor;
    border-bottom:2px solid currentColor;
    transform:rotate(45deg) translateY(-1px);
}
.submenu-toggle{
    display:none;
    align-items:center;
    justify-content:center;
    width:2.5rem;
    height:2.5rem;
    border:0;
    border-radius:999px;
    background:transparent;
    color:var(--primary);
    cursor:pointer;
}
.submenu-toggle span{
    width:.7rem;
    height:.7rem;
    border-right:2px solid currentColor;
    border-bottom:2px solid currentColor;
    transform:rotate(45deg) translateY(-1px);
}
.site-submenu{
    position:absolute;
    left:0;
    top:calc(100% + .3rem);
    min-width:250px;
    padding:.4rem;
    border-radius:18px;
    background:rgba(255,251,243,.98);
    border:1px solid rgba(92,59,18,.12);
    box-shadow:var(--shadow-card);
    opacity:0;
    transform:translateY(8px);
    pointer-events:none;
    transition:opacity .22s ease,transform .22s ease;
    z-index:20;
}
.has-children:hover > .menu-link-row > .site-submenu,
.has-children:focus-within > .menu-link-row > .site-submenu,
.has-children.is-open > .menu-link-row > .site-submenu{
    opacity:1;
    transform:translateY(0);
    pointer-events:auto;
}
.site-submenu li a{
    display:block;
    padding:.78rem .95rem;
    border-radius:12px;
    color:var(--text-muted);
}
.site-submenu li a:hover,
.site-submenu li a:focus-visible{
    background:rgba(92,59,18,.08);
    color:var(--primary);
}

.header-actions{display:flex;align-items:center;gap:.8rem}
.call-badge{
    display:flex;
    align-items:center;
    gap:.8rem;
    padding:.55rem .85rem;
    border-radius:18px;
    background:rgba(255,255,255,.82);
    border:1px solid rgba(92,59,18,.12);
    box-shadow:var(--shadow-card);
}
.call-badge__icon{
    display:grid;
    place-items:center;
    width:2.7rem;
    height:2.7rem;
    border-radius:16px;
    background:linear-gradient(135deg, var(--accent), #f3c760);
    color:#2a1b07;
}
.call-badge__copy{display:grid;gap:.1rem}
.call-badge__copy strong{font-size:.95rem;color:var(--primary)}
.call-badge__copy small{
    color:var(--text-muted);
    font-size:.72rem;
    letter-spacing:.06em;
    text-transform:uppercase;
}

.btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:.55rem;
    padding:.9rem 1.35rem;
    border-radius:999px;
    border:1px solid transparent;
    font-weight:800;
    transition:transform .22s ease,box-shadow .22s ease,background .22s ease,color .22s ease,border-color .22s ease;
    cursor:pointer;
}
.btn:hover{transform:translateY(-1px)}
.btn-accent{
    background:linear-gradient(135deg, var(--accent), #f1ba45);
    color:#2a1c09;
    box-shadow:0 18px 38px rgba(216,154,29,.28);
}
.btn-accent:hover{background:linear-gradient(135deg, var(--accent-dark), var(--accent))}
.btn-secondary{
    background:transparent;
    border-color:rgba(255,255,255,.4);
    color:#fff;
}
.btn-secondary:hover{background:rgba(255,255,255,.12)}
.btn-surface{
    background:#fff;
    border-color:rgba(92,59,18,.14);
    color:var(--primary);
}
.btn-dark{
    border-color:rgba(32,24,15,.18);
    color:var(--primary);
    background:rgba(255,248,237,.76);
}
.menu-toggle{
    display:none;
    align-items:center;
    justify-content:center;
    width:3.25rem;
    height:3.25rem;
    padding:0;
    border-radius:999px;
    border:1px solid rgba(92,59,18,.14);
    background:#fff;
    color:var(--primary);
    font-weight:800;
}
.menu-toggle__icon{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    line-height:1;
}
.menu-toggle__icon i{font-size:1.35rem}
.menu-toggle__icon--close{display:none}
.menu-toggle[aria-expanded="true"] .menu-toggle__icon--open{display:none}
.menu-toggle[aria-expanded="true"] .menu-toggle__icon--close{display:inline-flex}

.flash{padding:1rem 0}
.flash .container{
    padding:1rem 1.15rem;
    border-radius:18px;
    box-shadow:var(--shadow-card);
}
.flash-success .container{background:#edf7e7;color:#274917}
.flash-error .container{background:#fff0ed;color:#8c2c18}

.home-section,.page-content,.page-hero{
    padding:
        var(--section-pad-top, var(--section-space))
        0
        var(--section-pad-bottom, var(--section-space));
}
.home-section:first-of-type{padding-top:max(2rem,var(--section-pad-top, var(--section-space)))}
.eyebrow{
    display:inline-flex;
    align-items:center;
    gap:.45rem;
    padding:.42rem .85rem;
    border-radius:999px;
    background:rgba(41,64,30,.08);
    color:#29401e;
    font-size:.75rem;
    font-weight:800;
    letter-spacing:.08em;
    text-transform:uppercase;
}
.section-heading{max-width:760px;margin:0 0 calc(var(--content-gap) * .72)}
.section-heading h2,
.split-copy h2,
.page-hero h1,
.hero-copy h1,
.footer-callout h2{
    margin:.7rem 0 .9rem;
    font-family:var(--font-display);
    line-height:1.04;
    text-wrap:balance;
}
.section-heading h2,.split-copy h2{font-size:clamp(2.3rem,4vw,3.6rem)}
.section-copy,.split-copy p,.rich-article p,.card p,.focus-card p,.person-card p,.social-card p,.testimonial-card p{color:var(--text-muted)}
.section-actions{display:flex;justify-content:flex-start;margin-top:calc(var(--content-gap) * .72)}

.page-hero{
    position:relative;
    overflow:hidden;
    color:#fff7eb;
}
.page-hero::before{
    content:"";
    position:absolute;
    inset:0;
    background:
        linear-gradient(120deg, rgba(24,17,7,.84), rgba(45,64,26,.62) 50%, rgba(216,154,29,.40)),
        radial-gradient(circle at right, rgba(255,255,255,.12), transparent 26%);
}
.page-hero::after{
    content:"";
    position:absolute;
    inset:1.25rem;
    border-radius:28px;
    border:1px solid rgba(255,255,255,.12);
    pointer-events:none;
}
.page-hero-grid{
    position:relative;
    z-index:1;
    display:grid;
    grid-template-columns:minmax(0,1.05fr) minmax(320px,.95fr);
    gap:2rem;
    align-items:center;
}
.page-hero-grid:not(.has-media){grid-template-columns:minmax(0,1fr)}
.page-hero-copy{max-width:680px}
.page-hero h1{font-size:clamp(2.4rem,4.5vw,4.4rem)}
.page-hero-summary{max-width:58ch;color:rgba(255,247,235,.86);font-size:1.04rem}
.page-hero .eyebrow,.hero-overlay .eyebrow,.overlay-panel .eyebrow{
    background:rgba(255,255,255,.12);
    color:#fff8ef;
}
.hero-meta{
    display:flex;
    flex-wrap:wrap;
    gap:.75rem;
    margin-top:1.2rem;
}
.hero-meta span{
    padding:.68rem .95rem;
    border-radius:999px;
    background:rgba(255,255,255,.12);
    border:1px solid rgba(255,255,255,.14);
    font-weight:700;
}

.hero-shell{display:grid}
.hero-slider{
    position:relative;
    overflow:hidden;
    border-radius:var(--radius-xl);
    box-shadow:var(--shadow-soft);
    border:1px solid rgba(92,59,18,.10);
}
.hero-slides{position:relative;min-height:clamp(32rem,78vh,46rem)}
.hero-slide{
    position:absolute;
    inset:0;
    opacity:0;
    pointer-events:none;
    transition:opacity .55s ease,transform .55s ease;
    transform:scale(1.03);
}
.hero-slide.is-active{
    opacity:1;
    pointer-events:auto;
    transform:scale(1);
}
.hero-slide-image{width:100%;height:100%;object-fit:cover}
.hero-overlay{
    position:absolute;
    inset:0;
    display:flex;
    align-items:flex-end;
    padding:clamp(1.5rem,4vw,3rem);
    padding-bottom:clamp(5.5rem,10vh,7rem);
    background:
        linear-gradient(180deg, var(--hero-shadow-top, rgba(18,13,5,.08)) 0%, var(--hero-shadow-mid, rgba(18,13,5,.28)) 45%, var(--hero-shadow-strong, rgba(18,13,5,.58)) 100%),
        linear-gradient(110deg, var(--hero-tint-start, rgba(92,59,18,.18)), var(--hero-tint-end, rgba(216,154,29,.08)));
}
.hero-copy{
    width:min(760px,74%);
    max-width:100%;
    padding:clamp(1.1rem,2vw,1.6rem);
    border-radius:24px;
    background:linear-gradient(135deg, var(--hero-panel-bg, rgba(33,24,9,.18)), var(--hero-panel-bg-soft, rgba(33,24,9,.08)));
    backdrop-filter:blur(10px);
    border:1px solid rgba(255,255,255,.12);
}
.hero-copy h1{font-size:clamp(2.5rem,5vw,5rem);color:#fff7eb;max-width:11ch}
.hero-copy p{max-width:58ch;color:rgba(255,247,235,.88);margin:0}
.hero-actions{display:flex;flex-wrap:wrap;gap:.85rem;margin-top:1.4rem}
.hero-overlay--compact .hero-copy{width:min(820px,80%)}
.hero-overlay--compact .hero-copy h1{font-size:clamp(2.1rem,4.2vw,4rem)}
.hero-overlay--tight .hero-copy{width:min(860px,84%)}
.hero-overlay--tight .hero-copy h1{font-size:clamp(1.85rem,3.8vw,3.2rem)}
.hero-overlay--ultra .hero-copy{width:min(920px,88%);padding:.9rem}
.hero-overlay--ultra .hero-copy h1{font-size:clamp(1.55rem,3.2vw,2.6rem)}
.hero-overlay--ultra .hero-copy p{font-size:.92rem}
.hero-controls{
    position:absolute;
    left:1.2rem;
    right:1.2rem;
    bottom:1.2rem;
    z-index:3;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:1rem;
}
.hero-nav,.hero-dot{
    border:0;
    cursor:pointer;
}
.hero-nav{
    width:3rem;
    height:3rem;
    border-radius:50%;
    background:rgba(255,255,255,.14);
    color:#fff;
    border:1px solid rgba(255,255,255,.2);
    backdrop-filter:blur(10px);
}
.hero-dots{
    display:flex;
    align-items:center;
    justify-content:center;
    gap:.55rem;
    flex:1;
}
.hero-dot{
    width:.78rem;
    height:.78rem;
    border-radius:50%;
    background:rgba(255,255,255,.38);
}
.hero-dot.is-active{background:#fff;transform:scale(1.08)}

.split-layout,
.page-shell,
.page-stack,
.project-detail,
.dynamic-form-grid,
.card-grid,
.impact-grid,
.focus-grid,
.testimonial-grid,
.social-grid,
.people-grid,
.media-gallery{display:grid;gap:var(--content-gap)}
.split-layout{
    grid-template-columns:repeat(2,minmax(0,1fr));
    align-items:center;
}
.split-shell{
    padding:clamp(1rem,2.2vw,1.5rem);
    border:1px solid rgba(92,59,18,.12);
    border-radius:var(--radius-xl);
    background:linear-gradient(135deg, rgba(255,255,255,.72), rgba(245,234,210,.94));
    box-shadow:var(--shadow-soft);
}
.split-shell .split-layout{
    gap:clamp(1.15rem,2.4vw,2rem);
    align-items:stretch;
}
.split-shell--contact{background:linear-gradient(135deg, rgba(255,255,255,.86), rgba(244,230,195,.98))}
.split-layout--split-left .split-copy{order:2}
.split-layout--split-left .split-media{order:1}
.page-shell--with-form,
.page-shell--structure{grid-template-columns:minmax(0,1.05fr) minmax(340px,.95fr);align-items:start}

.split-copy,
.rich-article,
.dynamic-form-card,
.impact-card,
.focus-card,
.testimonial-card,
.social-card,
.person-card,
.card,
.hero-media-frame,
.structure-card,
.project-meta div{
    background:linear-gradient(180deg, rgba(255,255,255,.94), rgba(255,250,241,.94));
    border:1px solid rgba(92,59,18,.10);
    border-radius:var(--radius-lg);
    box-shadow:var(--shadow-card);
}
.split-copy,
.rich-article,
.dynamic-form-card,
.impact-card,
.focus-card,
.testimonial-card,
.social-card{padding:clamp(1.3rem,2.5vw,1.85rem)}
.split-shell .split-copy{height:100%}
.split-shell .split-media{
    display:flex;
    align-items:stretch;
    min-width:0;
}
.split-shell .split-media-frame,
.split-shell .map-frame{width:100%;height:100%}
.split-actions{
    display:flex;
    flex-wrap:wrap;
    gap:.85rem;
    margin-top:1.2rem;
}

.media-frame,
.card-media,
.person-card-media,
.focus-card-media,
.split-media-frame,
.rich-figure{
    display:grid;
    gap:.75rem;
    margin:0;
}
.media-frame,
.card-media,
.person-card-media,
.focus-card-media,
.split-media-frame{overflow:hidden;border-radius:calc(var(--radius-lg) - 2px)}
.media-frame-link,
.card-media,
.person-card-media,
.focus-card-media,
.rich-media-link{
    display:block;
    overflow:hidden;
    border-radius:inherit;
    aspect-ratio:var(--media-frame-ratio, var(--card-media-ratio));
    background:rgba(92,59,18,.06);
}
.media-frame-image,
.split-media-image,
.card-media img,
.person-card-media img,
.focus-card-media img,
.hero-media-image,
.feature-banner-image,
.gallery-media-image,
.structure-image,
.rich-content-image{
    width:100%;
    height:100%;
    object-fit:var(--media-frame-fit, cover);
    object-position:var(--media-frame-position, center);
    transition:transform .45s ease;
}
.media-frame-link:hover .media-frame-image,
.card-media:hover img,
.person-card-media:hover img,
.focus-card-media:hover img,
.gallery-media-link:hover .gallery-media-image,
.rich-media-link:hover .rich-content-image{transform:scale(1.04)}

.media-file-card{
    display:grid;
    place-items:center;
    align-content:center;
    gap:.75rem;
    padding:1.25rem;
    text-align:center;
    color:var(--primary);
}
.media-file-card__icon{font-size:2rem}
.media-file-card__label{font-weight:800}

.hero-media-frame{
    padding:0;
    overflow:hidden;
    --media-frame-ratio:var(--hero-media-ratio);
}
.hero-media-frame .media-frame-link{min-height:320px}
.hero-media-image{min-height:320px}
.hero-video-shell{
    position:relative;
    overflow:hidden;
    border-radius:var(--radius-xl);
    box-shadow:var(--shadow-soft);
    border:1px solid rgba(92,59,18,.10);
}
.hero-video-media,
.hero-video-fallback{
    display:block;
    width:100%;
    height:clamp(32rem,78vh,46rem);
    object-fit:cover;
}
.split-media{height:100%}
.split-media-frame{
    --media-frame-ratio:var(--card-media-ratio);
    min-height:320px;
    padding:0;
}
.split-media-frame .media-frame-link{
    min-height:320px;
}
.map-frame{height:100%;min-height:380px}
.split-media-image{min-height:320px}
.map-frame iframe{height:100%;min-height:380px}
.dynamic-form-card{scroll-margin-top:8rem}

.overlay-panel{
    position:relative;
    overflow:hidden;
    border-radius:var(--radius-xl);
    padding:clamp(2.2rem,6vw,4.8rem) clamp(1.4rem,4vw,3.2rem);
    min-height:360px;
    background-size:cover;
    background-position:center;
    display:grid;
    place-items:center;
    text-align:center;
    box-shadow:var(--shadow-soft);
    color:#fff8ec;
}
.overlay-panel::before{
    content:"";
    position:absolute;
    inset:0;
    background:
        linear-gradient(130deg, rgba(27,20,7,.88), rgba(41,64,30,.52)),
        linear-gradient(180deg, rgba(216,154,29,.18), rgba(216,154,29,0));
}
.overlay-panel::after{
    content:"";
    position:absolute;
    inset:1rem;
    border-radius:calc(var(--radius-xl) - 1rem);
    border:1px solid rgba(255,255,255,.14);
}
.overlay-panel__content{position:relative;z-index:1;max-width:780px}
.overlay-panel--align-left{justify-items:start;text-align:left}
.overlay-panel--align-right{justify-items:end;text-align:right}
.overlay-panel blockquote{
    margin:0 0 1rem;
    font-family:var(--font-display);
    font-size:clamp(1.9rem,4vw,3.5rem);
    line-height:1.18;
}

.products-showcase{
    display:grid;
    gap:clamp(1.1rem,2.4vw,1.7rem);
    padding:clamp(1.05rem,2.3vw,1.5rem);
    border:1px solid rgba(92,59,18,.12);
    border-radius:var(--radius-xl);
    background:linear-gradient(135deg, rgba(255,255,255,.84), rgba(246,236,215,.98));
    box-shadow:var(--shadow-soft);
}
.products-showcase .section-heading{
    max-width:none;
    margin:0;
}
.products-showcase .section-copy{
    max-width:42rem;
}
.products-showcase__actions{margin-top:0}
.products-grid{
    grid-template-columns:repeat(auto-fit,minmax(min(100%,18rem),1fr));
    align-items:stretch;
}
.products-showcase--featured{
    grid-template-columns:minmax(0,.9fr) minmax(320px,1.05fr);
    align-items:start;
}
.products-showcase--featured .section-heading{
    grid-column:1;
}
.products-showcase--featured .products-grid{
    grid-column:2;
    grid-row:1 / span 2;
    grid-template-columns:minmax(0,1fr);
}
.products-showcase--featured .products-showcase__actions{
    grid-column:1;
    align-self:start;
}
.products-showcase--featured .product-card{
    width:100%;
    max-width:34rem;
    justify-self:end;
}

.card-grid{
    grid-template-columns:repeat(3,minmax(0,1fr));
    grid-auto-rows:auto;
    align-items:start;
}
.focus-grid{grid-auto-rows:1fr}
.card{
    display:flex;
    flex-direction:column;
    padding:0;
    overflow:hidden;
}
.card-body{
    display:flex;
    flex-direction:column;
    gap:.68rem;
    padding:1.1rem 1.2rem 1.2rem;
}
.card h3,.focus-card h3,.person-card h3,.social-card h3,.impact-card h3{
    margin:0;
    font-size:1.25rem;
    line-height:1.28;
    text-wrap:balance;
}
.card h3 a,
.focus-card h3 a{
    display:-webkit-box;
    -webkit-box-orient:vertical;
    -webkit-line-clamp:3;
    overflow:hidden;
}
.card-media,
.person-card-media,
.focus-card-media{
    aspect-ratio:var(--card-media-ratio);
    background:rgba(92,59,18,.06);
}
.card-media img,
.person-card-media img,
.focus-card-media img{height:100%}
.card p,
.focus-card p,
.person-card p,
.social-card p,
.testimonial-card p{margin:0}
.card p,
.focus-card p{
    display:-webkit-box;
    -webkit-box-orient:vertical;
    -webkit-line-clamp:2;
    overflow:hidden;
}
.card .text-link,
.focus-card .text-link{
    margin-top:.05rem;
}
.text-link{color:var(--primary);font-weight:800}
.product-card{
    min-height:100%;
    background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(255,249,238,.96));
}
.product-card .card-body{
    gap:.82rem;
    padding:1.2rem 1.25rem 1.25rem;
}
.product-card .eyebrow{
    width:max-content;
    padding:.45rem .95rem;
    background:rgba(41,64,30,.08);
    color:#29401e;
}
.product-card p{
    -webkit-line-clamp:3;
}
.product-card .text-link{
    margin-top:auto;
    padding-top:.1rem;
}

.testimonial-marquee{
    --testimonial-marquee-gap:1.25rem;
    --testimonial-marquee-gap-half:.625rem;
    position:relative;
    overflow:hidden;
    padding:.15rem 0;
    mask-image:linear-gradient(90deg, transparent 0, #000 6%, #000 94%, transparent 100%);
}
.testimonial-marquee__rail{
    display:flex;
    align-items:stretch;
    gap:var(--testimonial-marquee-gap);
    width:max-content;
    will-change:transform;
    animation:testimonial-marquee-scroll 34s linear infinite;
}
.testimonial-marquee__group{
    display:flex;
    align-items:stretch;
    gap:var(--testimonial-marquee-gap);
}
.testimonial-marquee:hover .testimonial-marquee__rail{animation-play-state:paused}
.testimonial-marquee .testimonial-card{
    flex:0 0 clamp(18rem, 30vw, 23rem);
    min-height:100%;
}
.testimonial-marquee .testimonial-card__quote{
    display:-webkit-box;
    -webkit-box-orient:vertical;
    -webkit-line-clamp:5;
    overflow:hidden;
}
.testimonial-marquee--static{mask-image:none}
.testimonial-marquee--static .testimonial-marquee__rail{width:100%;animation:none}
.testimonial-marquee--static .testimonial-marquee__group{width:100%}
.testimonial-marquee--static .testimonial-card{flex:1 1 auto}

@keyframes testimonial-marquee-scroll{
    from{transform:translateX(0)}
    to{transform:translateX(calc(-50% - var(--testimonial-marquee-gap-half)))}
}

.impact-grid,.focus-grid,.testimonial-grid,.social-grid,.people-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
.impact-card{
    display:flex;
    flex-direction:column;
    align-items:center;
    text-align:center;
}
.impact-card strong{
    display:block;
    font-family:var(--font-display);
    font-size:2.7rem;
    color:var(--primary);
    margin:.15rem 0 .45rem;
}
.impact-icon,.focus-icon{
    display:inline-grid;
    place-items:center;
    width:3.4rem;
    height:3.4rem;
    border-radius:18px;
    background:rgba(216,154,29,.16);
    color:var(--primary);
    margin:0 auto 1rem;
}
.section-icon-shell i{font-size:1.35rem}
.focus-card{display:flex;flex-direction:column;gap:1rem}
.focus-card-body{display:flex;flex-direction:column;gap:.85rem}
.person-card{display:flex;flex-direction:column;gap:1rem;padding:1rem}
.testimonial-card{display:flex;flex-direction:column;gap:1rem}
.testimonial-card__header{display:flex;align-items:center;gap:.95rem}
.testimonial-card__person{
    display:grid;
    place-items:center;
    flex:0 0 auto;
    width:4.5rem;
    aspect-ratio:1/1;
    border-radius:50%;
    overflow:hidden;
    background:rgba(216,154,29,.14);
    border:1px solid rgba(92,59,18,.12);
    box-shadow:0 12px 24px rgba(44,32,12,.10);
}
.testimonial-card__person img{
    width:100%;
    height:100%;
    object-fit:cover;
    object-position:center top;
}
.testimonial-card__person--placeholder{
    color:var(--primary);
    font-weight:800;
    font-size:1rem;
    letter-spacing:.08em;
}
.testimonial-card__meta{display:flex;flex-direction:column;gap:.2rem;min-width:0}
.testimonial-card__name{line-height:1.2}
.testimonial-card__detail{color:var(--text-muted);font-size:.95rem}
.testimonial-card__quote{
    line-height:1.8;
    font-style:italic;
    color:color-mix(in srgb, var(--text) 92%, rgba(92,59,18,.9) 8%);
}
.testimonial-card__actions{
    display:flex;
    flex-wrap:wrap;
    gap:.65rem 1rem;
    margin-top:.2rem;
}
.testimonial-card .text-link{margin-top:0}
.quote-mark{color:var(--primary);font-weight:800}
.structure-card{
    padding:1rem;
    --media-frame-ratio:var(--card-media-ratio);
    --media-frame-fit:contain;
    --media-frame-position:center;
}
.structure-card .media-frame-link{background:#fffdf8}
.role{color:#29401e;font-weight:800;margin:.2rem 0 .45rem}

.project-detail{display:grid;gap:1.5rem}
.project-meta{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:1rem;
}
.project-meta div{padding:1rem 1.1rem}
.project-meta strong{display:block;margin-bottom:.35rem;color:var(--primary)}
.year-filter-row{
    display:flex;
    flex-wrap:wrap;
    gap:.7rem;
    margin-bottom:1.25rem;
}
.pill-link{
    display:inline-flex;
    align-items:center;
    padding:.65rem .95rem;
    border-radius:999px;
    background:#fff;
    border:1px solid rgba(92,59,18,.12);
    box-shadow:var(--shadow-card);
    font-weight:700;
    color:var(--primary);
}

.sdg-section{display:grid;gap:1rem}
.sdg-heading strong{display:block;font-size:1.05rem;margin-bottom:.25rem;color:var(--primary)}
.sdg-heading p{margin:0;color:var(--text-muted)}
.sdg-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:.85rem}
.sdg-chip{
    display:grid;
    place-items:center;
    aspect-ratio:var(--card-media-ratio);
    border-radius:18px;
    overflow:hidden;
    box-shadow:var(--shadow-card);
    background:#fff8ef;
}
.sdg-chip img{
    width:100%;
    height:100%;
    object-fit:contain;
    padding:.45rem;
}

.feature-banner{
    margin-bottom:1.3rem;
    --media-frame-ratio:var(--feature-media-ratio);
}
.feature-banner .media-frame-link{min-height:320px}
.feature-banner-image{min-height:320px}
.media-gallery{grid-template-columns:repeat(3,minmax(0,1fr))}
.gallery-media{--media-frame-ratio:var(--gallery-media-ratio)}
.gallery-media figcaption{padding:.75rem .95rem;color:var(--text-muted);font-size:.92rem}

.rich-article :where(p,ul,ol,blockquote,table,figure,.embed-frame,.rich-video-frame,section,article){margin:0 0 1.15rem}
.rich-article :where(h2,h3,h4){
    margin:1.6rem 0 .8rem;
    font-family:var(--font-display);
    line-height:1.16;
}
.rich-article :where(ul,ol){padding-left:1.25rem}
.rich-article blockquote{
    padding:1.3rem 1.45rem;
    border-left:4px solid var(--accent);
    background:rgba(216,154,29,.10);
    border-radius:var(--radius-md);
    color:var(--text);
    font-weight:700;
}
.rich-figure{--media-frame-ratio:var(--rich-media-ratio)}
.rich-media-link{
    background:rgba(92,59,18,.06);
    border-radius:var(--radius-md);
    box-shadow:var(--shadow-card);
}
.rich-content-image{border-radius:0;box-shadow:none}
.rich-video-frame,
.embed-frame{
    overflow:hidden;
    border-radius:var(--radius-lg);
    background:#130d05;
    box-shadow:var(--shadow-card);
    aspect-ratio:16/9;
}
.rich-content-video,
.embed-frame iframe{
    width:100%;
    height:100%;
}
.table-scroll{overflow:auto}
.rich-table{min-width:640px}

.dynamic-form-card h2{font-family:var(--font-display)}
.dynamic-form-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
.field{
    display:grid;
    gap:.55rem;
}
.field-full{grid-column:1 / -1}
.field-half{grid-column:span 1}
.field span{font-weight:700;color:var(--primary)}
.field small{color:var(--text-muted);font-size:.88rem}
.field input,
.field select,
.field textarea{
    width:100%;
    padding:.9rem 1rem;
    border-radius:14px;
    border:1px solid rgba(92,59,18,.16);
    background:#fffdf8;
    color:var(--text);
}
.field textarea{min-height:150px;resize:vertical}
.dynamic-form-grid .btn{margin-top:.5rem}

.site-footer{
    margin-top:var(--section-space);
    color:var(--footer-text);
    background:
        radial-gradient(circle at top right, rgba(216,154,29,.14), transparent 24%),
        linear-gradient(180deg, #2b1f0f 0%, #20160b 100%);
}
.footer-callout{
    padding:2rem 0 0;
}
.footer-callout__inner{
    display:grid;
    grid-template-columns:minmax(0,1.15fr) auto;
    gap:1.5rem;
    align-items:center;
    padding:1.8rem;
    border-radius:28px;
    background:
        linear-gradient(135deg, rgba(255,248,235,.95), rgba(255,243,215,.88)),
        linear-gradient(135deg, rgba(216,154,29,.20), rgba(41,64,30,.10));
    color:var(--text);
    border:1px solid rgba(216,154,29,.26);
    box-shadow:var(--shadow-soft);
    transform:translateY(-2.2rem);
}
.footer-callout__actions{
    display:flex;
    flex-wrap:wrap;
    gap:.8rem;
    justify-content:flex-end;
}

.partner-band{padding:0 0 2rem}
.partner-band__track{
    display:flex;
    align-items:center;
    flex-wrap:wrap;
    gap:1rem;
}
.partner-chip{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-width:130px;
    min-height:84px;
    padding:1rem 1.2rem;
    border-radius:20px;
    background:rgba(255,255,255,.06);
    border:1px solid rgba(255,255,255,.08);
}
.partner-chip img{max-height:42px;object-fit:contain;filter:grayscale(1) brightness(1.15)}

.footer-main{padding:0 0 2rem}
.footer-row{display:grid;gap:1.1rem;margin-bottom:2rem}
.footer-row__heading h3{
    margin:.55rem 0 0;
    font-family:var(--font-display);
    font-size:1.7rem;
}
.footer-grid{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:1rem;
}
.footer-card{
    padding:1.35rem 1.4rem;
    border-radius:22px;
    background:rgba(255,255,255,.05);
    border:1px solid rgba(255,255,255,.08);
    backdrop-filter:blur(10px);
}
.footer-card h4{
    margin:0 0 .85rem;
    font-size:1rem;
    letter-spacing:.06em;
    text-transform:uppercase;
    color:#f5dca1;
}
.footer-card__content{
    display:grid;
    gap:.7rem;
}
.footer-link{
    color:#fff4d7;
    font-weight:700;
}
.footer-copy,
.footer-copy p,
.footer-copy a{
    color:rgba(248,240,223,.84);
    margin:0;
}

.footer-base{
    border-top:1px solid rgba(255,255,255,.08);
    padding:1rem 0 1.5rem;
}
.footer-base__inner{
    display:flex;
    align-items:center;
    justify-content:center;
    gap:1rem;
    flex-wrap:wrap;
    text-align:center;
    color:rgba(248,240,223,.72);
}

.lightbox-modal{
    position:fixed;
    inset:0;
    z-index:120;
    display:grid;
    place-items:center;
    padding:2rem;
    background:rgba(14,10,4,.84);
}
.lightbox-modal[hidden]{display:none}
.lightbox-modal__content{
    position:relative;
    width:min(960px,100%);
    max-height:100%;
    display:grid;
    gap:1rem;
    justify-items:center;
}
.lightbox-modal__image{
    max-width:100%;
    max-height:min(74vh,760px);
    border-radius:24px;
    box-shadow:var(--shadow-soft);
}
.lightbox-modal__caption{
    margin:0;
    color:#fff8ec;
    text-align:center;
}
.lightbox-modal__close,
.lightbox-modal__nav{
    position:absolute;
    border:0;
    cursor:pointer;
    border-radius:999px;
    width:3rem;
    height:3rem;
    display:grid;
    place-items:center;
    background:rgba(255,255,255,.12);
    color:#fff;
    backdrop-filter:blur(10px);
}
.lightbox-modal__close{top:1rem;right:1rem}
.lightbox-modal__nav--prev{left:1rem;top:50%;transform:translateY(-50%)}
.lightbox-modal__nav--next{right:1rem;top:50%;transform:translateY(-50%)}

@media (max-width: 1100px){
    .header-shell{grid-template-columns:minmax(0,1fr) auto}
    .site-nav{
        position:absolute;
        top:100%;
        left:1rem;
        right:1rem;
        opacity:0;
        transform:translateY(-8px);
        pointer-events:none;
        transition:opacity .2s ease,transform .2s ease;
    }
    .site-nav.is-open{
        opacity:1;
        transform:translateY(0);
        pointer-events:auto;
    }
    .site-menu{
        flex-direction:column;
        align-items:stretch;
        gap:.2rem;
        padding:.8rem;
        border-radius:24px;
        background:rgba(255,251,243,.98);
        border:1px solid rgba(92,59,18,.12);
        box-shadow:var(--shadow-soft);
    }
    .site-menu > li > .menu-link-row > a{width:100%;justify-content:space-between}
    .submenu-toggle{display:inline-flex}
    .menu-caret{display:none}
    .site-submenu{
        position:static;
        min-width:0;
        margin-top:.35rem;
        opacity:1;
        transform:none;
        pointer-events:auto;
        display:none;
        box-shadow:none;
    }
    .has-children.is-open > .menu-link-row > .site-submenu{display:block}
    .menu-toggle{display:inline-flex}
    .page-hero-grid,
    .split-layout,
    .page-shell--with-form,
    .page-shell--structure,
    .products-showcase--featured,
    .footer-callout__inner{grid-template-columns:1fr}
    .card-grid,
    .impact-grid,
    .focus-grid,
    .testimonial-grid,
    .social-grid,
    .people-grid,
    .media-gallery,
    .footer-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
    .hero-copy{width:min(820px,88%)}
}

@media (max-width: 760px){
    .container{width:min(100% - 1.25rem, 100%)}
    .whatsapp-float{
        right:max(.85rem, calc(env(safe-area-inset-right, 0px) + .85rem));
        bottom:max(.85rem, calc(env(safe-area-inset-bottom, 0px) + .85rem));
        justify-content:center;
        width:4rem;
        height:4rem;
        padding:0;
    }
    .whatsapp-float__text{display:none}
    .site-header{
        overflow:clip;
        transition:box-shadow .22s ease;
    }
    .header-ribbon{
        max-height:16rem;
        overflow:hidden;
        opacity:1;
        transform:translateY(0);
        transition:max-height .24s ease, opacity .2s ease, transform .24s ease, border-color .24s ease;
    }
    .site-header.is-ribbon-collapsed .header-ribbon{
        max-height:0;
        opacity:0;
        transform:translateY(-100%);
        border-bottom-color:transparent;
        pointer-events:none;
    }
    .header-ribbon__inner,
    .header-ribbon__lead,
    .header-ribbon__meta{justify-content:center;text-align:center}
    .header-shell{padding:.85rem 0}
    .site-brand__mark{width:60px;height:60px}
    .site-brand__copy strong{font-size:1.15rem}
    .site-brand__copy small{font-size:.82rem}
    .header-actions{width:100%;justify-content:space-between}
    .call-badge{flex:1;min-width:0}
    .hero-slides{min-height:520px}
    .hero-overlay{
        align-items:flex-end;
        padding:1.15rem;
        padding-bottom:5.2rem;
    }
    .hero-copy{
        width:100%;
        padding:1rem;
        border-radius:18px;
    }
    .hero-copy h1{font-size:clamp(2rem,11vw,3rem)}
    .hero-actions{flex-direction:column;align-items:stretch}
    .hero-actions .btn{width:100%}
    .card-grid,
    .impact-grid,
    .focus-grid,
    .testimonial-grid,
    .social-grid,
    .people-grid,
    .media-gallery,
    .footer-grid,
    .dynamic-form-grid,
    .project-meta{grid-template-columns:1fr}
    .home-section,.page-content,.page-hero{
        padding:
            var(--section-pad-top-mobile, var(--section-space-mobile))
            0
            var(--section-pad-bottom-mobile, var(--section-space-mobile));
    }
    .home-section:first-of-type{padding-top:max(1.5rem,var(--section-pad-top-mobile, var(--section-space-mobile)))}
    .split-shell{padding:1rem}
    .products-showcase{padding:1rem}
    .products-showcase--featured .products-grid{
        grid-column:auto;
        grid-row:auto;
    }
    .products-showcase--featured .products-showcase__actions{
        grid-column:auto;
    }
    .split-actions{
        flex-direction:column;
        align-items:stretch;
    }
    .split-actions .btn{width:100%}
    .footer-callout__inner{transform:translateY(-1.8rem);padding:1.35rem}
    .footer-callout__actions{justify-content:flex-start}
    .testimonial-marquee{mask-image:none}
    .testimonial-marquee .testimonial-card{flex-basis:min(82vw, 19rem)}
    .lightbox-modal{padding:1rem}
    .lightbox-modal__nav--prev{left:.4rem}
    .lightbox-modal__nav--next{right:.4rem}
}

@media (prefers-reduced-motion: reduce){
    .testimonial-marquee{mask-image:none}
    .testimonial-marquee__rail{animation:none;transform:none}
}
