/* sexoc catalog css refactor: base -> mobile -> mobile landscape -> desktop */
*{box-sizing:border-box}
html,body{width:100%;height:100%;min-height:100%;margin:0;padding:0;background:#000;color:#fff;font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;overscroll-behavior:none;-webkit-text-size-adjust:100%;text-size-adjust:100%}
body{overflow:hidden}
button,a{-webkit-tap-highlight-color:transparent}
.pc-frame{width:100vw;height:100dvh;margin:0;overflow:hidden;background:#000}
.app{width:100vw;height:100dvh;margin:0;overflow-y:auto;overflow-x:hidden;scroll-snap-type:y mandatory;scroll-behavior:smooth;background:#000;-webkit-overflow-scrolling:touch}
.loading{min-height:100dvh;display:grid;place-items:center;color:#bbb;font-size:14px;text-align:center;line-height:1.7}
.seo-static-content{position:absolute;left:-10000px;top:auto;width:1px;height:1px;margin:0;padding:0;overflow:hidden;clip:rect(0,0,0,0);white-space:normal;border:0}
.seo-static-content h1,.seo-static-content p{margin:0;padding:0}
.empty-panel{min-height:100dvh;display:grid;place-items:center;color:#ccc;padding:20px;text-align:center;line-height:1.8}
.feed-item{position:relative;width:100vw;height:100dvh;min-height:100dvh;display:flex;flex-direction:column;scroll-snap-align:start;scroll-snap-stop:always;background:#000;overflow:hidden}
.video-panel{position:relative;flex:0 0 auto;width:100%;aspect-ratio:16/9;background:#000;display:grid;place-items:center;overflow:hidden}
.video-panel video{position:relative;z-index:1;display:block;width:100%;height:100%;object-fit:contain;background:#000}
.poster-fallback{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;background:#000;opacity:1;transition:opacity .16s ease}
.poster-fallback.is-hidden{opacity:0}
.info-panel{flex:1 1 auto;min-height:0;display:flex;flex-direction:column;gap:9px;padding:13px 14px calc(16px + env(safe-area-inset-bottom));background:linear-gradient(180deg,#111 0%,#050505 100%);color:#fff;overflow:hidden}
.platform-row{display:flex;align-items:center;gap:8px;color:#c9c9c9;font-size:12px;line-height:1.2}
.platform-badge{appearance:none;display:inline-flex;align-items:center;min-height:21px;padding:3px 8px;border:1px solid rgba(255,255,255,.22);border-radius:999px;background:rgba(255,255,255,.04);color:#fff;font:inherit;font-size:11px;letter-spacing:.02em;line-height:1.2;cursor:pointer}.platform-badge:hover,.platform-badge:focus-visible{background:rgba(255,255,255,.16);outline:none}
.index-indicator{margin-left:auto;color:#aaa;font-size:12px;min-width:44px;text-align:right}
.title{margin:0;color:#fff;font-size:22px;line-height:1.3;font-weight:700;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:3;line-clamp:3;overflow:hidden}
.title-mark{display:inline-flex;align-items:center;margin:0 .35em .12em 0;padding:.12em .42em;border-radius:.35em;background:#fff;color:#111;font-size:.58em;font-weight:800;line-height:1.25;text-transform:uppercase;vertical-align:middle;letter-spacing:.03em}
.one-line{margin:0;color:#e5e5e5;font-size:14px;line-height:1.52;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:3;line-clamp:3;overflow:hidden}
.tag-row{display:flex;gap:6px;flex-wrap:wrap;max-height:64px;overflow:hidden}
.tag{display:inline-flex;align-items:center;max-width:52vw;padding:5px 8px;border-radius:999px;background:rgba(255,255,255,.1);color:#eee;font-size:12px;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.genre-strip{margin:0;padding:0}
.genre-strip-title{margin:0 0 7px;color:#fff;font-size:12px;line-height:1.2;font-weight:700}
.genre-chip-scroll{display:flex;gap:7px;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:0 1px 2px}
.genre-chip-scroll::-webkit-scrollbar{display:none}
.genre-chip{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;min-height:31px;padding:7px 10px;border-radius:999px;background:rgba(255,255,255,.11);border:1px solid rgba(255,255,255,.14);color:#fff;text-decoration:none;font-size:12px;line-height:1;white-space:nowrap;backdrop-filter:blur(6px)}
.genre-chip:active,.genre-chip:hover{background:rgba(255,255,255,.22)}
.action-row{margin-top:auto;display:grid;grid-template-columns:1fr 46px 46px;gap:10px;align-items:center}
.primary-link{display:inline-flex;justify-content:center;align-items:center;min-height:46px;padding:10px 13px;border-radius:999px;background:#fff;color:#000;text-decoration:none;font-weight:700;font-size:15px;line-height:1.15}
.icon-button{display:inline-flex;align-items:center;justify-content:center;width:46px;height:46px;border:1px solid rgba(255,255,255,.25);border-radius:999px;background:rgba(255,255,255,.08);color:#fff;font-size:18px;padding:0;cursor:pointer}
.favorite-button.is-favorite{background:#fff;color:#d20045;border-color:#fff}
.mode-pill{
  position:fixed;
  z-index:20;
  top:10px;
  left:50%;
  transform:translateX(-50%);
  display:inline-flex;
  align-items:center;
  gap:6px;
  width:auto;
  max-width:calc(100vw - 24px);
  padding:6px;
  border:1px solid rgba(255,255,255,.28);
  border-radius:999px;
  background:rgba(0,0,0,.45);
  backdrop-filter:blur(8px);
  color:#fff;
  font-size:12px;
  white-space:nowrap;
  overflow-x:auto;
  overflow-y:hidden;
  scrollbar-width:none;
  opacity:1;
  transition:opacity .45s ease,transform .45s ease;
}

.mode-pill.is-hidden{
  opacity:0;
  transform:translate(-50%,-10px);
  pointer-events:none;
}

.mode-pill::-webkit-scrollbar{
  display:none;
}

.mode-pill button{
  all:unset;
  flex:0 0 auto;
  cursor:pointer;
  padding:6px 10px;
  border-radius:999px;
  line-height:1;
  white-space:nowrap;
}

.mode-pill button.is-active{
  background:#fff;
  color:#111;
}

.mode-pill button:disabled,
.mode-pill button.is-disabled{
  opacity:.38;
  color:rgba(255,255,255,.58);
  cursor:not-allowed;
}

.mode-pill button:disabled:hover,
.mode-pill button.is-disabled:hover{
  background:transparent;
}
.scroll-hint{position:fixed;left:50%;bottom:calc(96px + env(safe-area-inset-bottom));z-index:30;display:flex;align-items:center;gap:6px;padding:8px 12px;border-radius:999px;background:rgba(0,0,0,.58);border:1px solid rgba(255,255,255,.22);box-shadow:0 4px 18px rgba(0,0,0,.28);color:#fff;font-size:12px;font-weight:700;line-height:1;pointer-events:none;backdrop-filter:blur(8px);animation:scrollHintBounce 1.45s ease-in-out infinite;transition:opacity .25s ease,transform .25s ease}
.scroll-hint.is-hidden{opacity:0;transform:translate(-50%,8px)}
.scroll-hint__arrow{font-size:18px;line-height:1}
@keyframes scrollHintBounce{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,9px)}}
.tag-button{appearance:none;border:0;font:inherit;cursor:default}
.tag-button.has-tag-info{color:#fff;background:rgba(255,255,255,.16);text-decoration:underline;text-decoration-style:dotted;text-underline-offset:3px;cursor:pointer}
.tag-button.has-tag-info:hover{background:rgba(255,255,255,.24)}
.tag-modal{position:fixed;inset:0;z-index:80;display:none;align-items:center;justify-content:center;padding:18px;background:rgba(0,0,0,.62);backdrop-filter:blur(5px)}
.tag-modal.is-visible{display:flex}
.tag-modal__box{width:min(92vw,430px);max-height:74dvh;overflow:auto;border:1px solid rgba(255,255,255,.18);border-radius:18px;background:#161616;color:#fff;box-shadow:0 14px 42px rgba(0,0,0,.45);padding:18px}
.tag-modal__title{margin:0 0 8px;font-size:20px;line-height:1.35;font-weight:800}
.tag-modal__description{margin:0;color:#e8e8e8;font-size:14px;line-height:1.7}
.tag-modal__ja{margin:10px 0 0;color:#bdbdbd;font-size:12px;line-height:1.5}
.tag-modal__close{width:100%;margin-top:16px;min-height:42px;border:0;border-radius:999px;background:#fff;color:#111;font-size:14px;font-weight:700;cursor:pointer}.site-modal{position:fixed;inset:0;z-index:90;display:none;align-items:flex-end;justify-content:center;padding:16px;background:rgba(0,0,0,.66);backdrop-filter:blur(6px)}.site-modal.is-visible{display:flex}.site-modal__box{width:min(94vw,480px);max-height:78dvh;overflow:auto;border:1px solid rgba(255,255,255,.2);border-radius:22px 22px 18px 18px;background:#151515;color:#fff;box-shadow:0 18px 52px rgba(0,0,0,.5);padding:18px}.site-modal__title{margin:0 0 10px;font-size:20px;line-height:1.35;font-weight:800}.site-modal__body{display:grid;gap:10px;margin:0;color:#e9e9e9;font-size:14px;line-height:1.7}.site-modal__body p{margin:0}.site-modal__list{margin:2px 0 0;padding:0;list-style:none;display:grid;gap:7px}.site-modal__list li{padding-left:1.35em;position:relative}.site-modal__list li::before{content:"✓";position:absolute;left:0;color:#fff}.site-modal__note{margin:10px 0 0;color:#bdbdbd;font-size:12px;line-height:1.55}.site-modal__close{width:100%;margin-top:16px;min-height:42px;border:0;border-radius:999px;background:#fff;color:#111;font-size:14px;font-weight:700;cursor:pointer}.site-modal__links{display:grid;gap:8px;margin-top:12px}.site-modal__link{display:flex;align-items:center;justify-content:center;min-height:42px;padding:10px 13px;border-radius:999px;border:1px solid rgba(255,255,255,.24);background:rgba(255,255,255,.08);color:#fff;text-decoration:none;font-size:14px;font-weight:700;line-height:1.25;text-align:center}.site-modal__link:hover,.site-modal__link:focus-visible{background:rgba(255,255,255,.18);outline:none}.site-modal__link--primary{background:#fff;color:#111;border-color:#fff}.site-modal__link--primary:hover,.site-modal__link--primary:focus-visible{background:#eaeaea;color:#111}.site-modal__soft-link{appearance:none;border:0;background:transparent;color:#fff;text-decoration:underline;text-decoration-style:dotted;text-underline-offset:4px;font:inherit;font-size:13px;font-weight:700;line-height:1.5;padding:4px 0;margin-top:2px;cursor:pointer;text-align:left}.site-modal__soft-link:hover,.site-modal__soft-link:focus-visible{color:#eaeaea;outline:none}.site-modal__section{margin-top:10px}.site-modal__section-title{margin:0 0 6px;font-size:14px;line-height:1.45;font-weight:800;color:#fff}.site-modal__small-list{margin:0;padding:0;list-style:none;display:grid;gap:6px;color:#e9e9e9}.site-modal__small-list li{padding-left:1.25em;position:relative}.site-modal__small-list li::before{content:"•";position:absolute;left:.2em;color:#fff}
@media (max-width:768px) and (orientation:portrait){
  html.is-sexoc-chrome .title{font-size:23px}
  html.is-sexoc-chrome .one-line{font-size:15px;line-height:1.55}
  html.is-sexoc-firefox .info-panel{gap:9px;padding:13px 13px calc(16px + env(safe-area-inset-bottom))}
  html.is-sexoc-firefox .title{font-size:22px;line-height:1.28}
  html.is-sexoc-firefox .one-line{font-size:15px;line-height:1.52}
}
@media (max-width:768px) and (orientation:landscape){
  html,body,.pc-frame,.app,.feed-item{width:100vw;height:100dvh;min-height:100dvh;margin:0;padding:0;overflow:hidden;background:#000}
  .app{overflow-y:auto;overflow-x:hidden;scroll-snap-type:y mandatory;touch-action:pan-y}
  .feed-item{display:block;position:relative;touch-action:pan-y}
  .video-panel{position:absolute;inset:0;width:100vw;height:100dvh;max-width:none;max-height:none;aspect-ratio:auto;display:flex;align-items:center;justify-content:center;z-index:1;pointer-events:none;touch-action:pan-y}
  .video-panel video,.poster-fallback{position:absolute;inset:0;width:100vw;height:100dvh;max-width:none;max-height:none;object-fit:contain;pointer-events:none}
  .info-panel,.platform-row,.title,.one-line,.tag-row,.genre-strip,.action-row,.primary-link,.icon-button,.mode-pill,.scroll-hint,.tag-modal,.site-modal{display:none;visibility:hidden;opacity:0;pointer-events:none}
}
@media (min-width:769px){
  html,body{width:100%;height:100%;min-height:100%;overflow:hidden;background:#000}
  .pc-frame{position:relative;width:min(520px,100vw);height:100dvh;margin:0 auto;padding:0;overflow:hidden;background:#000;border-left:1px solid rgba(255,255,255,.08);border-right:1px solid rgba(255,255,255,.08);box-shadow:0 0 0 1px rgba(255,255,255,.03),0 0 40px rgba(0,0,0,.55)}
  .pc-frame>.app{position:relative;width:calc(100% + 28px);height:100dvh;margin:0;padding:0 28px 0 0;overflow-y:auto;overflow-x:hidden;scroll-snap-type:y mandatory;scroll-behavior:smooth;border:0;box-shadow:none;background:#000;scrollbar-width:none;-ms-overflow-style:none;touch-action:auto}
  .pc-frame>.app::-webkit-scrollbar{display:none;width:0;height:0}
  .pc-frame>.app .feed-item{position:relative;display:flex;flex-direction:column;width:calc(100% - 28px);height:calc(100dvh - 18px);min-height:calc(100dvh - 18px);margin:0;padding:0;overflow:hidden;scroll-snap-align:start;scroll-snap-stop:always;background:#000;touch-action:auto}
  .pc-frame>.app .video-panel{position:relative;inset:auto;z-index:auto;flex:0 0 auto;width:100%;max-width:100%;height:auto;min-height:0;max-height:none;aspect-ratio:16/9;display:grid;place-items:center;overflow:hidden;background:#000;pointer-events:auto;touch-action:auto}
  .pc-frame>.app .video-panel video{position:relative;inset:auto;display:block;width:100%;height:100%;max-width:100%;max-height:100%;object-fit:contain;background:#000;pointer-events:auto}
  .pc-frame>.app .poster-fallback{position:absolute;inset:0;width:100%;height:100%;max-width:100%;max-height:100%;object-fit:contain;background:#000;pointer-events:auto}
  .pc-frame>.app .info-panel{position:relative;z-index:auto;left:auto;right:auto;bottom:auto;flex:1 1 auto;min-height:0;max-height:none;display:flex;flex-direction:column;gap:10px;padding:14px 18px calc(18px + env(safe-area-inset-bottom));background:linear-gradient(180deg,#111 0%,#050505 100%);color:#fff;overflow:hidden;visibility:visible;opacity:1;width:auto;height:auto;pointer-events:auto}
  .pc-frame>.app .platform-row{display:flex;visibility:visible;opacity:1;font-size:12px}
  .pc-frame>.app .title{display:-webkit-box;visibility:visible;opacity:1;font-size:21px;line-height:1.35;-webkit-line-clamp:3;line-clamp:3}
  .pc-frame>.app .one-line{display:-webkit-box;visibility:visible;opacity:1;font-size:15px;line-height:1.55;-webkit-line-clamp:2;line-clamp:2}
  .pc-frame>.app .tag-row{display:flex;visibility:visible;opacity:1;max-height:58px}
  .pc-frame>.app .tag{max-width:220px;font-size:13px}
  .pc-frame>.app .genre-strip{display:block;visibility:visible;opacity:1;max-height:none}
  .pc-frame>.app .action-row{display:grid;visibility:visible;opacity:1;grid-template-columns:1fr 46px 46px;gap:10px;align-items:center;margin-top:auto}
  .pc-frame>.app .primary-link{display:inline-flex;visibility:visible;opacity:1;min-height:46px;padding:10px 14px;font-size:15px;line-height:1.2;max-width:none;pointer-events:auto}
  .pc-frame>.app .icon-button{display:inline-flex;visibility:visible;opacity:1;width:46px;height:46px;font-size:18px;pointer-events:auto}
  .mode-pill{display:inline-flex;top:16px;max-width:min(480px,calc(100vw - 24px))}
  .scroll-hint{left:50%;bottom:92px}
}
