.shops-page{background:#100e12}
.shops-page .site-header{background:rgba(16,14,18,.94);backdrop-filter:blur(16px)}
.shops-hero{min-height:560px;padding:170px 8vw 90px;display:flex;align-items:center;background:linear-gradient(90deg,rgba(12,7,18,.94),rgba(28,9,53,.6),rgba(8,5,12,.42)),url('assets/images/sivakasi-night-sky-v2.png') center/cover no-repeat}
.shops-hero-copy{max-width:950px}
.shops-hero h1{font-size:clamp(65px,8.5vw,135px)}
.shops-hero h1 em,.shop-directory h2 em{color:#d56a2d;font-style:italic}
.shops-hero-copy>p:last-child{max-width:590px;margin:30px 0 0;color:rgba(255,255,255,.72);font-size:17px;line-height:1.7}
.shop-directory{background:var(--cream);color:var(--ink);min-height:500px}
.directory-heading{display:flex;align-items:end;justify-content:space-between;gap:35px;margin-bottom:48px}
.directory-heading .section-kicker{width:38%;margin:0;color:#6d686e;border-color:rgba(16,14,18,.16)}
.shop-directory h2{font-size:clamp(58px,7vw,105px);white-space:nowrap}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.shop-search{position:relative;max-width:680px;margin:0 auto 42px}
.shop-search svg{position:absolute;left:19px;top:50%;width:20px;height:20px;transform:translateY(-50%);fill:none;stroke:#756d79;stroke-width:1.8;stroke-linecap:round}
.shop-search input{width:100%;height:58px;padding:0 54px;border:1px solid rgba(50,16,109,.14);border-radius:14px;background:#fff;font:500 15px Arial,sans-serif;color:var(--ink);outline:none;box-shadow:0 10px 30px rgba(38,24,19,.055);transition:.2s}
.shop-search input:focus{border-color:rgba(50,16,109,.48);box-shadow:0 0 0 4px rgba(50,16,109,.07),0 12px 30px rgba(38,24,19,.07)}
.shop-search button{position:absolute;right:14px;top:50%;width:32px;height:32px;transform:translateY(-50%);border:0;border-radius:50%;background:rgba(50,16,109,.07);color:var(--purple);font-size:21px;line-height:1;cursor:pointer}
.city-list{display:grid;gap:24px}
.city-group{border:1px solid rgba(50,16,109,.12);border-radius:22px;background:rgba(255,255,255,.65);box-shadow:0 22px 60px rgba(40,26,20,.08);overflow:hidden}
.city-group>summary{list-style:none;display:grid;grid-template-columns:1fr auto 34px;align-items:center;gap:20px;padding:29px 32px;background:linear-gradient(110deg,var(--purple),#4d188e);color:white;cursor:pointer;font:600 clamp(23px,2.5vw,31px) Arial,sans-serif;letter-spacing:-.025em}
.city-group>summary::-webkit-details-marker{display:none}
.city-group>summary small{font:600 10px Arial,sans-serif;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.75)}
.city-group>summary i,.area-group summary i{width:10px;height:10px;border-right:1.5px solid;border-bottom:1.5px solid;transform:rotate(45deg);transition:.25s}
.city-group[open]>summary i,.area-group[open] summary i{transform:rotate(225deg)}
.city-group>.area-list{padding:18px;display:grid;gap:12px}
.area-list{display:grid;gap:20px}
.area-group{border:1px solid rgba(50,16,109,.09);border-radius:20px;background:rgba(255,255,255,.82);box-shadow:0 18px 55px rgba(40,26,20,.075);overflow:hidden}
.area-group summary{position:relative;list-style:none;display:grid;grid-template-columns:1fr auto 34px;align-items:center;gap:20px;padding:27px 30px;cursor:pointer;font:600 clamp(20px,2.2vw,27px) Arial,Helvetica,sans-serif;letter-spacing:-.025em;transition:.25s}
.area-group summary:before{content:"";position:absolute;left:0;top:23%;bottom:23%;width:3px;border-radius:0 4px 4px 0;background:linear-gradient(var(--orange),var(--purple));opacity:0;transition:.25s}
.area-group summary::-webkit-details-marker{display:none}
.area-group summary:hover,.area-group[open] summary{background:linear-gradient(90deg,rgba(50,16,109,.045),transparent 65%)}
.area-group[open] summary:before{opacity:1}
.area-group summary small{padding:7px 11px;border-radius:999px;background:rgba(50,16,109,.07);font:600 10px Arial,sans-serif;letter-spacing:.08em;color:#675c71;text-transform:uppercase}
.area-group summary i{width:10px;height:10px;border-right:1.5px solid;border-bottom:1.5px solid;transform:rotate(45deg);transition:.25s}
.shop-grid{padding:4px 28px 28px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.shop-card{position:relative;min-height:0;padding:18px 20px;display:flex;flex-direction:column;align-items:flex-start;justify-content:center;border:1px solid rgba(30,22,34,.07);border-radius:13px;background:#fff;box-shadow:0 7px 20px rgba(38,24,19,.045);overflow:hidden;transition:transform .25s,box-shadow .25s,border-color .25s}
.shop-card:before{content:"";position:absolute;top:0;left:0;width:100%;height:2px;background:linear-gradient(90deg,var(--purple),var(--orange),#e2b943);opacity:.7}
.shop-card:hover{transform:translateY(-2px);border-color:rgba(50,16,109,.15);box-shadow:0 12px 28px rgba(38,24,19,.085)}
.shop-card h3{position:relative;z-index:1;padding:0;font:600 clamp(18px,1.7vw,22px)/1.25 Arial,Helvetica,sans-serif;letter-spacing:-.02em;text-transform:none;color:#18141b}
.shop-phone{position:relative;z-index:1;display:inline-flex;align-items:center;gap:8px;margin-top:10px;padding:0;border:0;background:transparent;font-size:12px;font-weight:600;color:var(--purple);transition:.22s}
.shop-phone:hover{color:var(--orange)}
.shop-phone svg{width:15px;height:15px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.shop-empty{padding:55px 25px;border:1px dashed #a69d98;text-align:center;color:#655e61}
@media(max-width:900px){.shops-hero{min-height:500px;padding:145px 25px 70px}.directory-heading{display:block}.directory-heading .section-kicker{width:100%;margin-bottom:32px}.shop-grid{grid-template-columns:1fr}}
@media(max-width:520px){.shops-hero{min-height:470px;padding:125px 20px 60px}.shops-hero h1{font-size:clamp(46px,14vw,58px);overflow-wrap:anywhere}.shops-hero-copy>p:last-child{font-size:15px}.shop-directory h2{font-size:47px;white-space:normal}.shop-search{margin-bottom:28px}.shop-search input{height:54px}.city-group{border-radius:16px}.city-group>summary{grid-template-columns:1fr auto 18px;gap:9px;padding:22px 18px;font-size:21px}.city-group>summary small{font-size:8px}.city-group>.area-list{padding:10px}.area-group{border-radius:13px}.area-group summary{grid-template-columns:1fr auto 18px;gap:9px;padding:18px 16px;font-size:18px}.area-group summary small{font-size:8px;padding:6px 8px}.shop-grid{padding:2px 10px 10px;gap:8px}.shop-card{padding:15px 17px;border-radius:10px}.shop-card h3{font-size:18px}.shop-phone{max-width:100%;margin-top:8px;overflow-wrap:anywhere}}
