*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
:root{
  --or:#D4751E;
  --or2:#E8893A;
  --or3:#F5E6D3;
  --ink:#111111;
  --ink2:#2A2A2A;
  --ink3:#4A4A4A;
  --dust:#888888;
  --rule:#E0DAD4;
  --rule2:#EDE8E3;
  --cream:#F7F4F0;
  --sand:#EEE9E3;
  --white:#FFFFFF;
}
body{font-family:'DM Sans',sans-serif;background:var(--white);color:var(--ink);overflow-x:hidden;}
::-webkit-scrollbar{width:3px;}
::-webkit-scrollbar-track{background:var(--cream);}
::-webkit-scrollbar-thumb{background:var(--or);border-radius:2px;}

/* ══ TOP BAR ══ */
.topbar{
  background:var(--ink);color:rgba(255,255,255,.5);
  padding:.4rem 5vw;display:flex;justify-content:space-between;align-items:center;
  font-family:'DM Mono',monospace;font-size:.68rem;letter-spacing:.06em;
}
.topbar a{color:var(--or);text-decoration:none;}
.topbar-r{display:flex;gap:2rem;}

/* ══ NAV ══ */
nav{
  position:sticky;top:0;z-index:200;
  background:rgba(255,255,255,.97);backdrop-filter:blur(16px);
  border-bottom:1px solid var(--rule);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 5vw;height:70px;transition:box-shadow .3s;
}
nav.scrolled{box-shadow:0 2px 24px rgba(0,0,0,.06);}

.nav-brand{display:flex;align-items:center;gap:.8rem;text-decoration:none;flex-shrink:0;}
.nav-logo-img{height:36px;width:auto;max-width:120px;object-fit:contain;display:none;}
.nav-logo-text{font-family:'Bebas Neue',sans-serif;font-size:1.8rem;letter-spacing:.1em;color:var(--ink);line-height:1;}
.nav-logo-text span{color:var(--or);}
.nav-logo-sub{font-family:'DM Mono',monospace;font-size:.58rem;color:var(--dust);letter-spacing:.14em;text-transform:uppercase;margin-top:1px;}
.logo-ph{
  height:34px;display:none;align-items:center;justify-content:center;
  padding:0 .8rem;border:1.5px dashed var(--rule);border-radius:2px;
  font-size:.68rem;color:var(--dust);cursor:pointer;white-space:nowrap;
  transition:border-color .2s,color .2s;font-family:'DM Mono',monospace;letter-spacing:.06em;
}
.logo-ph:hover{border-color:var(--or);color:var(--or);}
body.edit-mode .logo-ph{display:flex;}

.nav-links{display:flex;list-style:none;}
.nav-links li a{
  display:flex;align-items:center;height:70px;padding:0 1rem;
  font-size:.8rem;font-weight:500;letter-spacing:.05em;color:var(--ink3);
  text-decoration:none;border-bottom:2px solid transparent;margin-bottom:-1px;
  transition:color .2s,border-color .2s;white-space:nowrap;
}
.nav-links li a:hover{color:var(--ink);border-color:var(--or);}

.nav-right{display:flex;align-items:center;gap:.7rem;}
.btn-nav-quote{
  background:var(--or);color:#fff;padding:.48rem 1.2rem;
  font-size:.78rem;font-weight:600;letter-spacing:.05em;
  text-decoration:none;border-radius:2px;transition:background .2s;white-space:nowrap;
}
.btn-nav-quote:hover{background:var(--or2);}
.nav-edit-btn{
  background:none;border:1px solid var(--rule);color:var(--dust);
  padding:.42rem .85rem;border-radius:2px;font-family:'DM Sans',sans-serif;
  font-size:.72rem;font-weight:500;cursor:pointer;letter-spacing:.04em;transition:all .2s;
}
.nav-edit-btn:hover{border-color:var(--or);color:var(--or);}
.hamburger{display:none;flex-direction:column;gap:4px;cursor:pointer;padding:.3rem;}
.hamburger span{width:22px;height:2px;background:var(--ink);display:block;transition:.3s;}

