:root{
  --bg:#f2ece1;
  --panel:#e8dfcc;
  --card:#f8f4ea;
  --olive:#837B51;
  --olive-soft:#9a9468;
  --olive-deep:#5e5940;
  --text:#232119;
  --muted:#6b6555;
  --line:#d8cfbc;
  --shadow:0 10px 35px rgba(51,41,18,.08);
  --radius:28px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,system-ui,sans-serif;background:var(--bg);color:var(--text)}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
button,input,textarea,select{font:inherit}
.container{width:min(1180px,calc(100% - 40px));margin-inline:auto}
.section{padding:38px 0 64px}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.eyebrow,.about-kicker{display:inline-block;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--olive-deep);margin-bottom:14px}
.desktop-intro{max-width:820px;margin:0 auto 26px;text-align:center;color:var(--muted);line-height:1.8}

.site-header{display:none !important}
.crop-media{position:relative;width:100%;height:100%;overflow:hidden;background:#ebe5d8}
.crop-media img{position:absolute;left:50%;top:50%;width:100%;height:100%;object-fit:cover;transform:translate(calc(-50% + var(--crop-x, 0%)), calc(-50% + var(--crop-y, 0%))) scale(var(--crop-scale, 1));transform-origin:center center}
.board-thumb img,.catalogue-wide img,.catalogue-narrow img,.about-thumb img,.service-thumb img{will-change:transform}

.header-inner{display:flex;align-items:center;justify-content:space-between;padding:12px 0;gap:18px}
.brand{display:flex;align-items:center;gap:12px;font-weight:700;letter-spacing:.18em}
.brand img{width:auto;height:56px;max-width:none;border-radius:0;object-fit:contain}
.main-nav{display:flex;gap:24px;align-items:center}
.nav-link{font-size:14px;color:var(--muted);padding:8px 0;position:relative}
.nav-link.active,.nav-link:hover{color:var(--olive-deep)}
.nav-link.active::after{content:"";position:absolute;left:0;right:0;bottom:-12px;height:2px;background:var(--olive)}
.header-actions{display:flex;align-items:center;gap:12px}
.lang-switch{display:flex;border:1px solid var(--line);border-radius:999px;overflow:hidden;background:#fff}
.lang-switch a{padding:8px 12px;font-size:13px}
.lang-switch a.active{background:var(--olive);color:#fff}
.menu-toggle{display:none;width:42px;height:42px;border:1px solid var(--line);border-radius:999px;background:#fff;padding:0;position:relative}
.menu-toggle span{position:absolute;left:12px;right:12px;height:2px;background:var(--olive-deep);border-radius:2px;transition:.25s}
.menu-toggle span:nth-child(1){top:13px}.menu-toggle span:nth-child(2){top:20px}.menu-toggle span:nth-child(3){top:27px}
.menu-toggle.open span:nth-child(1){transform:rotate(45deg);top:20px}
.menu-toggle.open span:nth-child(2){opacity:0}.menu-toggle.open span:nth-child(3){transform:rotate(-45deg);top:20px}
.mobile-nav{display:none;border-top:1px solid var(--line);background:#f7f2e7}
.mobile-nav.open{display:block}
.mobile-nav-inner{display:grid;gap:10px;padding:14px 20px 18px}
.mobile-nav-link{padding:14px 16px;border-radius:18px;background:rgba(142,135,96,.12);color:var(--olive-deep);font-weight:500}

.page-heading{text-align:center;margin:0 auto 28px}
.page-heading h1{font-family:"Cormorant Garamond",serif;font-size:56px;line-height:1.02;font-weight:500;margin:0}
.page-heading p{margin:8px 0 0;color:var(--muted)}

.section-home{padding-top:24px}
.hero-phone{position:relative;width:min(100%,380px);height:min(86svh,860px);margin:0 auto;border-radius:0;overflow:hidden;background:#d8d1b8;box-shadow:var(--shadow)}
.hero-top{position:absolute;inset:0 0 56% 0;background:var(--olive)}
.hero-logo{position:absolute;top:36px;left:50%;transform:translateX(-50%);width:116px}
.hero-bg{position:absolute;inset:37% 0 0 0;width:100%;height:63%;object-fit:cover}
.hero-overlay{position:absolute;inset:37% 0 0 0;background:linear-gradient(to bottom,rgba(0,0,0,.04),rgba(0,0,0,.18))}
.home-title{position:absolute;top:43.2%;left:50%;transform:translateX(-50%);color:#fff;font-family:"Cormorant Garamond",serif;font-size:30px;letter-spacing:.04em}
.home-buttons{position:absolute;top:48.3%;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;gap:12px;width:156px}
.home-buttons a{padding:13px 12px;text-align:center;background:rgba(92,88,69,.56);color:#fff;border:1px solid rgba(255,255,255,.08);backdrop-filter:blur(1px);font-size:13px}
.desktop-home{display:grid;grid-template-columns:1fr 1fr;gap:28px;margin-top:42px;padding:32px}
.desktop-home-copy h1{margin:0 0 14px;font-family:"Cormorant Garamond",serif;font-size:56px;font-weight:500}
.desktop-home-copy p{line-height:1.85;color:var(--muted);margin:0}
.desktop-home-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.desktop-home-box{display:grid;place-items:center;min-height:170px;border-radius:24px;background:linear-gradient(160deg,var(--olive),var(--olive-soft));color:#fff;font-family:"Cormorant Garamond",serif;font-size:32px;padding:16px;text-align:center}

.service-hero{position:relative;width:min(100%,380px);height:min(84svh,820px);margin:0 auto 36px;overflow:hidden;background:#ddd2b6;border-radius:0}
.service-nav-bg{position:absolute;inset:36% 0 0 0}.service-nav-bg img{width:100%;height:100%;object-fit:cover}
.service-nav-top{position:absolute;inset:0 0 55% 0;background:var(--olive)}
.service-nav-logo{position:absolute;top:18px;right:22px;width:68px}
.service-nav-title{position:absolute;top:27.5%;left:50%;transform:translateX(-50%);font-family:"Cormorant Garamond",serif;font-size:31px;color:#fff}
.service-list-float{position:absolute;top:38%;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;gap:11px;width:190px}
.service-trigger{display:flex;align-items:center;justify-content:space-between;padding:11px 15px;border-radius:5px;background:rgba(83,80,61,.57);color:#fff;font-size:13px;border:none}
.service-layout{display:grid;gap:18px;margin-top:30px}
.service-item{overflow:hidden}
.service-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;background:var(--card);cursor:pointer}
.service-head strong{font-family:"Cormorant Garamond",serif;font-size:32px;font-weight:500}
.service-body{display:none;border-top:1px solid var(--line);grid-template-columns:30% 70%}
.service-body.active{display:grid}
.service-photo .crop-media{min-height:300px}
.service-copy{padding:28px 30px;background:#ece5d5}
.service-copy p,.service-copy li{line-height:1.82;color:#25231c}
.service-copy ul{padding-left:18px;margin:14px 0 0}

.about-stack{display:grid;gap:30px}
.about-row{display:grid;grid-template-columns:30% 70%;overflow:hidden}
.about-row.reverse{grid-template-columns:70% 30%}
.about-row .crop-media{min-height:360px}
.about-copy{padding:38px 38px 32px;display:flex;flex-direction:column;justify-content:center}
.about-copy h2{font-family:"Cormorant Garamond",serif;font-size:44px;font-weight:500;margin:0 0 18px}
.about-copy p{white-space:pre-line;line-height:1.95;color:#312e25;margin:0}

.section-projects{padding-top:24px}
.projects-phone{position:relative;width:min(100%,380px);margin:0 auto 40px;padding:0 16px 24px;background:#ece7d3;border-radius:0;overflow:hidden;box-shadow:var(--shadow)}
.projects-phone-top{position:absolute;left:0;right:0;top:0;height:175px;background:var(--olive)}
.projects-phone-logo{position:absolute;top:18px;right:18px;width:68px;z-index:2}
.projects-phone-title{position:relative;z-index:2;text-align:center;color:#fff;font-family:"Cormorant Garamond",serif;font-size:32px;padding-top:88px;margin-bottom:22px}
.projects-board{position:relative;width:100%;max-width:335px;margin:0 auto;padding-bottom:40px;z-index:2}
.project-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;align-items:start}
.project-col{display:flex;flex-direction:column;gap:18px}.project-col-offset{padding-top:10px}
.project-card{position:relative;border-radius:24px;overflow:hidden;box-shadow:var(--shadow);min-height:150px;background:#c9bfa4}
.project-card img{width:100%;height:100%;object-fit:cover;aspect-ratio:1/.82}
.project-card::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.35),rgba(0,0,0,.08))}
.project-card span{position:absolute;inset:auto 14px 14px 14px;text-align:center;color:#fff;font-family:"Cormorant Garamond",serif;font-size:18px;line-height:1.1;text-shadow:0 3px 12px rgba(0,0,0,.35);z-index:1}
.projects-home-link{position:absolute;right:2px;bottom:0;color:#d6ccb3;font-family:"Cormorant Garamond",serif;font-size:24px}

.desktop-project-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:24px;margin-top:28px}
.desktop-project-card{position:relative;overflow:hidden;border-radius:28px;min-height:260px;background:#cdbf9f;box-shadow:var(--shadow)}
.desktop-project-card img{width:100%;height:100%;object-fit:cover;aspect-ratio:1/.82}
.desktop-project-card::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.45),rgba(0,0,0,.08))}
.desktop-project-card span{position:absolute;left:18px;right:18px;bottom:18px;z-index:1;color:#fff;font-family:"Cormorant Garamond",serif;font-size:30px;line-height:1.02;text-shadow:0 3px 12px rgba(0,0,0,.35)}

.project-page-header{display:flex;align-items:center;justify-content:space-between;gap:20px;margin:18px auto 30px}
.project-pill{display:inline-block;background:var(--olive);color:#fff;padding:14px 18px;border-radius:8px;font-size:18px}
.project-summary{display:grid;grid-template-columns:minmax(240px,1fr) 2fr;gap:24px;align-items:start;margin-bottom:22px}
.summary-text{padding:28px}.summary-text p{white-space:pre-line;line-height:1.95;margin:0}
.summary-hero img{width:100%;height:100%;object-fit:cover}
.gallery-note{color:var(--muted);font-size:14px;margin:0 0 20px}
.board-section{margin:18px 0}
.board-frame{position:relative;width:100%;padding-top:56.25%;background:#f3f2ef;border-radius:8px;overflow:hidden}
.board-frame .board-image{position:absolute;overflow:hidden;cursor:pointer}
.board-frame .board-image .crop-media{width:100%;height:100%}

.contact-wrap{display:grid;grid-template-columns:1.1fr .9fr;gap:24px}
.contact-form{padding:30px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.form-grid .full{grid-column:1/-1}
input,textarea,select{width:100%;padding:14px 16px;border-radius:16px;border:1px solid var(--line);background:#fff}
textarea{min-height:160px;resize:vertical}
button,.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:13px 18px;border-radius:999px;border:none;background:var(--olive);color:#fff;font-weight:600;cursor:pointer}
.contact-info{padding:30px;background:var(--olive);color:#fff}
.contact-info h2{font-family:"Cormorant Garamond",serif;font-size:42px;font-weight:500;margin:0 0 18px}
.contact-info .info-block{display:grid;gap:16px;line-height:1.8}
.notice{padding:14px 18px;border-radius:16px;margin-bottom:16px}.notice.success{background:#dcefd9;color:#20461b}.notice.error{background:#f6dddf;color:#6d2932}

.site-footer{padding:32px 0;margin-top:42px;border-top:1px solid var(--line)}
.footer-grid{display:grid;grid-template-columns:1.2fr 1fr auto;gap:24px;align-items:start}
.footer-grid h3{margin:0 0 10px;font-family:"Cormorant Garamond",serif;font-size:34px;font-weight:500}
.footer-grid p{margin:0;color:var(--muted);line-height:1.7}
.footer-admin{display:inline-block;border:1px solid var(--line);padding:12px 16px;border-radius:999px}

.lightbox{position:fixed;inset:0;background:rgba(8,8,8,.9);display:none;align-items:center;justify-content:center;padding:20px;z-index:100}
.lightbox.open{display:flex}.lightbox-inner{max-width:min(96vw,1100px);max-height:90vh;display:grid;gap:12px}.lightbox-inner img{max-width:100%;max-height:80vh;border-radius:10px}.lightbox-close{justify-self:end;background:#fff;color:#111}

.admin-shell{display:grid;grid-template-columns:260px 1fr;min-height:100vh}
.admin-side{background:#1f1c15;color:#fff;padding:24px}.admin-side a{display:block;padding:10px 12px;border-radius:12px;color:#ece5d5}.admin-side a:hover,.admin-side a.active{background:rgba(255,255,255,.08)}
.admin-main{padding:28px;background:#f7f3ea}.admin-block{padding:22px;margin-bottom:18px}.admin-block h2{margin-top:0;font-family:"Cormorant Garamond",serif;font-size:36px;font-weight:500}.admin-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.admin-grid .full{grid-column:1/-1}
.image-preview{width:120px;height:90px;object-fit:cover;border-radius:12px;border:1px solid var(--line)}
.login-wrap{min-height:100vh;display:grid;place-items:center;padding:20px}.login-card{width:min(460px,100%);padding:28px}.login-card h1{font-family:"Cormorant Garamond",serif;font-size:42px;font-weight:500;margin:0 0 12px}.small{font-size:13px;color:var(--muted)}

.rtl .brand,.rtl .header-actions,.rtl .header-inner{flex-direction:row-reverse}
.rtl .service-copy ul{padding-right:18px;padding-left:0}
.rtl .project-page-header{flex-direction:row-reverse}
.rtl .projects-home-link{left:2px;right:auto}
.rtl .contact-info,.rtl .contact-form,.rtl .about-copy,.rtl .service-copy{text-align:right}

@media (max-width: 980px){
  .desktop-home,.services-desktop-top,.desktop-projects-top,.desktop-project-grid{display:none !important}
  .main-nav{display:none}
  .menu-toggle{display:block}
  .footer-grid,.contact-wrap,.project-summary,.about-row,.about-row.reverse,.service-body,.admin-shell,.admin-grid,.form-grid,.desktop-home{grid-template-columns:1fr}
  .desktop-home-copy h1,.page-heading h1{font-size:44px}
  .about-copy h2,.contact-info h2{font-size:36px}
  .service-head strong{font-size:28px}
  .desktop-home-box{min-height:120px;font-size:28px}
  .desktop-project-grid{grid-template-columns:1fr 1fr}
  .desktop-project-card span{font-size:24px}
  .admin-side{display:none}
}
@media (min-width: 981px){
  .mobile-nav{display:none !important}
  .hero-phone,.service-hero,.projects-phone{display:none !important}
}
@media (max-width: 640px){
  .container{width:min(100% - 20px,100%)}
  .section{padding:24px 0 50px}
  .page-heading{margin-bottom:20px}
  .page-heading h1{font-size:36px}
  .hero-phone,.service-hero,.projects-phone{width:100%;max-width:none}
  .hero-phone{height:100svh;min-height:720px}
  .service-hero{height:100svh;min-height:720px}
  .projects-phone{padding-inline:12px}
  .home-title{top:43.6%;font-size:27px}
  .home-buttons{top:48.6%;width:150px;gap:10px}.home-buttons a{padding:12px 8px;font-size:13px}
  .service-list-float{width:100%}
  .service-head{padding:16px 18px}
  .service-copy{padding:22px}
  .about-copy{padding:26px 22px}
  .project-grid{gap:14px}.project-col{gap:14px}.project-card{min-height:136px}.project-card span{font-size:17px}
  .project-pill{font-size:16px;padding:12px 15px}
  .project-page-header{align-items:flex-start;flex-direction:column}
}

.brand-text{display:inline-block}
.desktop-only{display:block}
.mobile-catalogue{display:none}
.mobile-service-panel{display:grid;grid-template-columns:25% 75%;border-radius:0 0 6px 6px;overflow:hidden;width:80vw;max-width:304px;margin:0 auto;background:transparent;max-height:0;opacity:0;transform:translateY(-8px);transition:max-height .35s ease, opacity .28s ease, transform .28s ease;pointer-events:none}
.mobile-service-photo .crop-media{width:100%;height:100%;min-height:158px}
.mobile-service-copy{padding:14px 14px 12px;min-height:158px}
.mobile-service-copy p,.mobile-service-copy li{font-size:10.5px;line-height:1.55;color:#201f19}
.mobile-service-copy ul{padding-left:15px;margin:8px 0 0}
.mobile-service-item .service-trigger span:last-child{transition:transform .25s ease}
.mobile-service-item.is-open .mobile-service-panel{max-height:520px;opacity:1;transform:translateY(0);pointer-events:auto}
.site-footer{display:none}

@media (max-width: 899px){
  .site-header{background:#837B51;border-bottom:none}
  .header-inner{padding:8px 0;min-height:74px}
  .brand{gap:0;height:58px;display:flex;align-items:center}
  .brand-text{display:none}
  .brand img{height:100%;width:auto;max-width:none;object-fit:contain;background:transparent;border:none;padding:0}
  .service-hero{height:auto;min-height:820px;margin-bottom:24px}
  .service-list-float{top:38%;left:50%;transform:translateX(-50%);width:100%;display:flex;flex-direction:column;align-items:center;gap:8px}
  .mobile-service-item{width:100%;display:flex;flex-direction:column;align-items:center;border-radius:6px;overflow:visible;background:transparent}
  .service-trigger{width:50vw;max-width:190px;min-width:160px;justify-content:center;gap:12px;border-radius:5px}
  .mobile-service-panel{width:80vw;max-width:304px}
  .service-layout{display:none}
  .service-item{display:none}
  .about-row{grid-template-columns:20% 80%}
  .about-row.reverse{grid-template-columns:80% 20%}
  .about-row .crop-media{min-height:220px}
  .about-copy{padding:18px 16px}
  .gallery-note{font-size:12px;margin-bottom:12px}
  .board-section,.project-summary{display:none}
  .mobile-catalogue{display:grid;gap:12px}
  .mobile-catalogue-row{display:grid;grid-template-columns:25% 75%;gap:12px;height:168px}
  .mobile-catalogue-row.reverse{grid-template-columns:75% 25%}
  .mobile-catalogue-item{overflow:hidden;border-radius:8px;background:#f3f2ef;cursor:pointer}
  .mobile-catalogue-item .crop-media{width:100%;height:100%}
  .project-page-header{align-items:flex-start;flex-direction:column}
}

@media (min-width: 900px){
  .mobile-service-accordion{display:none}
}

.crop-editor{display:grid;gap:10px;margin-top:10px}.crop-editor-frame{position:relative;overflow:hidden;border:1px solid var(--line);border-radius:16px;background:#f3eee1}.crop-editor-frame.service{aspect-ratio:25/75;max-width:260px}.crop-editor-frame.about{aspect-ratio:20/80;max-width:280px}.crop-editor-frame.catalogue-narrow{aspect-ratio:1/1.5;max-width:120px}.crop-editor-frame.catalogue-wide{aspect-ratio:3/2;max-width:280px}.crop-editor-frame img{position:absolute;left:50%;top:50%;width:100%;height:100%;object-fit:cover;transform:translate(calc(-50% + var(--crop-x,0%)), calc(-50% + var(--crop-y,0%))) scale(var(--crop-scale,1));transform-origin:center center;cursor:grab;user-select:none}.crop-editor-frame.dragging img{cursor:grabbing}.crop-controls{display:grid;gap:8px;max-width:320px}.crop-controls label{font-size:12px;color:var(--muted)}.crop-controls input[type=range]{width:100%} 

/* mobile v9 layout adjustments */
@media (max-width: 899px){
  .site-header{display:none !important}
  body{padding-top:0}
  .section-home{padding-top:0}
  .hero-phone{width:100%;max-width:none;height:auto;min-height:100svh;background:transparent;box-shadow:none}
  .hero-top{inset:0 0 auto 0;height:40svh;min-height:320px;background:var(--olive)}
  .hero-logo{top:0;left:50%;transform:translateX(-50%);height:40svh;min-height:320px;width:auto;max-width:100%;object-fit:contain;object-position:center center;z-index:2}
  .hero-bg{top:40svh;height:60svh;min-height:420px;object-fit:cover;object-position:center center}
  .hero-overlay{top:40svh;height:60svh;min-height:420px}
  .home-title{top:calc(40svh + 3.2%);font-size:30px}
  .home-buttons{top:calc(40svh + 8.5%);width:156px}

  .mobile-inner-shell{display:block;width:100%}
  .mobile-inner-top{height:65px;background:var(--olive);display:flex;align-items:flex-start;justify-content:space-between;padding:8px 12px 0}
  .mobile-home-icon{width:25px;height:25px;display:grid;place-items:center;color:#f1ead2;flex:0 0 auto}
  .mobile-home-icon svg{width:25px;height:25px;fill:currentColor}
  .mobile-inner-logo{height:50px;width:auto;object-fit:contain;display:block;margin-left:auto;max-width:none}
  .mobile-inner-blank{height:calc((40svh - 65px) * 0.7);min-height:161px;background:var(--olive)}
  .mobile-inner-content{position:relative;background-image:url("assets/img/slide01_img02.png");background-size:cover;background-position:center top;background-repeat:no-repeat;padding-top:18px;padding-bottom:40px}
  .mobile-section-title{position:relative;text-align:center;color:#fff;font-family:"Cormorant Garamond",serif;font-size:30px;line-height:1.1;margin:0 0 18px;z-index:2;font-family:Arial, Helvetica, sans-serif;}

  .service-hero{width:100%;max-width:none;margin:0;background:transparent;border-radius:0;min-height:auto;height:auto;box-shadow:none;overflow:visible}
  .service-nav-bg{position:absolute;inset:0}.service-nav-bg img{display:none}
  .service-nav-title{position:relative;top:auto;left:auto;transform:none;text-align:center;margin-bottom:18px;font-size:30px;z-index:2}
  .service-list-float{position:relative;top:auto;left:auto;transform:none;width:100%;display:flex;flex-direction:column;align-items:center;gap:8px;z-index:2}

  .page-heading{display:none}
  .container{position:relative;z-index:2}
  .about-stack{gap:18px}
  .about-row{grid-template-columns:30% 70%}
  .about-row.reverse{grid-template-columns:70% 30%}
  .about-row .crop-media{min-height:220px}
  .projects-phone{width:100%;max-width:none;margin:0;background:transparent;box-shadow:none;padding:0;border-radius:0}
  .projects-phone-top,.projects-phone-logo,.projects-home-link{display:none}
  .projects-phone-title{padding-top:0;margin-bottom:18px;font-size:30px}
  .projects-board{max-width:min(100%,340px)}
  .project-page-header{display:none}
  .gallery-note{position:relative;z-index:2;color:#fff;text-align:center;margin:0 0 12px}
  .mobile-catalogue{padding-inline:10px}
  .contact-wrap{gap:16px}
}

/* v11 mobile headerless corrections */
.site-header,.mobile-nav{display:none !important}
body{padding-top:0 !important}

@media (max-width: 899px){
  .section-home{padding-top:0}
  .hero-phone.home-mobile-layout{width:100%;max-width:none;height:auto;min-height:100svh;background:transparent;box-shadow:none}
  .hero-phone.home-mobile-layout .hero-top{inset:0 0 auto 0;height:40svh;min-height:320px;background:var(--olive)}
  .hero-phone.home-mobile-layout .hero-logo{
    top:auto;
    bottom:60svh;
    left:50%;
    transform:translateX(-50%);
    width:auto;
    height:40svh;
    min-height:320px;
    max-height:40svh;
    max-width:92vw;
    object-fit:contain;
    object-position:center bottom;
    z-index:2;
  }
  .hero-phone.home-mobile-layout .hero-bg{
    top:40svh;
    height:60svh;
    min-height:420px;
    object-fit:cover;
    object-position:center center;
  }
  .hero-phone.home-mobile-layout .hero-overlay{top:40svh;height:60svh;min-height:420px}
  .hero-phone.home-mobile-layout .home-buttons{
    top:calc(40svh + 8.5%);
    width:156px;
  }

  .mobile-inner-top{
    height:95px;
    background:var(--olive);
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    padding:10px 12px 0;
  }
  .mobile-home-icon{
    width:75px;
    height:75px;
    display:grid;
    place-items:center;
    color:#f1ead2;
    flex:0 0 auto;
  }
  .mobile-home-icon svg{width:25px;height:25px;fill:currentColor}
  .mobile-inner-logo{
    height:75px;
    width:auto;
    object-fit:contain;
    display:block;
    margin-left:auto;
    max-width:none;
  }
  .mobile-inner-blank{
    height:172px;
    background:var(--olive);
  }

  .projects-phone-top,
  .projects-phone-logo,
  .home-title{display:none !important}
}

@media (max-width: 899px){
  .page-about .page-heading h1, .page-services .page-heading h1, .page-projects .page-heading h1, .page-contact .page-heading h1, .page-project .project-pill, .mobile-section-title{font-family:Arial, Helvetica, sans-serif !important;}
}

/* v16 requested updates */
body,
button,
input,
textarea,
select,
.page-heading h1,
.home-title,
.desktop-home-copy h1,
.desktop-home-box,
.service-nav-title,
.service-head strong,
.about-copy h2,
.projects-phone-title,
.project-card span,
.projects-home-link,
.desktop-project-card span,
.contact-info h2,
.footer-grid h3,
.admin-block h2,
.login-card h1,
.project-pill,
.mobile-section-title,
.project-page-header .btn,
.about-kicker,
.eyebrow {
  font-family: Arial, Helvetica, sans-serif !important;
}

.hero-phone.home-mobile-layout .hero-bg,
.page-services .mobile-inner-content,
.page-about .mobile-inner-content,
.page-projects .mobile-inner-content {
  background-position: center top;
}

@media (max-width: 899px){
  .hero-phone.home-mobile-layout{
    min-height:100svh;
    display:grid;
    grid-template-rows:40svh auto;
  }
  .hero-phone.home-mobile-layout .hero-top{
    height:auto;
    min-height:0;
  }
  .hero-phone.home-mobile-layout .hero-bg,
  .hero-phone.home-mobile-layout .hero-overlay{
    top:40svh;
    height:calc(100svh - 40svh);
    min-height:0;
  }
  .hero-phone.home-mobile-layout .hero-bg{
    object-fit:contain;
    object-position:center top;
    background:#0000;
  }
  .hero-phone.home-mobile-layout .home-buttons{
    top:calc(40svh + 10%);
    width:176px;
    gap:24px;
  }

  .page-services .mobile-inner-blank,
  .page-about .mobile-inner-blank,
  .page-projects .mobile-inner-blank,
  .page-project .mobile-inner-blank{
    height:86px;
  }

  .page-services .mobile-inner-content,
  .page-about .mobile-inner-content,
  .page-projects .mobile-inner-content{
    background-size:100% auto;
    background-position:center top;
  }

  .page-project .mobile-inner-content{
    background-image:none;
    background:#fff;
  }

  .service-hero{
    margin-bottom:18px;
  }
  .service-list-float{
    width:min(92vw, 320px);
    gap:12px;
  }
  .service-trigger{
    min-height:48px;
    white-space:normal;
  }

  .page-services .service-hero.card,
  .page-projects .projects-phone.card,
  .page-services .service-item.card,
  .page-project .board-frame.card,
  .page-project .summary-text.card,
  .page-project .summary-hero.card{
    border:none;
  }

  .page-services .mobile-service-panel,
  .page-services .service-body{
    border-radius:28px;
    overflow:hidden;
  }

  .page-services .mobile-service-panel,
  .page-services .service-body,
  .page-about .about-row,
  .page-project .project-summary{
    grid-template-columns:40% 60%;
  }

  .page-about .about-row.reverse{
    grid-template-columns:60% 40%;
  }

  .page-projects .projects-phone{
    background:transparent;
    box-shadow:none;
    border:none;
  }
  .page-projects .projects-board{
    max-width:min(100%, 360px);
  }
  .page-projects .project-grid.project-grid-unified{
    grid-template-columns:1fr 1fr;
    gap:14px;
    align-items:stretch;
  }
  .page-projects .project-grid.project-grid-unified .project-card{
    min-height:148px;
    height:148px;
  }
  .page-projects .project-grid.project-grid-unified .project-card img{
    aspect-ratio:auto;
    height:100%;
  }
  .page-projects .mobile-section-title{
    display:none;
  }

  .page-project .mobile-inner-content .container{
    padding-top:0;
  }
}

@media (min-width: 900px){
  .page-services .page-heading,
  .page-about .page-heading,
  .page-projects .page-heading{
    margin-bottom:14px;
  }

  .page-services .service-item.card,
  .page-projects .desktop-project-card{
    border:none;
  }

  .page-services .service-body,
  .page-about .about-row,
  .page-about .about-row.reverse{
    grid-template-columns:40% 60%;
  }

  .page-about .about-row.reverse{
    grid-template-columns:60% 40%;
  }
}


.page-project .mobile-inner-content,
.page-project .board-frame,
.page-project .summary-text,
.page-project .summary-hero {
  background:#fff;
}


/* v17 completion fixes */
@media (max-width: 899px){
  .hero-phone.home-mobile-layout{
    min-height:auto;
    display:block;
    padding-bottom:18px;
    background:transparent;
  }
  .hero-phone.home-mobile-layout .hero-top{
    height:40svh;
    min-height:320px;
  }
  .hero-phone.home-mobile-layout .hero-logo{
    bottom:60svh;
  }
  .hero-phone.home-mobile-layout .hero-bg{
    position:absolute;
    top:40svh;
    left:0;
    width:100%;
    height:auto;
    min-height:0;
    object-fit:contain;
    object-position:center top;
  }
  .hero-phone.home-mobile-layout .hero-overlay{
    display:none;
  }
  .hero-phone.home-mobile-layout .home-buttons{
    top:calc(40svh + 9%);
    width:176px;
    gap:24px;
  }

  .page-services .mobile-inner-content,
  .page-about .mobile-inner-content,
  .page-projects .mobile-inner-content{
    background-size:100% auto !important;
    background-position:center top !important;
    background-repeat:no-repeat !important;
  }

  .page-services .mobile-inner-blank,
  .page-about .mobile-inner-blank,
  .page-projects .mobile-inner-blank,
  .page-project .mobile-inner-blank{
    height:86px !important;
    min-height:86px !important;
  }

  .page-services .service-hero,
  .page-about .mobile-inner-content .container,
  .page-projects .projects-phone,
  .page-project .mobile-inner-content .container{
    margin-top:0;
  }

  .page-services .service-list-float{
    width:min(96vw, 360px);
    gap:12px;
  }
  .page-services .service-trigger{
    width:100%;
    min-height:48px;
    padding:12px 18px;
    white-space:nowrap;
  }

  .page-services .service-item.card,
  .page-services .service-head,
  .page-services .service-body,
  .page-projects .projects-phone.card,
  .page-project .board-frame.card,
  .page-project .summary-text.card,
  .page-project .summary-hero.card{
    border:none !important;
  }

  .page-services .service-body,
  .page-about .about-row,
  .page-project .project-summary{
    grid-template-columns:40% 60% !important;
  }
  .page-about .about-row.reverse{
    grid-template-columns:60% 40% !important;
  }

  .page-services .service-body{
    border-radius:28px !important;
    overflow:hidden;
    background:#ece5d5;
  }
  .page-services .service-copy{
    padding:24px 24px 24px 20px;
  }
  .page-services .service-photo .crop-media,
  .page-about .about-row .crop-media{
    min-height:220px;
  }

  .page-project .mobile-inner-content,
  .page-project .board-frame,
  .page-project .summary-text,
  .page-project .summary-hero{
    background:#fff !important;
    background-image:none !important;
  }
}

@media (min-width: 900px){
  .page-services .page-heading,
  .page-about .page-heading,
  .page-projects .page-heading{
    margin-bottom:14px;
  }
  .page-services .service-item.card,
  .page-projects .desktop-project-card{
    border:none !important;
  }
  .page-services .service-body,
  .page-about .about-row,
  .page-about .about-row.reverse{
    grid-template-columns:40% 60% !important;
  }
  .page-about .about-row.reverse{
    grid-template-columns:60% 40% !important;
  }
}


/* v18 home load fix + pending mobile page fixes */
@media (max-width: 899px){
  .hero-phone.home-mobile-layout{
    width:100% !important;
    max-width:none !important;
    min-height:100svh !important;
    height:100svh !important;
    display:block !important;
    position:relative !important;
    overflow:hidden !important;
    padding-bottom:0 !important;
    background:transparent !important;
  }
  .hero-phone.home-mobile-layout .hero-top{
    position:absolute !important;
    inset:0 0 auto 0 !important;
    height:40svh !important;
    min-height:320px !important;
  }
  .hero-phone.home-mobile-layout .hero-logo{
    position:absolute !important;
    top:0 !important;
    bottom:auto !important;
    left:50% !important;
    transform:translateX(-50%) !important;
    width:auto !important;
    height:40svh !important;
    min-height:320px !important;
    max-height:none !important;
    max-width:92vw !important;
    object-fit:contain !important;
    object-position:center center !important;
    z-index:2 !important;
  }
  .hero-phone.home-mobile-layout .hero-bg{
    position:absolute !important;
    top:40svh !important;
    left:0 !important;
    right:0 !important;
    width:100% !important;
    height:60svh !important;
    min-height:420px !important;
    object-fit:contain !important;
    object-position:center top !important;
    z-index:1 !important;
  }
  .hero-phone.home-mobile-layout .hero-overlay{
    display:none !important;
  }
  .hero-phone.home-mobile-layout .home-buttons{
    position:absolute !important;
    top:calc(40svh + 9%) !important;
    left:50% !important;
    transform:translateX(-50%) !important;
    width:176px !important;
    gap:24px !important;
    z-index:3 !important;
  }

  .page-services .mobile-inner-blank,
  .page-about .mobile-inner-blank,
  .page-projects .mobile-inner-blank,
  .page-project .mobile-inner-blank,
  .page-services-php .mobile-inner-blank,
  .page-about-php .mobile-inner-blank,
  .page-projects-php .mobile-inner-blank,
  .page-project-php .mobile-inner-blank{
    height:86px !important;
    min-height:86px !important;
  }

  .page-services .mobile-inner-content,
  .page-about .mobile-inner-content,
  .page-projects .mobile-inner-content,
  .page-services-php .mobile-inner-content,
  .page-about-php .mobile-inner-content,
  .page-projects-php .mobile-inner-content{
    background-size:100% auto !important;
    background-position:center top !important;
    background-repeat:no-repeat !important;
  }

  .page-services .service-hero.card,
  .page-projects .projects-phone.card,
  .page-services-php .service-hero.card,
  .page-projects-php .projects-phone.card{
    border:none !important;
    box-shadow:none !important;
    background:transparent !important;
  }

  .page-services .service-list-float,
  .page-services-php .service-list-float{
    width:min(96vw, 420px) !important;
    gap:12px !important;
  }
  .page-services .service-trigger,
  .page-services-php .service-trigger{
    width:100% !important;
    max-width:none !important;
    min-width:0 !important;
    min-height:48px !important;
    padding:12px 20px !important;
    white-space:nowrap !important;
  }

  .page-services .mobile-service-panel,
  .page-services .service-body,
  .page-services-php .mobile-service-panel,
  .page-services-php .service-body{
    grid-template-columns:40% 60% !important;
    border-radius:28px !important;
    overflow:hidden !important;
  }

  .page-about .about-row,
  .page-about-php .about-row,
  .page-project .project-summary,
  .page-project-php .project-summary{
    grid-template-columns:40% 60% !important;
  }
  .page-about .about-row.reverse,
  .page-about-php .about-row.reverse{
    grid-template-columns:60% 40% !important;
  }

  .page-project .mobile-inner-content,
  .page-project .board-frame,
  .page-project .summary-text,
  .page-project .summary-hero,
  .page-project-php .mobile-inner-content,
  .page-project-php .board-frame,
  .page-project-php .summary-text,
  .page-project-php .summary-hero{
    background:#fff !important;
    background-image:none !important;
  }
}


/* v19 targeted overrides */
@media (max-width: 900px){
  .hero-phone.home-mobile-layout{
    width:100% !important;
    max-width:none !important;
    min-height:calc(100svh + 34px) !important;
    padding-bottom:34px !important;
    overflow:hidden !important;
  }
  .hero-phone.home-mobile-layout .hero-bg{
    width:100% !important;
    left:0 !important;
    right:0 !important;
    top:40svh !important;
    height:calc(60svh + 34px) !important;
    min-height:454px !important;
    object-fit:cover !important;
    object-position:center center !important;
  }
  .hero-phone.home-mobile-layout .hero-overlay{
    top:40svh !important;
    height:calc(60svh + 34px) !important;
    min-height:454px !important;
    display:block !important;
    background:linear-gradient(to bottom,rgba(0,0,0,.04),rgba(0,0,0,.18)) !important;
  }
  .hero-phone.home-mobile-layout .hero-copyright{
    position:absolute !important;
    left:0 !important;
    right:0 !important;
    bottom:8px !important;
    z-index:4 !important;
    text-align:center !important;
    color:#fff !important;
    font-family:Arial, Helvetica, sans-serif !important;
    font-size:10px !important;
    line-height:1.2 !important;
    letter-spacing:.4px !important;
    pointer-events:none !important;
  }

  .page-services .mobile-inner-blank,
  .page-about .mobile-inner-blank,
  .page-projects .mobile-inner-blank,
  .page-project .mobile-inner-blank,
  .page-services-php .mobile-inner-blank,
  .page-about-php .mobile-inner-blank,
  .page-projects-php .mobile-inner-blank,
  .page-project-php .mobile-inner-blank{
    height:65px !important;
    min-height:65px !important;
  }

  .page-contact .mobile-inner-blank,
  .page-contact-php .mobile-inner-blank{
    height:34px !important;
    min-height:34px !important;
  }
}
/* v21 hard split between home header and background */
@media (max-width: 900px){
  .hero-phone.home-mobile-layout{
    position:relative !important;
    width:100% !important;
    max-width:none !important;
    min-height:calc(100svh + 34px) !important;
    height:auto !important;
    padding-bottom:34px !important;
    overflow:hidden !important;
    background:var(--olive) !important;
  }

  .hero-phone.home-mobile-layout .hero-top{
    position:absolute !important;
    top:0 !important;
    left:0 !important;
    right:0 !important;
    height:44svh !important;
    min-height:350px !important;
    background:var(--olive) !important;
    z-index:5 !important;
    overflow:hidden !important;
    border-bottom:1px solid rgba(255,255,255,.08) !important;
  }

  .hero-phone.home-mobile-layout .hero-logo{
    position:absolute !important;
    left:50% !important;
    top:10px !important;
    transform:translateX(-50%) !important;
    width:auto !important;
    height:calc(44svh - 20px) !important;
    max-height:330px !important;
    max-width:90vw !important;
    object-fit:contain !important;
    object-position:center center !important;
    z-index:6 !important;
  }

  .hero-phone.home-mobile-layout .hero-bg{
    position:absolute !important;
    top:calc(44svh + 1px) !important;
    left:0 !important;
    right:0 !important;
    width:100% !important;
    height:calc(56svh + 33px) !important;
    min-height:420px !important;
    object-fit:cover !important;
    object-position:center center !important;
    z-index:1 !important;
  }

  .hero-phone.home-mobile-layout .hero-overlay{
    position:absolute !important;
    top:calc(44svh + 1px) !important;
    left:0 !important;
    right:0 !important;
    height:calc(56svh + 33px) !important;
    min-height:420px !important;
    background:linear-gradient(to bottom,rgba(0,0,0,.04),rgba(0,0,0,.18)) !important;
    z-index:2 !important;
    display:block !important;
  }

  .hero-phone.home-mobile-layout .home-buttons{
    position:absolute !important;
    top:calc(44svh + 8%) !important;
    left:50% !important;
    transform:translateX(-50%) !important;
    width:176px !important;
    gap:24px !important;
    z-index:3 !important;
  }

  .hero-phone.home-mobile-layout .hero-copyright{
    position:absolute !important;
    left:0 !important;
    right:0 !important;
    bottom:8px !important;
    text-align:center !important;
    color:#fff !important;
    font-family:Arial, Helvetica, sans-serif !important;
    font-size:10px !important;
    line-height:1.2 !important;
    letter-spacing:.4px !important;
    z-index:4 !important;
    pointer-events:none !important;
  }
}
/* v22 services subsection width + text match About Us */
.page-services .mobile-service-panel,
.page-services-php .mobile-service-panel,
.page-services .service-body,
.page-services-php .service-body{
  width:90% !important;
  margin:0 auto !important;
  grid-template-columns:40% 60% !important;
}

@media (min-width: 900px){
  .page-services .service-body,
  .page-services-php .service-body{
    width:90% !important;
    margin:0 auto !important;
    grid-template-columns:40% 60% !important;
  }
}

@media (max-width: 899px){
  .page-services .mobile-service-panel,
  .page-services-php .mobile-service-panel{
    width:90% !important;
    max-width:none !important;
    margin:0 auto !important;
    grid-template-columns:40% 60% !important;
  }

  .page-services .service-body,
  .page-services-php .service-body{
    width:90% !important;
    margin:0 auto !important;
    grid-template-columns:40% 60% !important;
  }
}

.page-services .service-copy,
.page-services-php .service-copy,
.page-services .mobile-service-copy,
.page-services-php .mobile-service-copy{
  font-family:Arial, Helvetica, sans-serif !important;
  font-size:inherit !important;
  color:#312e25 !important;
}

.page-services .service-copy p,
.page-services .service-copy li,
.page-services-php .service-copy p,
.page-services-php .service-copy li,
.page-services .mobile-service-copy p,
.page-services .mobile-service-copy li,
.page-services-php .mobile-service-copy p,
.page-services-php .mobile-service-copy li{
  font-family:Arial, Helvetica, sans-serif !important;
  font-size:inherit !important;
  line-height:1.95 !important;
  color:#312e25 !important;
  margin:0 !important;
}

.page-services .service-copy ul,
.page-services-php .service-copy ul,
.page-services .mobile-service-copy ul,
.page-services-php .mobile-service-copy ul{
  margin:14px 0 0 !important;
}

.page-services .service-body,
.page-services-php .service-body,
.page-services .mobile-service-panel,
.page-services-php .mobile-service-panel{
  display:block !important;
  width:90% !important;
  margin:0 auto !important;
  overflow:hidden !important;
  border-radius:28px !important;
}

.page-services .service-photo,
.page-services-php .service-photo,
.page-services .mobile-service-photo,
.page-services-php .mobile-service-photo{
  width:100% !important;
}

.page-services .service-photo .crop-media,
.page-services-php .service-photo .crop-media,
.page-services .mobile-service-photo .crop-media,
.page-services-php .mobile-service-photo .crop-media{
  width:100% !important;
  aspect-ratio:16 / 9 !important;
  min-height:auto !important;
}

.page-services .service-copy,
.page-services-php .service-copy,
.page-services .mobile-service-copy,
.page-services-php .mobile-service-copy{
  width:100% !important;
  padding:22px 20px !important;
  background:#ece5d5 !important;
}

.page-services .service-copy p,
.page-services .service-copy li,
.page-services-php .service-copy p,
.page-services-php .service-copy li,
.page-services .mobile-service-copy p,
.page-services .mobile-service-copy li,
.page-services-php .mobile-service-copy p,
.page-services-php .mobile-service-copy li{
  line-height:1.95 !important;
  color:#312e25 !important;
}

@media (min-width: 900px){
  .page-services .service-body,
  .page-services-php .service-body,
  .page-services .service-body.active,
  .page-services-php .service-body.active{
    width:90% !important;
    margin:0 auto !important;
    display:grid !important;
    grid-template-columns:1fr !important;
    grid-template-rows:auto auto !important;
    border-radius:28px !important;
    overflow:hidden !important;
    background:#ece5d5 !important;
  }

  .page-services .service-photo,
  .page-services-php .service-photo{
    width:100% !important;
    grid-column:1 !important;
    grid-row:1 !important;
  }

  .page-services .service-photo .crop-media,
  .page-services-php .service-photo .crop-media{
    width:100% !important;
    aspect-ratio:16 / 9 !important;
    min-height:auto !important;
    height:auto !important;
  }

  .page-services .service-copy,
  .page-services-php .service-copy{
    width:100% !important;
    grid-column:1 !important;
    grid-row:2 !important;
    padding:26px 22px !important;
    background:#ece5d5 !important;
  }
}

@media (max-width: 899px){
  .page-services .mobile-service-panel,
  .page-services-php .mobile-service-panel{
    width:90% !important;
    max-width:none !important;
    margin:0 auto !important;
    display:grid !important;
    grid-template-columns:1fr !important;
    grid-template-rows:auto auto !important;
    border-radius:28px !important;
    overflow:hidden !important;
    background:#ece5d5 !important;
  }

  .page-services .mobile-service-photo,
  .page-services-php .mobile-service-photo{
    width:100% !important;
    grid-column:1 !important;
    grid-row:1 !important;
  }

  .page-services .mobile-service-photo .crop-media,
  .page-services-php .mobile-service-photo .crop-media{
    width:100% !important;
    aspect-ratio:16 / 9 !important;
    min-height:auto !important;
    height:auto !important;
  }

  .page-services .mobile-service-copy,
  .page-services-php .mobile-service-copy{
    width:100% !important;
    grid-column:1 !important;
    grid-row:2 !important;
    min-height:auto !important;
    padding:18px 18px 20px !important;
    background:#ece5d5 !important;
  }

  .page-services .service-body,
  .page-services-php .service-body,
  .page-services .service-body.active,
  .page-services-php .service-body.active{
    width:90% !important;
    margin:0 auto !important;
    display:grid !important;
    grid-template-columns:1fr !important;
    grid-template-rows:auto auto !important;
    border-radius:28px !important;
    overflow:hidden !important;
    background:#ece5d5 !important;
  }

  .page-services .service-photo,
  .page-services-php .service-photo{
    width:100% !important;
    grid-column:1 !important;
    grid-row:1 !important;
  }

  .page-services .service-photo .crop-media,
  .page-services-php .service-photo .crop-media{
    width:100% !important;
    aspect-ratio:16 / 9 !important;
    min-height:auto !important;
    height:auto !important;
  }

  .page-services .service-copy,
  .page-services-php .service-copy{
    width:100% !important;
    grid-column:1 !important;
    grid-row:2 !important;
    padding:18px 18px 20px !important;
    background:#ece5d5 !important;
  }
}

.page-services .service-copy p,
.page-services .service-copy li,
.page-services-php .service-copy p,
.page-services-php .service-copy li,
.page-services .mobile-service-copy p,
.page-services .mobile-service-copy li,
.page-services-php .mobile-service-copy p,
.page-services-php .mobile-service-copy li{
  font-family:Arial, Helvetica, sans-serif !important;
  line-height:1.95 !important;
  color:#312e25 !important;
}

/* final home mobile block - header reduced to 70% */
@media (max-width: 900px){
  .hero-phone.home-mobile-layout{
    position:relative !important;
    width:100% !important;
    max-width:none !important;
    min-height:calc(31svh + 520px + 34px) !important;
    height:auto !important;
    overflow:hidden !important;
    padding-bottom:34px !important;
    background:var(--olive) !important;
  }

  .hero-phone.home-mobile-layout .hero-top{
    position:absolute !important;
    top:0 !important;
    left:0 !important;
    right:0 !important;
    height:25svh !important;
    min-height:0 !important;
   background:var(--olive) !important;
    z-index:5 !important;
    overflow:hidden !important;
    border-bottom:1px solid rgba(255,255,255,.08) !important;
  }

.hero-phone.home-mobile-layout .hero-logo{
  position:absolute !important;
  left:50% !important;
  top:0 !important;
  transform:translateX(-50%) !important;

  width:auto !important;
  height:auto !important;

  max-width:none !important;
  min-width:0 !important;
  max-height:none !important;
  min-height:0 !important;

  object-fit:unset !important;
  object-position:center top !important;
  z-index:6 !important;
}

 .hero-phone.home-mobile-layout .hero-bg{
  position:absolute !important;
  top:calc(31svh - 2px) !important;
  left:0 !important;
  right:0 !important;
  width:100% !important;
  height:520px !important;
  min-height:520px !important;
  object-fit:cover !important;
  object-position:center center !important;
  z-index:1 !important;
}

.hero-phone.home-mobile-layout .hero-overlay{
  position:absolute !important;
  top:calc(31svh - 2px) !important;
  left:0 !important;
  right:0 !important;
  width:100% !important;
  height:520px !important;
  min-height:520px !important;
  background:linear-gradient(to bottom,rgba(0,0,0,0),rgba(0,0,0,.18)) !important;
  z-index:2 !important;
  display:block !important;
}
  .hero-phone.home-mobile-layout .home-buttons{
    position:absolute !important;
    top:calc(25svh + 40px) !important;
    left:50% !important;
    transform:translateX(-50%) !important;
    width:176px !important;
    display:flex !important;
    flex-direction:column !important;
    gap:24px !important;
    z-index:3 !important;
  }

  .hero-phone.home-mobile-layout .home-buttons a{
    display:block !important;
  }

  .hero-phone.home-mobile-layout .hero-copyright{
    position:absolute !important;
    left:0 !important;
    right:0 !important;
    bottom:8px !important;
    margin:0 !important;
    text-align:center !important;
    color:#fff !important;
    font-family:Arial, Helvetica, sans-serif !important;
    font-size:10px !important;
    line-height:1.2 !important;
    letter-spacing:.4px !important;
    z-index:4 !important;
    pointer-events:none !important;
  }
}
@media (max-width: 900px){
  .home-like-inner-layout{
    width:100% !important;
    max-width:none !important;
    min-height:auto !important;
    height:auto !important;
    overflow:hidden !important;
    background:transparent !important;
    padding-bottom:34px !important;
    box-shadow:none !important;
  }

  .home-like-inner-layout .mobile-inner-top{
    height:65px !important;
    background:var(--olive) !important;
    display:block !important;
  }

  .home-like-inner-layout .mobile-inner-blank{
    height:152px !important; /* adjust this freely */
    min-height:0 !important;
    background:var(--olive) !important;
    display:block !important;
  }

.home-like-inner-layout .mobile-inner-content.home-mobile-content{
  position:relative !important;
  background-image:url("assets/img/slide05_img01.png") !important;
  background-size:cover !important;
  background-position:center top !important;
  background-repeat:no-repeat !important;
  padding-top:40px !important;
  padding-bottom:180px !important;
  min-height:520px !important;
}
.home-like-inner-layout .home-inner-logo{
 position:absolute !important;
  top:10px !important;
  left:50% !important;
  transform:translateX(-50%) !important;
  width:auto !important;
  height:auto !important;
  max-width:none !important;
  max-height:none !important;
  object-fit:unset !important;
  z-index:6 !important;
}
  .home-like-inner-layout .home-buttons{
    position:relative !important;
    top:auto !important;
    left:auto !important;
    transform:none !important;
    width:176px !important;
    margin:0 auto !important;
    display:flex !important;
    flex-direction:column !important;
    gap:24px !important;
    z-index:3 !important;
  }

  .home-like-inner-layout .home-buttons a{
    display:block !important;
  }

  .home-like-inner-layout .hero-copyright{
    position:absolute !important;
    left:0 !important;
    right:0 !important;
    bottom:8px !important;
    margin:0 !important;
    text-align:center !important;
    color:#fff !important;
    font-family:Arial, Helvetica, sans-serif !important;
    font-size:10px !important;
    line-height:1.2 !important;
    letter-spacing:.4px !important;
    z-index:4 !important;
    pointer-events:none !important;
  }

  /* kill old home-layer elements if still present */
  .home-like-inner-layout .hero-top,
  .home-like-inner-layout .hero-bg,
  .home-like-inner-layout .hero-overlay{
    display:none !important;
  }
}

@media (max-width: 900px){
  .home-like-inner-layout{
    position:relative !important;
    width:100% !important;
    max-width:none !important;
    min-height:auto !important;
    height:auto !important;
    overflow:hidden !important;
    background:transparent !important;
    padding-bottom:34px !important;
    box-shadow:none !important;
  }

  .home-like-inner-layout .mobile-inner-top{
    height:65px !important;
    background:var(--olive) !important;
    display:block !important;
  }

  .home-like-inner-layout .mobile-inner-blank{
    height:152px !important;
    min-height:0 !important;
    background:var(--olive) !important;
    display:block !important;
  }

  .home-like-inner-layout .mobile-inner-content.home-mobile-content{
    position:relative !important;
    background-image:url("assets/img/slide05_img01.png") !important;
    background-size:cover !important;
    background-position:center top !important;
    background-repeat:no-repeat !important;
    padding-top:40px !important;
    padding-bottom:180px !important;
    min-height:520px !important;
  }

  .home-like-inner-layout .home-inner-logo{
   position:absolute !important;
  top:-12px !important;
  left:50% !important;
  transform:translateX(-50%) !important;
  z-index:20 !important;
  }

  .home-like-inner-layout .home-buttons{
    position:relative !important;
    top:auto !important;
    left:auto !important;
    transform:none !important;
    width:176px !important;
    margin:0 auto !important;
    display:flex !important;
    flex-direction:column !important;
    gap:24px !important;
    z-index:3 !important;
  }

  .home-like-inner-layout .hero-copyright{
    position:absolute !important;
    left:0 !important;
    right:0 !important;
    bottom:8px !important;
    margin:0 !important;
    text-align:center !important;
    color:#fff !important;
    font-family:Arial, Helvetica, sans-serif !important;
    font-size:10px !important;
    line-height:1.2 !important;
    letter-spacing:.4px !important;
    z-index:4 !important;
    pointer-events:none !important;
  }
}

@media (max-width: 900px){
  /* clean home layout based on inner pages */
  .hero-phone.home-mobile-layout.home-like-inner-layout{
    display:grid !important;
    grid-template-rows:65px 152px auto 34px !important;
    width:100% !important;
    max-width:none !important;
    min-height:auto !important;
    height:auto !important;
    overflow:hidden !important;
    background:transparent !important;
    padding:0 !important;
    box-shadow:none !important;
    position:relative !important;
  }

  .hero-phone.home-mobile-layout.home-like-inner-layout .mobile-inner-top{
    grid-row:1 !important;
    height:auto !important;
    min-height:0 !important;
    background:var(--olive) !important;
    display:block !important;
  }

  .hero-phone.home-mobile-layout.home-like-inner-layout .mobile-inner-blank{
    grid-row:2 !important;
    height:auto !important;
    min-height:0 !important;
    background:var(--olive) !important;
    display:block !important;
  }

  /* logo lives in header area, not absolute over page */
  .hero-phone.home-mobile-layout.home-like-inner-layout .home-inner-logo{
    grid-row:1 / span 2 !important;
    justify-self:center !important;
    align-self:start !important;
    display:block !important;
    position:relative !important;
    top:10px !important;
    left:auto !important;
    transform:none !important;
    width:150px !important;
    height:150px !important;
    max-width:none !important;
    max-height:none !important;
    margin:0 !important;
    z-index:20 !important;
  }

  .hero-phone.home-mobile-layout.home-like-inner-layout .mobile-inner-content.home-mobile-content{
    grid-row:3 !important;
    position:relative !important;
    background-image:url("assets/img/slide05_img01.png") !important;
    background-size:cover !important;
    background-position:center top !important;
    background-repeat:no-repeat !important;
    min-height:520px !important;
    padding:40px 0 180px 0 !important;
  }

  .hero-phone.home-mobile-layout.home-like-inner-layout .home-buttons{
    position:relative !important;
    top:auto !important;
    left:auto !important;
    transform:none !important;
    width:176px !important;
    margin:0 auto !important;
    display:flex !important;
    flex-direction:column !important;
    gap:24px !important;
    z-index:3 !important;
  }

  .hero-phone.home-mobile-layout.home-like-inner-layout .hero-copyright{
    grid-row:4 !important;
    position:relative !important;
    left:auto !important;
    right:auto !important;
    bottom:auto !important;
    margin:0 !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    text-align:center !important;
    color:#fff !important;
    font-family:Arial, Helvetica, sans-serif !important;
    font-size:10px !important;
    line-height:1.2 !important;
    letter-spacing:.4px !important;
    z-index:4 !important;
    pointer-events:none !important;
    background:transparent !important;
  }

  /* completely disable old hero-layer behavior on this page */
  .hero-phone.home-mobile-layout.home-like-inner-layout .hero-top,
  .hero-phone.home-mobile-layout.home-like-inner-layout .hero-bg,
  .hero-phone.home-mobile-layout.home-like-inner-layout .hero-overlay{
    display:none !important;
  }
}
/* ===== FINAL CLEAN HOME MOBILE FIX ===== */
@media (max-width: 900px){

  /* kill old home hero layers completely on the home inner layout */
  .hero-phone.home-mobile-layout.home-like-inner-layout .hero-top,
  .hero-phone.home-mobile-layout.home-like-inner-layout .hero-bg,
  .hero-phone.home-mobile-layout.home-like-inner-layout .hero-overlay,
  .hero-phone.home-mobile-layout.home-like-inner-layout .hero-logo,
  .hero-phone.home-mobile-layout.home-like-inner-layout .home-title{
    display:none !important;
  }

  .hero-phone.home-mobile-layout.home-like-inner-layout{
    position:relative !important;
    display:grid !important;
    grid-template-rows:65px 152px auto 34px !important;
    width:100% !important;
    max-width:none !important;
    min-height:auto !important;
    height:auto !important;
    overflow:hidden !important;
    background:transparent !important;
    padding:0 !important;
    margin:0 auto !important;
    box-shadow:none !important;
  }

  .hero-phone.home-mobile-layout.home-like-inner-layout .mobile-inner-top{
    grid-row:1 !important;
    display:block !important;
    height:65px !important;
    min-height:65px !important;
    background:var(--olive) !important;
  }

  .hero-phone.home-mobile-layout.home-like-inner-layout .mobile-inner-blank{
    grid-row:2 !important;
    display:block !important;
    height:152px !important;
    min-height:152px !important;
    background:var(--olive) !important;
  }

  /* the logo is a normal grid item inside the top two rows */
  .hero-phone.home-mobile-layout.home-like-inner-layout > .home-inner-logo{
    grid-row:1 / span 2 !important;
    justify-self:center !important;
    align-self:start !important;

    position:static !important;
    transform:none !important;
    left:auto !important;
    top:auto !important;
    bottom:auto !important;
    right:auto !important;

    display:block !important;
    width:150px !important;
    height:150px !important;
    margin:10px 0 0 0 !important;
    max-width:none !important;
    max-height:none !important;
    min-width:0 !important;
    min-height:0 !important;

    object-fit:contain !important;
    z-index:20 !important;
  }

  .hero-phone.home-mobile-layout.home-like-inner-layout .mobile-inner-content.home-mobile-content{
    grid-row:3 !important;
    position:relative !important;
    background-image:url("assets/img/slide05_img01.png") !important;
    background-size:cover !important;
    background-position:center top !important;
    background-repeat:no-repeat !important;
    min-height:520px !important;
    padding:40px 0 180px 0 !important;
  }

  .hero-phone.home-mobile-layout.home-like-inner-layout .home-buttons{
    position:relative !important;
    top:auto !important;
    left:auto !important;
    right:auto !important;
    bottom:auto !important;
    transform:none !important;

    width:176px !important;
    margin:0 auto !important;
    display:flex !important;
    flex-direction:column !important;
    gap:24px !important;
    z-index:3 !important;
  }

  .hero-phone.home-mobile-layout.home-like-inner-layout .hero-copyright{
    grid-row:4 !important;
    position:relative !important;
    left:auto !important;
    right:auto !important;
    top:auto !important;
    bottom:auto !important;
    transform:none !important;

    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    text-align:center !important;
    margin:0 !important;

    color:#fff !important;
    font-family:Arial, Helvetica, sans-serif !important;
    font-size:10px !important;
    line-height:1.2 !important;
    letter-spacing:.4px !important;
    pointer-events:none !important;
    background:transparent !important;
  }
}
/* ===== FORCE LOGO (TEMP CLEAN FIX) ===== */
@media (max-width: 900px){
  .force-logo{
    position:absolute !important;
    top:10px !important;
    left:50% !important;
    transform:translateX(-50%) !important;

    width:150px !important;
    height:150px !important;

    z-index:9999 !important;

    display:block !important;
    pointer-events:none !important;
  }
}
@media (max-width: 900px){
  .hero-logo,
  .home-inner-logo{
    display:none !important;
  }
}
/* =========================================================
   DESKTOP + ADMIN FINAL LAYER
   Mobile layout is intentionally untouched above this block.
   All public website changes are scoped to min-width:901px.
========================================================= */
@media (min-width: 901px){
  body{
    background:
      radial-gradient(circle at top left, rgba(131,123,81,.14), transparent 34%),
      linear-gradient(180deg,#f6f0e5 0%,#eee5d3 100%);
    color:#252116;
  }

  .site-header.desktop-site-header{
    display:block !important;
    position:sticky;
    top:0;
    z-index:80;
    background:#837B51;
    border-bottom:1px solid rgba(237,229,202,.32);
    backdrop-filter:none;
  }
  .desktop-header-inner{
    min-height:82px;
    display:grid;
    grid-template-columns:auto 1fr auto;
    align-items:center;
    gap:28px;
  }
  .desktop-brand{
    display:flex;
    align-items:center;
    color:#EDE5CA;
  }
  .desktop-brand img{width:196px;height:auto;object-fit:contain;display:block}
  .desktop-nav{
    display:flex;
    align-items:center;
    justify-content:center;
    gap:26px;
  }
  .desktop-nav .nav-link{
    font-size:13px;
    letter-spacing:.08em;
    text-transform:uppercase;
    color:#EDE5CA;
    padding:31px 0 27px;
  }
  .desktop-nav .nav-link.active::after{
    bottom:20px;
    height:1px;
  }
  .desktop-header-actions{
    display:flex;
    align-items:center;
    gap:12px;
  }
  .desktop-contact-link{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    height:40px;
    padding:0 18px;
    border-radius:999px;
    background:#EDE5CA;
    color:#5e5940;
    font-size:13px;
    font-weight:700;
    border:1px solid rgba(237,229,202,.55);
  }
  .lang-switch{background:rgba(237,229,202,.16);border-color:rgba(237,229,202,.55)}
  .lang-switch a{font-weight:700;color:#EDE5CA}
  .lang-switch a.active{background:#EDE5CA;color:#5e5940}

  .mobile-inner-top,
  .mobile-inner-blank,
  .mobile-section-title,
  .projects-phone,
  .service-hero{
    display:none !important;
  }
  .mobile-inner-shell,
  .mobile-inner-content{
    display:block !important;
    background:none !important;
    padding:0 !important;
    min-height:0 !important;
  }

  .section{padding:78px 0 96px}
  .section-home{padding-top:56px}
  .page-heading{margin-bottom:18px}
  .page-heading h1{
    font-size:clamp(48px,5vw,82px);
    line-height:.96;
    letter-spacing:-.04em;
    color:#2c281d;
  }
  .page-heading p,.desktop-intro{
    font-size:17px;
    max-width:790px;
    color:#625b48;
  }
  .desktop-intro{margin-bottom:42px}

  .desktop-home{
    position:relative;
    overflow:hidden;
    min-height:590px;
    grid-template-columns:1.05fr .95fr;
    align-items:stretch;
    gap:34px;
    padding:42px;
    border:none;
    background:linear-gradient(135deg,#fbf7ee 0%,#e9dec8 100%);
    box-shadow:0 28px 80px rgba(68,55,29,.14);
  }
  .desktop-home::before{
    content:"";
    position:absolute;
    inset:42px 42px 42px auto;
    width:44%;
    background:url("assets/img/slide05_img01.png") center/cover no-repeat;
    border-radius:32px;
    box-shadow:0 30px 70px rgba(37,29,12,.18);
  }
  .desktop-home-copy{
    position:relative;
    z-index:2;
    display:flex;
    flex-direction:column;
    justify-content:center;
    max-width:610px;
    padding:28px 0 28px 18px;
  }
  .desktop-home-copy .eyebrow{margin-bottom:20px}
  .desktop-home-copy h1{
    font-size:clamp(58px,6vw,92px);
    line-height:.9;
    letter-spacing:-.055em;
    color:#2c281d;
  }
  .desktop-home-copy p{font-size:18px;color:#5d5747;line-height:1.9}
  .desktop-hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:28px}
  .btn.ghost{background:transparent;color:var(--olive-deep);border:1px solid rgba(131,123,81,.42)}
  .desktop-home-grid{
    position:relative;
    z-index:2;
    align-self:center;
    margin:auto 0 auto auto;
    width:min(100%,430px);
    grid-template-columns:1fr 1fr;
    gap:14px;
    align-content:center;
    justify-content:center;
  }
  .desktop-home-box{
    min-height:134px;
    display:flex;
    align-items:center;
    justify-content:center;
    padding:22px;
    border-radius:24px;
    background:rgba(65,60,43,.72);
    border:1px solid rgba(255,255,255,.18);
    backdrop-filter:blur(4px);
    font-size:25px;
    line-height:1.15;
    text-align:center;
    transition:transform .25s ease, background .25s ease;
  }
  .desktop-home-box:hover{transform:translateY(-4px);background:rgba(42,38,27,.82)}

  .service-layout{
    display:grid !important;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:24px;
    margin-top:18px;
  }
  .service-item.card{
    overflow:hidden;
    border:1px solid rgba(131,123,81,.18) !important;
    background:#fbf7ee;
    box-shadow:0 22px 55px rgba(67,54,24,.11);
  }
  .service-head{
    min-height:92px;
    background:#fbf7ee;
    padding:24px 26px;
  }
  .service-head strong{font-size:30px;letter-spacing:-.03em;color:#2f2a1c}
  .service-body,
  .service-body.active{
    display:grid !important;
    grid-template-columns:42% 58% !important;
    gap:14px;
    padding:14px;
    border-top:1px solid rgba(131,123,81,.16);
    background:#fbf7ee;
  }
  .service-photo .crop-media{min-height:360px;border-radius:18px}
  .service-copy{padding:34px 34px 42px;background:#ece5d5;border-radius:18px}
  .service-copy p,.service-copy li{font-size:15px;line-height:1.85;color:#2e2a1f}

  .about-stack{gap:34px;margin-top:12px}
  .about-row.card{
    border:none;
    min-height:430px;
    background:#fbf7ee;
    box-shadow:0 24px 70px rgba(67,54,24,.12);
  }
  .about-row,
  .about-row.reverse{grid-template-columns:45% 55% !important}
  .about-row.reverse{grid-template-columns:55% 45% !important}
  .about-row .crop-media{min-height:430px}
  .about-copy{padding:58px 64px}
  .about-copy h2{font-size:48px;letter-spacing:-.04em;color:#2f2a1c}
  .about-copy p{font-size:16px;line-height:2;color:#504938}

  .desktop-project-grid{
    display:grid !important;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:24px;
  }
  .desktop-project-card{
    min-height:390px;
    border-radius:30px;
    box-shadow:0 24px 70px rgba(52,42,20,.16);
    transition:transform .25s ease, box-shadow .25s ease;
  }
  .desktop-project-card:hover{transform:translateY(-6px);box-shadow:0 30px 90px rgba(52,42,20,.22)}
  .desktop-project-card img{height:100%;aspect-ratio:auto;transition:transform .45s ease}
  .desktop-project-card:hover img{transform:scale(1.04)}
  .desktop-project-card::after{background:linear-gradient(to top,rgba(0,0,0,.58),rgba(0,0,0,.08) 58%,rgba(0,0,0,0))}
  .desktop-project-card span{font-size:30px;bottom:24px;left:24px;right:24px}

  .project-page-header{
    margin-top:0;
    padding-bottom:8px;
    border-bottom:1px solid rgba(131,123,81,.22);
  }
  .project-pill{
    background:transparent;
    color:#2f2a1c;
    padding:0;
    font-size:42px;
    letter-spacing:-.045em;
  }
  .project-summary{
    grid-template-columns:.9fr 1.1fr;
    gap:28px;
    margin:34px 0;
  }
  .summary-text,.summary-hero{border:none;overflow:hidden;box-shadow:0 20px 60px rgba(67,54,24,.12)}
  .summary-text{padding:42px;background:#fbf7ee}
  .summary-text p{font-size:16px;color:#504938;line-height:2}
  .summary-hero img{height:420px;object-fit:cover}
  .board-section{display:block;margin:28px 0}
  .board-frame{border:none;box-shadow:0 24px 70px rgba(67,54,24,.12);background:#fbf7ee;border-radius:28px}
  .gallery-note{color:#6c644f;text-align:center;margin-top:18px}
  .project-bottom-actions{
    display:flex;
    justify-content:center;
    align-items:center;
    gap:14px;
    flex-wrap:wrap;
    margin:42px auto 0;
    padding-top:30px;
    border-top:1px solid rgba(131,123,81,.22);
  }

  .contact-wrap{
    grid-template-columns:1.1fr .9fr;
    gap:28px;
    align-items:stretch;
  }
  .contact-form,.contact-info{
    border:none;
    box-shadow:0 24px 70px rgba(67,54,24,.12);
  }
  .contact-form{padding:42px;background:#fbf7ee}
  .contact-info{padding:42px;background:linear-gradient(145deg,#837B51,#514c35)}
  .contact-info h2{font-size:48px;letter-spacing:-.04em}
  input,textarea,select{border-radius:18px;border-color:rgba(131,123,81,.25)}
}

@media (min-width: 901px) and (max-width: 1180px){
  .desktop-header-inner{grid-template-columns:1fr;gap:10px;padding:12px 0 18px}
  .desktop-brand{justify-content:center}
  .desktop-nav{gap:18px;flex-wrap:wrap}
  .desktop-nav .nav-link{padding:8px 0}
  .desktop-nav .nav-link.active::after{bottom:-4px}
  .desktop-header-actions{justify-content:center}
  .desktop-home{grid-template-columns:1fr;min-height:auto}
  .desktop-home::before{position:relative;inset:auto;width:100%;height:360px;order:2;display:block}
  .desktop-home-grid{width:100%}
  .service-layout,.desktop-project-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}

/* Admin-only polish. Scoped to admin classes so public mobile stays safe. */
.admin-shell{
  background:#f4efe5;
}
.admin-side{
  position:sticky;
  top:0;
  height:100vh;
  background:linear-gradient(180deg,#1f1c15,#37301f);
  padding:28px 20px;
  box-shadow:12px 0 40px rgba(0,0,0,.08);
}
.admin-side h2{margin:0 0 22px;font-size:24px;line-height:1;color:#fff}
.admin-side a{margin-bottom:6px;color:#efe8d4;border:1px solid transparent}
.admin-side a:hover,.admin-side a.active{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.08)}
.admin-main{padding:34px;max-width:1380px;width:100%}
.admin-main > .notice{position:sticky;top:14px;z-index:20;box-shadow:0 14px 30px rgba(0,0,0,.08)}
.admin-block.card{
  border:1px solid rgba(131,123,81,.2);
  background:#fffaf1;
  box-shadow:0 18px 45px rgba(67,54,24,.08);
  border-radius:24px;
}
.admin-block h2{font-size:34px;color:#2e291e;margin-bottom:18px}
.admin-block h3{font-size:18px;margin:0 0 16px;color:#514b35}
.admin-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
.admin-grid label{display:grid;gap:8px;font-size:13px;font-weight:700;color:#5d553e}
.admin-grid input,.admin-grid textarea,.admin-grid select{background:#fff;border-radius:14px}
.admin-grid textarea{min-height:132px}
.image-preview{width:160px;height:110px;border-radius:16px;margin:8px 0 10px;background:#eee2c9}
.crop-editor{background:#f8f1e3;border:1px dashed rgba(131,123,81,.38);border-radius:18px;padding:12px}
.crop-controls{max-width:100%}
.login-wrap{background:linear-gradient(135deg,#f6efe1,#dcd0b6)}
.login-card{border:none;box-shadow:0 28px 80px rgba(67,54,24,.16);background:#fffaf1}

@media (max-width: 900px){
  .admin-shell{display:block}
  .admin-side{position:relative;height:auto;display:block}
  .admin-main{padding:16px}
  .admin-grid{grid-template-columns:1fr}
}

/* Desktop refinement patch: header contrast, project CTA, and Nails & Spa board alignment. */
@media (min-width: 901px){
  .site-header.desktop-site-header .nav-link:hover,
  .site-header.desktop-site-header .nav-link.active{color:#fff8dc}
  .site-header.desktop-site-header .nav-link.active::after{background:#EDE5CA}
  body.rtl .desktop-home-box{text-align:center}
  body.rtl .desktop-home-grid{margin:auto auto auto 0}
  .page-project .project-bottom-actions .btn.ghost,
  .page-project-php .project-bottom-actions .btn.ghost{background:transparent;color:var(--olive-deep);border:1px solid rgba(131,123,81,.42)}
  .page-project .project-bottom-actions .btn:not(.ghost),
  .page-project-php .project-bottom-actions .btn:not(.ghost){background:var(--olive);color:#fff}
}
@media (max-width: 900px){
  .project-bottom-actions{
    display:flex;
    flex-direction:column;
    gap:10px;
    margin:22px auto 4px;
    padding:18px 0 0;
    width:100%;
  }
  .project-bottom-actions .btn{width:100%;max-width:260px;margin:0 auto}
}

/* =========================================================
   V3 targeted fixes from client feedback
   Public layout changes are desktop-scoped unless noted.
========================================================= */
@media (min-width: 901px){
  /* 5. Home pillar cards: true center alignment inside the right-side area */
  .desktop-home{
    align-items:center !important;
  }
  .desktop-home-grid{
    display:grid !important;
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
    gap:16px !important;
    width:min(100%,440px) !important;
    margin:0 !important;
    justify-self:end !important;
    align-self:center !important;
    place-content:center !important;
    place-items:stretch !important;
  }
  body.rtl .desktop-home-grid{
    justify-self:start !important;
    margin:0 !important;
  }
  .desktop-home-box{
    width:100% !important;
    min-height:150px !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    text-align:center !important;
  }

  /* 6. Services: keep the inner light box away from the outer card bottom */
  .page-services .service-item.card,
  .page-services-php .service-item.card{
    padding-bottom:24px !important;
  }
  .page-services .service-body,
  .page-services-php .service-body,
  .page-services .service-body.active,
  .page-services-php .service-body.active{
    width:calc(100% - 48px) !important;
    margin:0 auto 0 !important;
    padding:18px !important;
    background:#fbf7ee !important;
    border-radius:24px !important;
    overflow:visible !important;
  }
  .page-services .service-copy,
  .page-services-php .service-copy{
    padding:30px 28px 36px !important;
    border-radius:20px !important;
    margin:0 !important;
  }

  /* 9. Women Majlis catalogue: clean centered desktop board layout */
  .project-slug-women-majlis .board-frame{
    padding:24px !important;
    aspect-ratio:auto !important;
    display:grid !important;
    grid-template-columns:repeat(auto-fit,minmax(230px,1fr)) !important;
    gap:18px !important;
    align-items:center !important;
    justify-items:center !important;
  }
  .project-slug-women-majlis .board-frame .board-image{
    position:relative !important;
    left:auto !important;
    top:auto !important;
    width:100% !important;
    height:280px !important;
    max-width:100% !important;
    border-radius:18px !important;
    overflow:hidden !important;
  }
  .project-slug-women-majlis .board-frame .board-image .crop-media{
    width:100% !important;
    height:100% !important;
  }
}

/* 10. Copyright line at the bottom of every public page */
.alore-copyright-line{
  width:100%;
  text-align:center;
  padding:18px 20px 22px;
  color:#6a634b;
  font-size:12px;
  letter-spacing:.08em;
  border-top:1px solid rgba(131,123,81,.18);
  background:#f2ece1;
}
@media (max-width: 900px){
  .alore-copyright-line{
    padding:10px 16px 14px;
    font-size:10px;
    letter-spacing:.04em;
  }
}

/* =========================================================
   V4 final correction patch
   Targets the exact desktop selectors that were still failing.
   Mobile remains protected by min-width:901px for layout fixes.
========================================================= */
@media (min-width: 901px){
  /* 1. Home right-side pillar cards: center the whole group inside the hero,
     keep breathing space from the right edge, and center text inside each card. */
  .page-index .desktop-home,
  .page-index-php .desktop-home{
    grid-template-columns:minmax(0,1.05fr) minmax(360px,.95fr) !important;
    align-items:center !important;
    column-gap:48px !important;
    padding:54px 64px 54px 54px !important;
  }
  .page-index .desktop-home::before,
  .page-index-php .desktop-home::before{
    inset:54px 64px 54px auto !important;
    width:calc(44% - 16px) !important;
  }
  .page-index .desktop-home-grid,
  .page-index-php .desktop-home-grid{
    grid-column:2 !important;
    display:grid !important;
    grid-template-columns:repeat(2, minmax(0, 1fr)) !important;
    gap:18px !important;
    width:min(100%, 380px) !important;
    max-width:380px !important;
    margin:0 auto !important;
    justify-self:center !important;
    align-self:center !important;
    place-items:stretch !important;
    padding:0 !important;
  }
  .page-index .desktop-home-box,
  .page-index-php .desktop-home-box{
    width:100% !important;
    min-height:132px !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    text-align:center !important;
    padding:20px !important;
  }

  /* 2. Services cards: real bottom padding between the inner light box and the outer card. */
  .page-services .service-item.card,
  .page-services-php .service-item.card{
    padding-bottom:30px !important;
    overflow:visible !important;
  }
  .page-services .service-body,
  .page-services-php .service-body,
  .page-services .service-body.active,
  .page-services-php .service-body.active{
    width:calc(100% - 52px) !important;
    margin:0 auto 0 !important;
    padding:16px 16px 28px !important;
    box-sizing:border-box !important;
    border-radius:28px !important;
    overflow:visible !important;
    background:#fbf7ee !important;
  }
  .page-services .service-copy,
  .page-services-php .service-copy{
    margin:0 !important;
    padding:28px 26px 34px !important;
    border-radius:20px !important;
    box-sizing:border-box !important;
  }

  /* 4. Women Majlis catalogue: ignore the old absolute collage positions on desktop,
     center every image tile inside an even clean grid. */
  main.project-slug-women-majlis .board-frame.card{
    position:relative !important;
    display:grid !important;
    grid-template-columns:repeat(auto-fit, minmax(240px, 1fr)) !important;
    gap:22px !important;
    width:100% !important;
    height:auto !important;
    min-height:0 !important;
    padding:26px !important;
    padding-top:26px !important;
    aspect-ratio:auto !important;
    align-items:center !important;
    justify-items:center !important;
    overflow:visible !important;
  }
  main.project-slug-women-majlis .board-frame.card .board-image{
    position:relative !important;
    inset:auto !important;
    left:auto !important;
    top:auto !important;
    right:auto !important;
    bottom:auto !important;
    width:100% !important;
    height:300px !important;
    max-width:100% !important;
    display:block !important;
    border-radius:20px !important;
    overflow:hidden !important;
    background:#ebe5d8 !important;
    box-shadow:0 12px 34px rgba(67,54,24,.10) !important;
  }
  main.project-slug-women-majlis .board-frame.card .board-image .crop-media,
  main.project-slug-women-majlis .board-frame.card .board-image .board-thumb{
    width:100% !important;
    height:100% !important;
    min-height:0 !important;
  }
  main.project-slug-women-majlis .board-frame.card .board-image img{
    object-position:center center !important;
  }
}

@media (min-width: 901px) and (max-width: 1180px){
  .page-index .desktop-home,
  .page-index-php .desktop-home{
    grid-template-columns:1fr !important;
    padding:42px !important;
  }
  .page-index .desktop-home::before,
  .page-index-php .desktop-home::before{
    position:relative !important;
    inset:auto !important;
    width:100% !important;
    height:360px !important;
    order:2 !important;
  }
  .page-index .desktop-home-grid,
  .page-index-php .desktop-home-grid{
    grid-column:1 !important;
    width:min(100%, 420px) !important;
    max-width:420px !important;
    justify-self:center !important;
  }
}

/* 5. Copyright line: centered and in the brand olive color. */
.alore-copyright-line{
  text-align:center !important;
  color:#837B51 !important;
}

@media (min-width: 901px) {
  .page-about .about-photo-1 {
    object-fit: cover;
    object-position: center 10% !important;
  }

  .page-about .about-photo-2 {
    object-fit: cover;
    object-position: center 90% !important;
  }
}
/* Arabic brand fonts */
html[lang="ar"] body,
html[lang="ar"] button,
html[lang="ar"] input,
html[lang="ar"] textarea,
html[lang="ar"] select,
html[lang="ar"] p,
html[lang="ar"] li,
html[lang="ar"] a {
  font-family: "IBM Plex Sans Arabic", Arial, sans-serif !important;
}

html[lang="ar"] h1,
html[lang="ar"] h2,
html[lang="ar"] h3,
html[lang="ar"] .page-heading h1,
html[lang="ar"] .home-title,
html[lang="ar"] .desktop-home-copy h1,
html[lang="ar"] .desktop-home-box,
html[lang="ar"] .service-nav-title,
html[lang="ar"] .service-head strong,
html[lang="ar"] .about-copy h2,
html[lang="ar"] .projects-phone-title,
html[lang="ar"] .project-card span,
html[lang="ar"] .desktop-project-card span,
html[lang="ar"] .contact-info h2,
html[lang="ar"] .footer-grid h3,
html[lang="ar"] .project-pill,
html[lang="ar"] .mobile-section-title {
  font-family: "Noto Kufi Arabic", "IBM Plex Sans Arabic", Arial, sans-serif !important;
}

/* Final correct Arabic desktop Home layout */
@media (min-width: 901px) {
  html[lang="ar"] .desktop-home {
    direction: ltr !important;
    grid-template-columns: 1fr 1fr !important;
  }

  html[lang="ar"] .desktop-home-copy {
    order: 1 !important;
    direction: rtl !important;
    text-align: right !important;
  }

  html[lang="ar"] .desktop-home-grid {
    order: 2 !important;
    direction: rtl !important;
  }
}
/* Center Arabic desktop Home small boxes */
@media (min-width: 901px) {
  html[lang="ar"] .desktop-home-grid {
    width: 100% !important;
    max-width: 520px !important;
    justify-self: center !important;
    align-self: center !important;
    margin: 0 auto !important;
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 18px !important;
  }

  html[lang="ar"] .desktop-home-box {
    width: 100% !important;
    min-height: 170px !important;
    display: grid !important;
    place-items: center !important;
    text-align: center !important;
  }
}
/* Reduce Arabic desktop Home boxes by 20% */
@media (min-width: 901px) {
  html[lang="ar"] .desktop-home-grid {
    max-width: 416px !important; /* 520px reduced by 20% */
    gap: 14px !important;
  }

  html[lang="ar"] .desktop-home-box {
    min-height: 136px !important; /* 170px reduced by 20% */
    font-size: 26px !important;
    padding: 12px !important;
  }
}

/* Reduce Arabic desktop Home title size */
@media (min-width: 901px) {
  html[lang="ar"] .desktop-home-copy h1 {
    font-size: 28px !important;
    line-height: 1.4 !important;
  }
}

/* About page inner title adjustment */
.about-kicker-large {
  font-family: "Noto Kufi Arabic", "IBM Plex Sans Arabic", Arial, sans-serif !important;
  font-size: 28px !important;
  line-height: 1.35 !important;
  font-weight: 600 !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  color: var(--olive-deep) !important;
  margin-bottom: 20px !important;
}

/* English About kicker title font */
html[lang="en"] .about-kicker-large {
  font-family: Arial, Helvetica, sans-serif !important;
  font-size: 28px !important;
  font-weight: 600 !important;
}