
:root{--bg:#fff7ed;--paper:#fff;--ink:#171717;--muted:#68635f;--gold:#d89b2b;--teal:#0f766e;--night:#111827;--line:rgba(23,23,23,.12);--shadow:0 24px 70px rgba(65,45,20,.12);--max:1180px;--r:30px}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Arial,Helvetica,sans-serif;color:var(--ink);background:radial-gradient(circle at 12% 0,rgba(216,155,43,.18),transparent 30%),linear-gradient(180deg,#f7fffb 0,#fff7ed 58%,#fff 100%);line-height:1.72}a{text-decoration:none;color:inherit}.container{width:min(var(--max),calc(100% - 40px));margin:auto}
.header{position:sticky;top:0;z-index:20;background:rgba(255,247,237,.9);backdrop-filter:blur(16px);border-bottom:1px solid var(--line)}.nav{min-height:78px;display:flex;align-items:center;justify-content:space-between;gap:24px}.logo{display:flex;align-items:center;gap:12px;font-weight:900;letter-spacing:-.04em;font-size:1.16rem}.logo-mark{width:44px;height:44px;border-radius:16px;background:linear-gradient(135deg,var(--teal),var(--night));color:#fff;display:grid;place-items:center;font-weight:900}.menu{display:flex;gap:18px;color:var(--muted);font-weight:800;font-size:.94rem}.menu a:hover,.menu .active{color:var(--teal)}
.btn{display:inline-flex;align-items:center;justify-content:center;min-height:48px;padding:0 20px;border-radius:999px;background:linear-gradient(135deg,var(--teal),var(--night));color:#fff;font-weight:900}.btn.secondary{background:#fff;color:var(--teal);border:1px solid var(--line)}
.hero{position:relative;overflow:hidden;padding:78px 0 58px}.hero-grid{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:44px;align-items:center}.eyebrow{display:inline-flex;margin-bottom:18px;padding:8px 14px;border-radius:999px;background:#fff;border:1px solid var(--line);color:var(--teal);font-size:.84rem;font-weight:900}h1,h2,h3{margin:0;line-height:1.08;letter-spacing:-.055em}h1{font-size:clamp(3rem,7vw,6.1rem);max-width:860px}h1 span,h2 span{color:var(--gold)}h2{font-size:clamp(2rem,4vw,3.75rem)}h3{font-size:1.45rem}.lead{font-size:clamp(1.05rem,2vw,1.22rem);color:var(--muted);max-width:720px;margin:22px 0 30px}.actions{display:flex;gap:14px;flex-wrap:wrap}
.hero-art{min-height:560px;border-radius:44px;position:relative;overflow:hidden;background:linear-gradient(180deg,rgba(17,24,39,.05),rgba(17,24,39,.62)),url("../img/bangkok-skyline.svg") center/cover;box-shadow:var(--shadow)}.caption{position:absolute;left:24px;right:24px;bottom:24px;padding:24px;border-radius:26px;background:rgba(17,24,39,.52);border:1px solid rgba(255,255,255,.24);backdrop-filter:blur(14px);color:#fff}.caption p{margin:8px 0 0;color:rgba(255,255,255,.78)}
section{padding:70px 0}.section-head{display:flex;justify-content:space-between;align-items:end;gap:28px;margin-bottom:32px}.section-head p{margin:0;color:var(--muted);max-width:470px}.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.card,.article,.sidebar,.cta{background:#fff;border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow)}.card{padding:28px;position:relative;overflow:hidden;border-top:4px solid var(--gold);min-height:270px}.card:after{content:attr(data-code);position:absolute;right:16px;top:4px;color:rgba(15,118,110,.075);font-size:5.6rem;line-height:1;font-weight:1000}.tag{display:inline-flex;padding:7px 11px;border-radius:999px;background:#ecfdf5;color:var(--teal);font-size:.78rem;font-weight:900}.card h3{margin-top:42px}.card p,.article p,.article li{color:var(--muted)}
.illustration-grid{display:grid;grid-template-columns:1.15fr .85fr .85fr;gap:18px;margin-top:34px}.illustration{min-height:270px;border-radius:30px;background-size:cover;background-position:center;position:relative;overflow:hidden;box-shadow:0 22px 60px rgba(17,24,39,.14);border:1px solid rgba(17,24,39,.10)}.illustration.large{min-height:380px}.illustration:after{content:attr(data-title);position:absolute;left:18px;right:18px;bottom:18px;padding:12px 14px;border-radius:18px;color:#fff;background:rgba(17,24,39,.56);backdrop-filter:blur(10px);font-weight:900}.ill-skyline{background-image:url("../img/bangkok-skyline.svg")}.ill-night{background-image:url("../img/bangkok-night.svg")}.ill-bts{background-image:url("../img/bangkok-bts.svg")}.ill-river{background-image:url("../img/bangkok-river.svg")}.ill-temple{background-image:url("../img/bangkok-temple.svg")}.ill-food{background-image:url("../img/bangkok-food.svg")}
.feature{border-radius:44px;padding:42px;background:radial-gradient(circle at 100% 0,rgba(216,155,43,.18),transparent 30%),linear-gradient(135deg,var(--night),#062c2a);color:#fff;box-shadow:var(--shadow)}.feature p{color:rgba(255,255,255,.76)}.split{display:grid;grid-template-columns:.9fr 1.1fr;gap:36px;align-items:center}.map{min-height:430px;border-radius:32px;background:url("../img/bangkok-night.svg") center/cover;position:relative;overflow:hidden}.map span{position:absolute;padding:9px 12px;border-radius:999px;background:rgba(17,24,39,.58);border:1px solid rgba(255,255,255,.22);color:#fff;font-size:.86rem;font-weight:900}.nana{left:44%;top:28%}.cowboy{left:58%;top:36%}.silom{left:30%;top:56%}.river{left:14%;top:44%}.airport{right:10%;bottom:15%}
.article-layout{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:28px;align-items:start}.article{padding:34px}.article h1{font-size:clamp(2.4rem,5vw,4.7rem)}.article h2{font-size:clamp(1.75rem,3vw,2.7rem);margin-top:38px}.sidebar{padding:28px;position:sticky;top:100px}.sidebar ul{padding-left:18px;color:var(--muted)}.note{margin:24px 0;padding:18px 20px;border-radius:18px;background:#ecfdf5;border-left:5px solid var(--teal)}.cta{padding:48px;background:radial-gradient(circle at 12% 0,rgba(216,155,43,.18),transparent 34%),linear-gradient(135deg,#fff,#ecfdf5)}
.footer{padding:42px 0;background:#fff;border-top:1px solid var(--line);color:var(--muted)}.footer-grid{display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap}.footer-links{display:flex;gap:18px;font-weight:800}
@media(max-width:940px){.menu{display:none}.hero-grid,.split,.article-layout{grid-template-columns:1fr}.hero-art{min-height:430px}.cards{grid-template-columns:1fr 1fr}.section-head{display:block}.section-head p{margin-top:14px}.sidebar{position:static}}@media(max-width:760px){.illustration-grid{grid-template-columns:1fr}.illustration,.illustration.large{min-height:260px}}@media(max-width:620px){.container{width:min(100% - 24px,var(--max))}.hero{padding-top:46px}.cards{grid-template-columns:1fr}.hero-art,.feature,.cta{border-radius:28px}.card,.feature,.article,.sidebar,.cta{padding:22px}.btn{width:100%}.map{min-height:320px}}


/* Real Bangkok photos */
.real-photo-grid{
  display:grid;
  grid-template-columns:1.15fr .85fr .85fr;
  gap:18px;
  margin-top:34px;
}
.real-photo{
  min-height:280px;
  border-radius:30px;
  background-size:cover;
  background-position:center;
  position:relative;
  overflow:hidden;
  box-shadow:0 24px 64px rgba(17,24,39,.16);
  border:1px solid rgba(17,24,39,.10);
}
.real-photo.large{min-height:390px}
.real-photo::after{
  content:attr(data-title);
  position:absolute;
  left:18px;
  right:18px;
  bottom:18px;
  padding:12px 14px;
  border-radius:18px;
  color:#fff;
  background:rgba(17,24,39,.58);
  backdrop-filter:blur(10px);
  font-weight:900;
}
.photo-skyline{background-image:url("../img/bangkok-skyline-photo.jpg")}
.photo-palace{background-image:url("../img/bangkok-grand-palace-photo.jpg")}
.photo-bts{background-image:url("../img/bangkok-bts-photo.jpg")}
.hero-art{
  background-image:linear-gradient(180deg,rgba(17,24,39,.05),rgba(17,24,39,.68)),url("../img/bangkok-skyline-photo.jpg") !important;
  background-size:cover !important;
  background-position:center !important;
}
.pattaya-note{
  margin-top:26px;
  padding:22px;
  border-radius:22px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.18);
}
.pattaya-note a{
  color:#ffd77d;
  font-weight:900;
  text-decoration:underline;
  text-underline-offset:4px;
}
.photo-credit{
  color:var(--muted, #666);
  font-size:.86rem;
  margin-top:12px;
}
@media(max-width:760px){
  .real-photo-grid{grid-template-columns:1fr}
  .real-photo,.real-photo.large{min-height:260px}
}


/* Real Bangkok neighborhood photos + longer guide pages */
.hero-art{
  background-image:linear-gradient(180deg,rgba(17,24,39,.06),rgba(17,24,39,.68)),url("../img/sukhumvit-asok-photo.jpg") !important;
  background-size:cover !important;
  background-position:center !important;
}
.guide-photo-grid{display:grid;grid-template-columns:1.2fr .8fr .8fr;gap:18px;margin-top:34px}
.guide-photo{min-height:290px;border-radius:30px;background-size:cover;background-position:center;position:relative;overflow:hidden;box-shadow:0 24px 64px rgba(17,24,39,.18);border:1px solid rgba(17,24,39,.10)}
.guide-photo.large{min-height:410px}
.guide-photo::after{content:attr(data-title);position:absolute;left:18px;right:18px;bottom:18px;padding:12px 14px;border-radius:18px;color:#fff;background:rgba(17,24,39,.62);backdrop-filter:blur(10px);font-weight:900}
.photo-nana{background-image:url("../img/nana-plaza-photo.jpg")}
.photo-cowboy{background-image:url("../img/soi-cowboy-photo.jpg")}
.photo-patpong{background-image:url("../img/patpong-photo.jpg")}
.photo-sukhumvit{background-image:url("../img/sukhumvit-asok-photo.jpg")}
.photo-river{background-image:url("../img/riverside-photo.jpg")}
.photo-airport{background-image:url("../img/airport-photo.jpg")}
.area-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:24px 0 4px}
.area-pill{padding:16px;border-radius:18px;background:#fff;border:1px solid var(--line, rgba(0,0,0,.12));box-shadow:0 10px 28px rgba(17,24,39,.06)}
.area-pill strong{display:block;color:var(--teal,#0f766e);margin-bottom:4px}
.pro-con{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:20px}
.pro-con div{padding:20px;border-radius:22px;background:#fff;border:1px solid var(--line, rgba(0,0,0,.12))}
.credit-note{color:var(--muted,#666);font-size:.86rem;margin-top:12px}
.hotel-table{display:grid;gap:12px;margin-top:24px}
.hotel-row{display:grid;grid-template-columns:1.1fr .9fr 1.4fr;gap:14px;align-items:start;padding:16px;border:1px solid var(--line, rgba(0,0,0,.12));border-radius:18px;background:#fff}
.hotel-row b{color:var(--teal,#0f766e)}
.note a{color:var(--teal,#0f766e);font-weight:900;text-decoration:underline;text-underline-offset:4px}
@media(max-width:900px){.guide-photo-grid,.area-summary,.pro-con,.hotel-row{grid-template-columns:1fr}.guide-photo,.guide-photo.large{min-height:260px}}


/* Fixed photo paths */
.photo-nana{background-image:url("../img/nana-plaza-photo.jpg") !important}
.photo-cowboy{background-image:url("../img/soi-cowboy-photo.jpg") !important}
.photo-patpong{background-image:url("../img/patpong-photo.jpg") !important}
.photo-sukhumvit{background-image:url("../img/sukhumvit-asok-photo.jpg") !important}
.photo-river{background-image:url("../img/riverside-photo.jpg") !important}
.photo-airport{background-image:url("../img/airport-photo.jpg") !important}
.hero-art{background-image:linear-gradient(180deg,rgba(17,24,39,.06),rgba(17,24,39,.68)),url("../img/sukhumvit-asok-photo.jpg") !important;background-size:cover !important;background-position:center !important}




/* FINAL LOCAL PHOTO FIX - no external photo URLs */
.guide-photo,.real-photo,.illustration{background-size:cover!important;background-position:center!important;background-repeat:no-repeat!important;position:relative;overflow:hidden;}
.guide-photo img,.real-photo img,.illustration img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;display:block;}
.guide-photo::after,.real-photo::after,.illustration::after{z-index:2;}
.photo-nana{background-image:url("../img/nana-plaza-photo.jpg")!important;}
.photo-cowboy{background-image:url("../img/soi-cowboy-photo.jpg")!important;}
.photo-patpong{background-image:url("../img/patpong-photo.jpg")!important;}
.photo-sukhumvit{background-image:url("../img/sukhumvit-asok-photo.jpg")!important;}
.photo-river{background-image:url("../img/riverside-photo.jpg")!important;}
.photo-airport{background-image:url("../img/airport-photo.jpg")!important;}
.photo-skyline,.ill-skyline{background-image:url("../img/bangkok-skyline-photo.jpg")!important;}
.photo-bts,.ill-bts{background-image:url("../img/bangkok-bts-photo.jpg")!important;}
.ill-night{background-image:url("../img/soi-cowboy-photo.jpg")!important;}
.ill-river{background-image:url("../img/riverside-photo.jpg")!important;}
.ill-temple{background-image:url("../img/bangkok-grand-palace-photo.jpg")!important;}
.ill-food{background-image:url("../img/bangkok-food.svg")!important;}
.hero-art{background-image:linear-gradient(180deg,rgba(17,24,39,.06),rgba(17,24,39,.68)),url("../img/sukhumvit-asok-photo.jpg")!important;background-size:cover!important;background-position:center!important;}


/* Image overflow fix + logo styling */
html, body{
  overflow-x:hidden;
}
img{
  max-width:100%;
  height:auto;
}
.logo{
  min-width:0;
}
.logo img.site-logo{
  display:block;
  width:min(310px, 58vw);
  height:auto;
  max-height:72px;
  object-fit:contain;
}
.logo .logo-mark,
.logo > span:not(.logo-mark){
  display:none !important;
}
.hero-art,
.guide-photo,
.real-photo,
.illustration,
.ny-photo,
.map,
.card,
.article,
.sidebar,
.cta,
.feature,
.post{
  overflow:hidden !important;
}
.guide-photo,
.real-photo,
.illustration,
.ny-photo{
  width:100% !important;
  max-width:100% !important;
  min-width:0 !important;
}
.guide-photo img,
.real-photo img,
.illustration img,
.ny-photo img,
.photo-card img{
  width:100% !important;
  height:100% !important;
  display:block !important;
  object-fit:cover !important;
  object-position:center !important;
}
.guide-photo-grid,
.real-photo-grid,
.illustration-grid,
.photo-strip,
.cards,
.posts,
.article-layout,
.hero-grid,
.split{
  min-width:0 !important;
}
.guide-photo-grid > *,
.real-photo-grid > *,
.illustration-grid > *,
.photo-strip > *,
.cards > *,
.posts > *,
.article-layout > *,
.hero-grid > *,
.split > *{
  min-width:0 !important;
}
.hero-art{
  width:100% !important;
  max-width:100% !important;
}
@media(max-width:940px){
  .logo img.site-logo{
    width:min(260px, 70vw);
    max-height:60px;
  }
}
@media(max-width:620px){
  .logo img.site-logo{
    width:min(220px, 72vw);
  }
  .nav{
    min-width:0;
  }
}


/* Final visual polish: no overflow, clean photos, better logo */
*, *::before, *::after{box-sizing:border-box}
html,body{max-width:100%;overflow-x:hidden}
body{background:linear-gradient(180deg,#f8fffb 0%,#fff7ed 55%,#ffffff 100%) !important}
.container{max-width:1180px}
.header{background:rgba(255,255,255,.92) !important}
.nav{min-width:0}
.logo{display:flex;align-items:center;min-width:0;flex-shrink:1}
.logo img.site-logo{display:block;width:clamp(230px,28vw,390px) !important;height:auto !important;max-height:76px !important;object-fit:contain}
.logo .logo-mark,.logo > span:not(.logo-mark){display:none !important}
.hero-grid,.article-layout,.split,.cards,.guide-photo-grid,.real-photo-grid,.illustration-grid,.photo-strip,.posts{min-width:0 !important}
.hero-grid > *,.article-layout > *,.split > *,.cards > *,.guide-photo-grid > *,.real-photo-grid > *,.illustration-grid > *,.photo-strip > *,.posts > *{min-width:0 !important}
.hero-art{width:100% !important;max-width:100% !important;min-width:0 !important;overflow:hidden !important;border-radius:34px !important}
.guide-photo-grid,.real-photo-grid,.illustration-grid,.photo-strip{
  display:grid !important;
  grid-template-columns:1.2fr .9fr .9fr !important;
  gap:18px !important;
  width:100% !important;
  overflow:hidden !important;
}
.guide-photo,.real-photo,.illustration,.ny-photo{
  position:relative !important;
  display:block !important;
  width:100% !important;
  max-width:100% !important;
  min-width:0 !important;
  aspect-ratio:16/10 !important;
  min-height:0 !important;
  height:auto !important;
  border-radius:26px !important;
  overflow:hidden !important;
  background-size:cover !important;
  background-position:center !important;
  box-shadow:0 18px 48px rgba(17,24,39,.14) !important;
}
.guide-photo.large,.real-photo.large,.illustration.large,.ny-photo.large{
  aspect-ratio:16/11 !important;
  min-height:0 !important;
}
.guide-photo img,.real-photo img,.illustration img,.ny-photo img{
  position:absolute !important;
  inset:0 !important;
  display:block !important;
  width:100% !important;
  height:100% !important;
  max-width:100% !important;
  object-fit:cover !important;
  object-position:center !important;
  border:0 !important;
}
.guide-photo::before,.real-photo::before,.illustration::before,.ny-photo::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:1;
  background:linear-gradient(180deg,rgba(17,24,39,0) 45%,rgba(17,24,39,.62) 100%);
  pointer-events:none;
}
.guide-photo::after,.real-photo::after,.illustration::after,.ny-photo::after{
  z-index:2 !important;
  left:14px !important;
  right:14px !important;
  bottom:14px !important;
  width:auto !important;
  max-width:calc(100% - 28px) !important;
  white-space:normal !important;
}
.card,.article,.sidebar,.cta,.feature,.post{overflow:hidden !important}
img{max-width:100%;height:auto}
@media(max-width:980px){
  .guide-photo-grid,.real-photo-grid,.illustration-grid,.photo-strip{grid-template-columns:1fr 1fr !important}
  .guide-photo.large,.real-photo.large,.illustration.large,.ny-photo.large{grid-column:1/-1}
}
@media(max-width:640px){
  .logo img.site-logo{width:min(260px,72vw) !important;max-height:58px !important}
  .guide-photo-grid,.real-photo-grid,.illustration-grid,.photo-strip{grid-template-columns:1fr !important}
  .guide-photo,.real-photo,.illustration,.ny-photo,.guide-photo.large,.real-photo.large,.illustration.large,.ny-photo.large{aspect-ratio:4/3 !important;border-radius:20px !important}
  .nav{min-height:68px}
}


/* Simple logo + compact cropped photos */
.logo img.site-logo{
  width:clamp(210px, 24vw, 330px) !important;
  max-height:58px !important;
  height:auto !important;
}
.header .nav{
  min-height:68px !important;
}
.guide-photo-grid,
.real-photo-grid,
.illustration-grid,
.photo-strip{
  display:grid !important;
  grid-template-columns:repeat(3, minmax(0, 1fr)) !important;
  gap:18px !important;
  width:100% !important;
  overflow:visible !important;
  align-items:stretch !important;
}
.guide-photo,
.real-photo,
.illustration,
.ny-photo{
  width:100% !important;
  max-width:100% !important;
  height:230px !important;
  min-height:230px !important;
  max-height:230px !important;
  aspect-ratio:auto !important;
  border-radius:22px !important;
  overflow:hidden !important;
  position:relative !important;
  display:block !important;
}
.guide-photo.large,
.real-photo.large,
.illustration.large,
.ny-photo.large{
  height:300px !important;
  min-height:300px !important;
  max-height:300px !important;
  grid-row:span 1 !important;
}
.guide-photo img,
.real-photo img,
.illustration img,
.ny-photo img{
  position:absolute !important;
  inset:0 !important;
  width:100% !important;
  height:100% !important;
  max-width:none !important;
  object-fit:cover !important;
  object-position:center !important;
  display:block !important;
}
.hero-art{
  min-height:360px !important;
  height:clamp(320px, 36vw, 460px) !important;
  max-height:460px !important;
  border-radius:28px !important;
}
.hero{
  padding-top:58px !important;
  padding-bottom:44px !important;
}
.card{
  min-height:230px !important;
}
@media(max-width:980px){
  .guide-photo-grid,
  .real-photo-grid,
  .illustration-grid,
  .photo-strip{
    grid-template-columns:1fr 1fr !important;
  }
  .guide-photo.large,
  .real-photo.large,
  .illustration.large,
  .ny-photo.large{
    grid-column:auto !important;
    height:250px !important;
    min-height:250px !important;
    max-height:250px !important;
  }
  .guide-photo,
  .real-photo,
  .illustration,
  .ny-photo{
    height:220px !important;
    min-height:220px !important;
    max-height:220px !important;
  }
}
@media(max-width:640px){
  .logo img.site-logo{
    width:min(230px, 72vw) !important;
    max-height:52px !important;
  }
  .guide-photo-grid,
  .real-photo-grid,
  .illustration-grid,
  .photo-strip{
    grid-template-columns:1fr !important;
  }
  .guide-photo,
  .real-photo,
  .illustration,
  .ny-photo,
  .guide-photo.large,
  .real-photo.large,
  .illustration.large,
  .ny-photo.large{
    height:220px !important;
    min-height:220px !important;
    max-height:220px !important;
    border-radius:18px !important;
  }
  .hero-art{
    min-height:280px !important;
    height:300px !important;
    max-height:300px !important;
  }
}


/* === DESIGNER LOGO + BEAUTIFUL LOCAL IMAGE CARDS === */
html,body{max-width:100% !important;overflow-x:hidden !important}
*,*::before,*::after{box-sizing:border-box !important}
.container{width:min(1160px,calc(100% - 36px)) !important;max-width:1160px !important}
.header{background:rgba(255,255,255,.94) !important}
.header .nav{min-height:74px !important;padding:8px 0 !important}
.logo{display:flex !important;align-items:center !important;max-width:300px !important;min-width:0 !important;overflow:hidden !important}
.logo img.site-logo{display:block !important;width:280px !important;max-width:280px !important;max-height:56px !important;height:auto !important;object-fit:contain !important}
.logo .logo-mark,.logo > span:not(.logo-mark){display:none !important}

.hero-grid,.article-layout,.split,.cards,.guide-photo-grid,.real-photo-grid,.illustration-grid,.photo-strip,.posts{min-width:0 !important}
.hero-grid>*,
.article-layout>*,
.split>*,
.cards>*,
.guide-photo-grid>*,
.real-photo-grid>*,
.illustration-grid>*,
.photo-strip>*,
.posts>*{min-width:0 !important}

.hero-grid{grid-template-columns:minmax(0,1fr) minmax(320px,480px) !important;gap:36px !important}
.hero-art{
  width:100% !important;
  max-width:480px !important;
  height:330px !important;
  min-height:330px !important;
  max-height:330px !important;
  justify-self:end !important;
  overflow:hidden !important;
  border-radius:28px !important;
  background-size:cover !important;
  background-position:center !important;
  box-shadow:0 20px 55px rgba(17,24,39,.16) !important;
}
.guide-photo-grid,.real-photo-grid,.illustration-grid,.photo-strip{
  display:grid !important;
  grid-template-columns:repeat(3,minmax(0,1fr)) !important;
  gap:20px !important;
  width:100% !important;
  max-width:100% !important;
  align-items:start !important;
  overflow:visible !important;
}
.guide-photo,.real-photo,.illustration,.ny-photo{
  position:relative !important;
  display:block !important;
  width:100% !important;
  max-width:100% !important;
  height:255px !important;
  min-height:255px !important;
  max-height:255px !important;
  aspect-ratio:auto !important;
  border-radius:24px !important;
  overflow:hidden !important;
  background-size:cover !important;
  background-position:center !important;
  border:1px solid rgba(17,24,39,.08) !important;
  box-shadow:0 18px 46px rgba(17,24,39,.14) !important;
}
.guide-photo.large,.real-photo.large,.illustration.large,.ny-photo.large{
  grid-column:auto !important;
  grid-row:auto !important;
  height:255px !important;
  min-height:255px !important;
  max-height:255px !important;
}
.guide-photo img,.real-photo img,.illustration img,.ny-photo img{
  position:absolute !important;
  inset:0 !important;
  width:100% !important;
  max-width:none !important;
  height:100% !important;
  object-fit:cover !important;
  object-position:center !important;
  display:block !important;
  transform:scale(1.01);
}
.guide-photo::before,.real-photo::before,.illustration::before,.ny-photo::before{
  content:"" !important;
  position:absolute !important;
  inset:0 !important;
  z-index:1 !important;
  background:linear-gradient(180deg,rgba(0,0,0,0) 48%,rgba(0,0,0,.62) 100%) !important;
  pointer-events:none !important;
}
.guide-photo::after,.real-photo::after,.illustration::after,.ny-photo::after{
  z-index:2 !important;
  left:14px !important;
  right:14px !important;
  bottom:14px !important;
  width:auto !important;
  max-width:calc(100% - 28px) !important;
  padding:9px 12px !important;
  border-radius:14px !important;
  font-size:.92rem !important;
  line-height:1.2 !important;
  white-space:normal !important;
  background:rgba(17,24,39,.58) !important;
}
.photo-nana{background-image:url("../img/nana-plaza-photo.jpg") !important}
.photo-cowboy{background-image:url("../img/soi-cowboy-photo.jpg") !important}
.photo-patpong{background-image:url("../img/patpong-photo.jpg") !important}
.photo-sukhumvit{background-image:url("../img/sukhumvit-asok-photo.jpg") !important}
.photo-river{background-image:url("../img/riverside-photo.jpg") !important}
.photo-airport{background-image:url("../img/airport-photo.jpg") !important}
.hero-art{background-image:linear-gradient(180deg,rgba(17,24,39,.08),rgba(17,24,39,.62)),url("../img/sukhumvit-asok-photo.jpg") !important}
.card,.article,.sidebar,.cta,.feature,.post{overflow:hidden !important}
img{max-width:100% !important}
section{padding:60px 0 !important}
@media(max-width:980px){
  .hero-grid{grid-template-columns:1fr !important}
  .hero-art{max-width:100% !important;justify-self:stretch !important;height:290px !important;min-height:290px !important;max-height:290px !important}
  .guide-photo-grid,.real-photo-grid,.illustration-grid,.photo-strip{grid-template-columns:repeat(2,minmax(0,1fr)) !important}
  .guide-photo,.real-photo,.illustration,.ny-photo,.guide-photo.large,.real-photo.large,.illustration.large,.ny-photo.large{height:235px !important;min-height:235px !important;max-height:235px !important}
}
@media(max-width:640px){
  .header .nav{min-height:64px !important}
  .logo{max-width:230px !important}
  .logo img.site-logo{width:220px !important;max-width:220px !important;max-height:48px !important}
  .guide-photo-grid,.real-photo-grid,.illustration-grid,.photo-strip{grid-template-columns:1fr !important}
  .guide-photo,.real-photo,.illustration,.ny-photo,.guide-photo.large,.real-photo.large,.illustration.large,.ny-photo.large{height:225px !important;min-height:225px !important;max-height:225px !important;border-radius:20px !important}
  .hero-art{height:240px !important;min-height:240px !important;max-height:240px !important}
}