/* ══ HERO ══ */
#hero{
  min-height:94vh;display:grid;grid-template-columns:1fr 1fr;
  position:relative;overflow:hidden;
}
.hero-left{
  display:flex;flex-direction:column;justify-content:center;
  padding:8rem 5vw 6rem 6vw;position:relative;z-index:2;
}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:.6rem;
  font-family:'DM Mono',monospace;font-size:.68rem;
  color:var(--or);letter-spacing:.16em;text-transform:uppercase;
  margin-bottom:1.6rem;
}
.hero-eyebrow::before{content:'';width:24px;height:1px;background:var(--or);}
.hero-title{
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(5rem,9vw,8.5rem);
  line-height:.88;letter-spacing:.02em;
  color:var(--ink);margin-bottom:1.6rem;
}
.hero-title .accent{color:var(--or);}
.hero-title .outline{
  -webkit-text-stroke:1.5px var(--ink);color:transparent;
}
.hero-sub{
  font-size:1rem;line-height:1.75;color:var(--ink3);
  max-width:420px;font-weight:300;margin-bottom:2.4rem;
}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:3.5rem;}
.btn-primary{
  background:var(--ink);color:#fff;
  padding:.85rem 2rem;border-radius:2px;
  font-weight:600;font-size:.88rem;letter-spacing:.05em;
  text-decoration:none;transition:background .2s,transform .15s;display:inline-block;
}
.btn-primary:hover{background:var(--or);transform:translateY(-2px);}
.btn-ghost{
  border:1.5px solid var(--rule);color:var(--ink3);
  padding:.85rem 2rem;border-radius:2px;
  font-weight:500;font-size:.88rem;letter-spacing:.04em;
  text-decoration:none;transition:all .2s;display:inline-block;
}
.btn-ghost:hover{border-color:var(--or);color:var(--or);}

.hero-stats{display:flex;gap:0;border-top:1px solid var(--rule);}
.hstat{padding:1.2rem 2rem 1.2rem 0;border-right:1px solid var(--rule);margin-right:2rem;}
.hstat:last-child{border:none;margin:0;}
.hstat-n{font-family:'Bebas Neue',sans-serif;font-size:2.4rem;color:var(--or);line-height:1;}
.hstat-l{font-size:.72rem;color:var(--dust);letter-spacing:.08em;text-transform:uppercase;font-family:'DM Mono',monospace;margin-top:.2rem;}

/* Hero right — image */
.hero-right{
  position:relative;background:var(--cream);
  border-left:1px solid var(--rule);overflow:hidden;
}
.hero-img-wrap{position:absolute;inset:0;}
.hero-img-wrap img{width:100%;height:100%;object-fit:cover;opacity:.9;display:none;}
.hero-ph{
  position:absolute;inset:0;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:.8rem;
  cursor:pointer;transition:background .2s;border:2px dashed var(--rule2);
}
body.edit-mode .hero-ph:hover{background:rgba(212,117,30,.04);border-color:var(--or);}
.hero-ph .phi{font-size:3rem;opacity:.15;}
.hero-ph p{font-size:.78rem;color:var(--dust);text-align:center;padding:0 2rem;}

/* Decorative corner */
.hero-corner{
  position:absolute;bottom:2.5rem;right:2.5rem;
  width:80px;height:80px;
  border-bottom:2px solid var(--or);border-right:2px solid var(--or);
  pointer-events:none;
}
.hero-tag{
  position:absolute;top:2rem;left:2rem;
  font-family:'DM Mono',monospace;font-size:.62rem;
  color:var(--dust);letter-spacing:.1em;text-transform:uppercase;
  background:rgba(255,255,255,.9);padding:.3rem .6rem;border:1px solid var(--rule);
}

/* Scroll hint */
.scroll-hint{
  position:absolute;bottom:2.5rem;left:6vw;
  font-family:'DM Mono',monospace;font-size:.62rem;
  color:var(--dust);letter-spacing:.1em;
  display:flex;align-items:center;gap:.5rem;
  animation:bounce 2s ease-in-out infinite;
}
.scroll-hint::after{content:'↓';color:var(--or);}
@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(5px)}}

/* ══ TICKER ══ */
.ticker{
  background:var(--or);overflow:hidden;
  padding:.65rem 0;border-top:none;border-bottom:none;
}
.ticker-track{display:flex;animation:tick 28s linear infinite;width:max-content;}
.ticker-track span{
  font-family:'Bebas Neue',sans-serif;font-size:.95rem;
  letter-spacing:.2em;color:#fff;padding:0 2.2rem;white-space:nowrap;
}
.ticker-track .sep{color:rgba(255,255,255,.35);padding:0 .5rem;}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ══ SHARED ══ */
section{padding:7rem 6vw;}
.sec-tag{
  font-family:'DM Mono',monospace;font-size:.65rem;
  color:var(--or);letter-spacing:.16em;text-transform:uppercase;
  display:flex;align-items:center;gap:.6rem;margin-bottom:.7rem;
}
.sec-tag::before{content:'';width:18px;height:1px;background:var(--or);}
.sec-title{
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(2.6rem,5vw,4rem);
  color:var(--ink);line-height:.92;letter-spacing:.02em;
  margin-bottom:1rem;
}
.sec-sub{font-size:.98rem;line-height:1.8;color:var(--ink3);max-width:520px;font-weight:300;}

/* ══ ABOUT ══ */
#about{
  background:var(--cream);
  display:grid;grid-template-columns:1fr 1fr;gap:6vw;align-items:center;
}
.about-img-wrap{position:relative;}
.about-img-box{
  aspect-ratio:4/3;background:var(--sand);
  border:1.5px dashed var(--rule);overflow:hidden;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:.8rem;transition:border-color .2s;
}
.about-img-box img{width:100%;height:100%;object-fit:cover;display:none;}
.about-img-box .ph-i{font-size:2.5rem;opacity:.2;}
.about-img-box .ph-t{font-size:.75rem;color:var(--dust);text-align:center;padding:0 1.5rem;}
body.edit-mode .about-img-box{cursor:pointer;}
body.edit-mode .about-img-box:hover{border-color:var(--or);background:rgba(212,117,30,.03);}
/* Corner brackets */
.about-img-wrap::before,.about-img-wrap::after{
  content:'';position:absolute;width:32px;height:32px;z-index:2;
}
.about-img-wrap::before{top:-6px;left:-6px;border-top:2px solid var(--or);border-left:2px solid var(--or);}
.about-img-wrap::after{bottom:-6px;right:-6px;border-bottom:2px solid var(--or);border-right:2px solid var(--or);}

.about-body{font-size:.96rem;line-height:1.85;color:var(--ink3);font-weight:300;margin:1.4rem 0;}
.about-body p{margin-bottom:1rem;}
.about-body p:last-child{margin:0;}
.pull-quote{
  border-left:3px solid var(--or);padding:.7rem 1.1rem;
  background:rgba(212,117,30,.05);
  font-size:.95rem;font-style:italic;color:var(--ink2);font-weight:400;
  margin:1.4rem 0;
}
.chips{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:1.4rem;}
.chip{
  font-family:'DM Mono',monospace;font-size:.72rem;
  padding:.3rem .75rem;border:1px solid var(--rule);
  color:var(--dust);border-radius:2px;letter-spacing:.04em;
  transition:all .2s;cursor:default;
}
.chip:hover{border-color:var(--or);color:var(--or);}

/* ══ SERVICES ══ */
#services{background:var(--white);}
.svc-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:3.5rem;flex-wrap:wrap;gap:1.5rem;}
.svc-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  border:1px solid var(--rule);
}
.svc-card{
  padding:2rem 1.8rem;border-right:1px solid var(--rule);border-bottom:1px solid var(--rule);
  position:relative;transition:background .25s;
}
.svc-card:hover{background:var(--cream);}
.svc-card::after{
  content:'';position:absolute;left:0;bottom:0;width:0;height:2px;
  background:var(--or);transition:width .3s;
}
.svc-card:hover::after{width:100%;}
.svc-n{font-family:'DM Mono',monospace;font-size:.6rem;color:var(--rule);letter-spacing:.1em;margin-bottom:.9rem;}
.svc-icon{font-size:1.5rem;margin-bottom:.7rem;display:block;}
.svc-name{font-family:'Bebas Neue',sans-serif;font-size:1.15rem;letter-spacing:.06em;color:var(--ink);margin-bottom:.45rem;}
.svc-desc{font-size:.82rem;color:var(--dust);line-height:1.7;font-weight:300;}

/* ══ PORTFOLIO ══ */
#portfolio{background:var(--cream);padding:7rem 6vw;}
.port-hdr{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:2.8rem;flex-wrap:wrap;gap:1rem;}
.port-note{font-size:.78rem;color:var(--dust);font-style:italic;}

.port-grid{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  grid-template-rows:300px 240px;
  gap:6px;
}
.p-card{position:relative;overflow:hidden;background:var(--sand);border:1px solid var(--rule);}
.p-card:nth-child(1){grid-column:1/8;}
.p-card:nth-child(2){grid-column:8/13;}
.p-card:nth-child(3){grid-column:1/5;grid-row:2;}
.p-card:nth-child(4){grid-column:5/9;grid-row:2;}
.p-card:nth-child(5){grid-column:9/13;grid-row:2;}

.p-card img{width:100%;height:100%;object-fit:cover;transition:transform .5s;opacity:.85;display:none;}
.p-card:hover img{transform:scale(1.04);}
.p-card-ph{
  position:absolute;inset:0;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:.6rem;
  border:1.5px dashed var(--rule2);transition:border-color .2s;
}
body.edit-mode .p-card:hover .p-card-ph{border-color:var(--or);}
.p-card-ph .phi{font-size:1.8rem;opacity:.2;}
.p-card-ph p{font-size:.7rem;color:var(--dust);text-align:center;}
.p-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(17,17,17,.88) 0%,transparent 55%);
  opacity:0;transition:opacity .3s;
  display:flex;align-items:flex-end;padding:1.2rem;
}
.p-card:hover .p-overlay{opacity:1;}
.p-info{transform:translateY(6px);transition:transform .3s;}
.p-card:hover .p-info{transform:translateY(0);}
.p-title{font-family:'Bebas Neue',sans-serif;font-size:1rem;letter-spacing:.06em;color:#fff;}
.p-tag{font-family:'DM Mono',monospace;font-size:.6rem;color:var(--or);margin-top:.2rem;}

/* ══ PROCESS ══ */
#process{background:var(--white);}
.proc-grid{display:grid;grid-template-columns:repeat(4,1fr);border:1px solid var(--rule);margin-top:4rem;}
.proc-step{
  padding:2.4rem 2rem;border-right:1px solid var(--rule);
  position:relative;transition:background .25s;
}
.proc-step:last-child{border:none;}
.proc-step:hover{background:var(--cream);}
.proc-num{
  font-family:'Bebas Neue',sans-serif;font-size:4.5rem;
  color:var(--rule2);line-height:1;margin-bottom:.6rem;
  transition:color .3s;
}
.proc-step:hover .proc-num{color:var(--or3);}
.proc-icon{font-size:1.4rem;margin-bottom:.7rem;display:block;}
.proc-title{font-family:'Bebas Neue',sans-serif;font-size:1.1rem;letter-spacing:.06em;color:var(--ink);margin-bottom:.5rem;}
.proc-body{font-size:.82rem;color:var(--dust);line-height:1.7;font-weight:300;}
.proc-step::after{
  content:'→';position:absolute;right:-10px;top:2.4rem;
  font-size:1.1rem;color:var(--rule);z-index:2;
}
.proc-step:last-child::after{display:none;}

/* ══ TOOLS ══ */
#tools{
  background:var(--ink);padding:2.8rem 6vw;
  display:flex;flex-wrap:wrap;align-items:center;gap:2.5rem;
}
.tools-lbl{font-family:'DM Mono',monospace;font-size:.62rem;color:rgba(255,255,255,.3);letter-spacing:.14em;text-transform:uppercase;white-space:nowrap;}
.tools-list{display:flex;flex-wrap:wrap;gap:.7rem;}
.tool-tag{
  font-family:'DM Mono',monospace;font-size:.72rem;letter-spacing:.08em;
  padding:.35rem .9rem;border:1px solid rgba(255,255,255,.12);
  color:rgba(255,255,255,.45);border-radius:2px;transition:all .2s;
}
.tool-tag:hover{border-color:var(--or);color:var(--or);}

/* ══ REGIONS ══ */
#regions{
  background:var(--sand);padding:2.5rem 6vw;
  border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);
}
.regions-inner{display:flex;align-items:center;gap:2.5rem;flex-wrap:wrap;}
.regions-lbl{font-family:'DM Mono',monospace;font-size:.62rem;color:var(--dust);letter-spacing:.12em;text-transform:uppercase;white-space:nowrap;}
.regions-list{display:flex;flex-wrap:wrap;gap:.6rem;}
.region{
  display:flex;align-items:center;gap:.5rem;
  padding:.45rem .9rem;border:1px solid var(--rule);border-radius:2px;
  font-size:.8rem;color:var(--ink3);background:var(--white);transition:border-color .2s;
}
.region:hover{border-color:var(--or);}
.r-num{font-family:'DM Mono',monospace;font-size:.65rem;color:var(--or);}

/* ══ CONTACT ══ */
#contact{
  background:var(--white);
  display:grid;grid-template-columns:1fr 1fr;gap:6vw;align-items:start;
}
.c-details{margin-top:2.2rem;display:flex;flex-direction:column;}
.c-item{
  display:flex;gap:.9rem;align-items:flex-start;
  padding:1.1rem 0;border-bottom:1px solid var(--rule2);
}
.c-item:last-child{border:none;}
.c-ico{
  width:36px;height:36px;background:var(--cream);
  border:1px solid var(--rule);border-radius:2px;
  display:flex;align-items:center;justify-content:center;
  font-size:.95rem;flex-shrink:0;
}
.c-lbl{font-family:'DM Mono',monospace;font-size:.58rem;color:var(--or);letter-spacing:.12em;text-transform:uppercase;margin-bottom:.25rem;}
.c-val{font-size:.88rem;color:var(--ink2);}

.contact-form{padding-top:1rem;}
.fg{margin-bottom:.9rem;}
.fg label{display:block;font-family:'DM Mono',monospace;font-size:.6rem;color:var(--dust);letter-spacing:.1em;text-transform:uppercase;margin-bottom:.45rem;}
.fg input,.fg textarea,.fg select{
  width:100%;background:var(--cream);border:1px solid var(--rule);
  color:var(--ink);font-family:'DM Sans',sans-serif;font-size:.9rem;
  padding:.7rem 1rem;border-radius:2px;outline:none;transition:border-color .2s;appearance:none;
}
.fg input:focus,.fg textarea:focus,.fg select:focus{border-color:var(--or);background:var(--white);}
.fg textarea{resize:vertical;min-height:110px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.9rem;}
.btn-send{
  width:100%;padding:.85rem;background:var(--or);color:#fff;
  border:none;border-radius:2px;font-family:'DM Sans',sans-serif;
  font-weight:600;font-size:.9rem;letter-spacing:.05em;cursor:pointer;transition:background .2s;
}
.btn-send:hover{background:var(--or2);}
.form-note{font-size:.72rem;color:var(--dust);margin-top:.6rem;text-align:center;}

/* ══ FOOTER ══ */
footer{
  background:var(--ink);border-top:3px solid var(--or);
  padding:2rem 6vw;
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;
}
.foot-brand{font-family:'Bebas Neue',sans-serif;font-size:1.4rem;letter-spacing:.1em;color:rgba(255,255,255,.4);}
.foot-brand span{color:var(--or);}
.foot-copy{font-size:.72rem;color:rgba(255,255,255,.3);}
.foot-tag{font-family:'DM Mono',monospace;font-size:.6rem;color:rgba(255,255,255,.2);letter-spacing:.12em;}

/* ══ EDIT BAR ══ */
.edit-bar{
  display:none;position:fixed;bottom:0;left:0;right:0;z-index:999;
  background:var(--or);color:#fff;padding:.55rem 2rem;
  font-size:.78rem;font-weight:600;letter-spacing:.04em;
  align-items:center;justify-content:space-between;gap:1rem;
}
.edit-bar.active{display:flex;}
.edit-dot{width:7px;height:7px;border-radius:50%;background:#fff;animation:pulse 1.4s ease-in-out infinite;}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.6)}}
.edit-bar-l{display:flex;align-items:center;gap:.6rem;}
.lock-btn{background:rgba(0,0,0,.18);border:1px solid rgba(255,255,255,.3);color:#fff;padding:.28rem .85rem;border-radius:2px;font-size:.72rem;font-weight:600;cursor:pointer;font-family:'DM Sans',sans-serif;}
.lock-btn:hover{background:rgba(0,0,0,.3);}

/* ══ PW MODAL ══ */
.pw-ov{display:none;position:fixed;inset:0;z-index:400;background:rgba(0,0,0,.7);backdrop-filter:blur(10px);align-items:center;justify-content:center;}
.pw-ov.open{display:flex;}
.pw-box{background:var(--white);border-top:3px solid var(--or);padding:2.4rem;max-width:340px;width:90%;text-align:center;}
.pw-ico{font-size:2rem;margin-bottom:.7rem;display:block;}
.pw-box h3{font-family:'Bebas Neue',sans-serif;font-size:2rem;letter-spacing:.06em;color:var(--ink);margin-bottom:.3rem;}
.pw-box p{font-size:.82rem;color:var(--dust);margin-bottom:1.3rem;}
.pw-inp{
  width:100%;padding:.7rem 1rem;margin-bottom:.65rem;
  background:var(--cream);border:1px solid var(--rule);
  color:var(--ink);font-size:1rem;text-align:center;letter-spacing:.2em;
  border-radius:2px;outline:none;font-family:'DM Sans',sans-serif;transition:border-color .2s;
}
.pw-inp:focus{border-color:var(--or);}
.pw-inp.shake{animation:shk .35s;border-color:#e53935;}
@keyframes shk{0%,100%{transform:translateX(0)}25%{transform:translateX(-6px)}75%{transform:translateX(6px)}}
.pw-err{font-size:.76rem;color:#e53935;margin-bottom:.65rem;display:none;}
.pw-sub{width:100%;padding:.72rem;background:var(--or);color:#fff;border:none;border-radius:2px;font-family:'DM Sans',sans-serif;font-size:.88rem;font-weight:600;letter-spacing:.05em;cursor:pointer;transition:background .2s;}
.pw-sub:hover{background:var(--or2);}
.pw-cancel{display:block;margin-top:.65rem;font-size:.76rem;color:var(--dust);cursor:pointer;text-decoration:underline;}

/* ══ UPLOAD MODAL ══ */
.m-ov{display:none;position:fixed;inset:0;z-index:300;background:rgba(0,0,0,.65);backdrop-filter:blur(8px);align-items:center;justify-content:center;}
.m-ov.open{display:flex;}
.m-box{background:var(--white);border-top:3px solid var(--or);padding:2.2rem;max-width:440px;width:90%;position:relative;}
.m-box h3{font-family:'Bebas Neue',sans-serif;font-size:1.8rem;letter-spacing:.06em;color:var(--ink);margin-bottom:.3rem;}
.m-desc{font-size:.8rem;color:var(--dust);margin-bottom:1.1rem;}
.m-box input[type=file]{display:none;}
.m-drop{
  border:2px dashed var(--rule);border-radius:2px;padding:1.8rem;
  text-align:center;cursor:pointer;transition:border-color .2s,background .2s;margin-bottom:.9rem;
}
.m-drop:hover{border-color:var(--or);background:rgba(212,117,30,.03);}
.m-drop .di{font-size:2rem;opacity:.18;margin-bottom:.4rem;}
.m-drop p{font-size:.78rem;color:var(--dust);}
.m-close{position:absolute;top:.9rem;right:1.1rem;font-size:1.3rem;cursor:pointer;color:var(--dust);background:none;border:none;}
.title-fields{display:none;}
.title-fields label{display:block;font-family:'DM Mono',monospace;font-size:.6rem;color:var(--dust);letter-spacing:.1em;text-transform:uppercase;margin-bottom:.4rem;}
.title-fields input{width:100%;padding:.6rem .8rem;background:var(--cream);border:1px solid var(--rule);color:var(--ink);border-radius:2px;font-family:'DM Sans',sans-serif;font-size:.86rem;outline:none;margin-bottom:.7rem;transition:border-color .2s;}
.title-fields input:focus{border-color:var(--or);}
.m-actions{display:flex;gap:.7rem;justify-content:flex-end;}
.m-actions button{padding:.55rem 1.3rem;border-radius:2px;font-family:'DM Sans',sans-serif;font-size:.84rem;font-weight:500;cursor:pointer;}
.btn-cancm{background:var(--cream);border:1px solid var(--rule);color:var(--dust);}
.btn-applm{background:var(--or);border:none;color:#fff;}
.btn-applm:hover{background:var(--or2);}

/* ══ EDIT TRIGGERS ══ */
.edit-trigger{pointer-events:none;cursor:default!important;}
body.edit-mode .edit-trigger{pointer-events:auto;cursor:pointer!important;}
body:not(.edit-mode) .hero-ph{pointer-events:none;}

/* ══ REVEAL ══ */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .55s ease,transform .55s ease;}
.reveal.visible{opacity:1;transform:translateY(0);}

/* ══ RESPONSIVE ══ */
@media(max-width:960px){
  #hero{grid-template-columns:1fr;}
  .hero-right{display:none;}
  #about{grid-template-columns:1fr;}
  .svc-grid{grid-template-columns:1fr 1fr;}
  .port-grid{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto;}
  .p-card{grid-column:auto!important;grid-row:auto!important;aspect-ratio:4/3;}
  .proc-grid{grid-template-columns:1fr 1fr;}
  .proc-step::after{display:none;}
  #contact{grid-template-columns:1fr;}
  .form-row{grid-template-columns:1fr;}
  .nav-links{display:none;}
  .hamburger{display:flex;}
}
@media(max-width:580px){
  .svc-grid{grid-template-columns:1fr;}
  .port-grid{grid-template-columns:1fr;}
  .proc-grid{grid-template-columns:1fr;}
  section{padding:5rem 5vw;}
  .hero-title{font-size:4rem;}
  .topbar-r{display:none;}
}