:root{
    --cream: #FFF6E8;
    --cream-2: #FFF1DD;
    --ink: #3F2B22;
    --ink-2: #40261B;
    --clay: #8B5E45;
    --clay-2: #6F4D37;
    --gold: #F2DFC4;
    --rust: #9B6D55;
    --brown-deep: #4F3429;
    --brown-mid: #5C4033;
    --line: #7C5B49;
    --paper: #FBEFDD;
  }

  *{margin:0; padding:0; box-sizing:border-box;}

  html{scroll-behavior:smooth;}

  body{
    background: var(--cream);
    color: var(--ink);
    font-family:'Be Vietnam Pro', sans-serif;
    font-weight:400;
    overflow-x:hidden;
    position:relative;
  }

  body::before{
    content:"";
    position:fixed;
    inset:0;
    pointer-events:none;
    z-index:500;
    opacity:.05;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
    mix-blend-mode:multiply;
  }

  .film-rail{
    position:fixed;
    top:0; bottom:0;
    width:22px;
    background: repeating-linear-gradient(to bottom, var(--ink-2) 0 10px, transparent 10px 26px);
    z-index:400;
    opacity:.14;
  }
  .film-rail.left{left:0;}
  .film-rail.right{right:0;}

  .eyebrow{
    font-family:'Space Mono', monospace;
    font-size:11px;
    letter-spacing:.18em;
    text-transform:uppercase;
    color: var(--clay-2);
  }

  h1,h2,h3{
    font-family:'Lora', serif;
    font-weight:500;
    color: var(--ink-2);
  }

  a{color:inherit; text-decoration:none;}

  .wrap{
    max-width:1180px;
    margin:0 auto;
    padding:0 48px;
  }

  /* NAV */
  nav{
    position:sticky;
    top:0;
    z-index:100;
    background: rgba(255,246,232,.86);
    backdrop-filter: blur(6px);
    border-bottom: 1px solid rgba(63,43,34,.12);
  }
  .nav-inner{
    display:flex;
    align-items:center;
    justify-content:space-between;
    padding:18px 48px;
    max-width:1180px;
    margin:0 auto;
  }
  .nav-brand{
    display:flex;
    align-items:center;
    gap:12px;
  }
  .nav-logo{
    width:36px; height:36px;
    border-radius:50%;
    background: radial-gradient(circle at 35% 30%, var(--gold), var(--clay) 70%);
    border:1px solid rgba(63,43,34,.25);
    flex-shrink:0;
  }
  .nav-brand span{
    font-family:'Lora', serif;
    font-size:15px;
    font-weight:600;
    letter-spacing:.02em;
  }
  .nav-links{
    display:flex;
    gap:34px;
    font-size:14px;
    color: var(--brown-mid);
  }
  .nav-links a{
    position:relative;
    transition:color .2s;
  }
  .nav-links a:hover{color:var(--ink-2);}
  .nav-links a::after{
    content:"";
    position:absolute;
    left:0; bottom:-5px;
    width:0; height:1px;
    background: var(--clay);
    transition:width .25s ease;
  }
  .nav-links a:hover::after{width:100%;}
  .nav-toggle{display:none;}

  /* HERO */
  .hero{
    position:relative;
    padding:96px 48px 120px;
    text-align:center;
    background:
      radial-gradient(ellipse 80% 60% at 50% 0%, rgba(242,223,196,.55), transparent 60%),
      var(--cream);
  }
  .hero-timestamp{
    position:absolute;
    top:110px;
    right:56px;
    font-family:'Space Mono', monospace;
    font-size:12px;
    color: var(--rust);
    opacity:.7;
    letter-spacing:.05em;
    writing-mode: vertical-rl;
  }
  .avatar{
    width:104px; height:104px;
    border-radius:50%;
    margin:0 auto 28px;
    background: radial-gradient(circle at 32% 28%, var(--gold) 0%, var(--clay) 55%, var(--brown-deep) 100%);
    border:2px solid var(--cream-2);
    box-shadow: 0 0 0 1px rgba(63,43,34,.18);
  }
  .hero h1{
    font-size: clamp(30px, 4.6vw, 54px);
    line-height:1.15;
    max-width:920px;
    margin:0 auto 22px;
    letter-spacing:-.01em;
  }
  .hero h1 .divider{
    color: var(--clay);
    font-weight:400;
    padding:0 10px;
  }
  .hero-bio{
    max-width:560px;
    margin:0 auto;
    font-size:16.5px;
    line-height:1.75;
    color: var(--brown-mid);
  }
  .hero-bio em{
    font-family:'Lora', serif;
    font-style:italic;
    color: var(--ink-2);
  }
  .hero-scroll{
    margin-top:52px;
    font-family:'Space Mono', monospace;
    font-size:11px;
    letter-spacing:.16em;
    text-transform:uppercase;
    color: var(--rust);
  }

  /* SPOTLIGHT */
  .spotlight{
    padding:20px 48px 120px;
    background: var(--cream);
  }
  .spotlight-inner{
    max-width:1180px;
    margin:0 auto;
    display:grid;
    grid-template-columns: 1.05fr 0.95fr;
    gap:56px;
    align-items:center;
    background: var(--ink-2);
    border-radius:18px;
    padding:56px;
    position:relative;
    overflow:hidden;
  }
  .spotlight-inner::before{
    content:"";
    position:absolute;
    inset:0;
    background: radial-gradient(circle at 85% 15%, rgba(242,223,196,.14), transparent 55%);
    pointer-events:none;
  }
  .spot-media{
    position:relative;
    aspect-ratio: 4/5;
    border-radius:12px;
    overflow:hidden;
    background: linear-gradient(160deg, var(--clay) 0%, var(--brown-deep) 100%);
    border:1px solid rgba(242,223,196,.25);
  }
  .spot-media video, .spot-media img{
    width:100%; height:100%;
    object-fit:cover;
    display:block;
    opacity:.92;
  }
  .spot-media .badge{
    position:absolute;
    top:16px; left:16px;
    font-family:'Space Mono', monospace;
    font-size:11px;
    letter-spacing:.1em;
    text-transform:uppercase;
    background: rgba(63,43,34,.55);
    color: var(--gold);
    padding:6px 12px;
    border-radius:20px;
    border:1px solid rgba(242,223,196,.35);
  }
  .spot-media .grain-frame{
    position:absolute; inset:0;
    box-shadow: inset 0 0 60px rgba(0,0,0,.35);
  }
  .spot-copy .eyebrow{color: var(--gold); opacity:.8;}
  .spot-copy h2{
    color: var(--cream-2);
    font-size: clamp(26px, 3vw, 38px);
    margin: 14px 0 18px;
    line-height:1.2;
  }
  .spot-copy p{
    color: rgba(255,246,232,.78);
    font-size:15.5px;
    line-height:1.8;
    margin-bottom:28px;
    max-width:440px;
  }
  .btn-primary{
    display:inline-flex;
    align-items:center;
    gap:10px;
    background: var(--gold);
    color: var(--ink-2);
    font-family:'Be Vietnam Pro', sans-serif;
    font-weight:600;
    font-size:14.5px;
    padding:14px 28px;
    border-radius:30px;
    border:1px solid transparent;
    transition: transform .2s ease, background .2s ease;
  }
  .btn-primary:hover{
    background: var(--cream-2);
    transform: translateY(-2px);
  }
  .btn-primary .arrow{transition: transform .2s ease;}
  .btn-primary:hover .arrow{transform: translateX(3px);}

  /* GALLERY */
  .gallery{
    padding:20px 48px 130px;
  }
  .gallery-head{
    max-width:1180px;
    margin:0 auto 46px;
    text-align:center;
  }
  .gallery-head h2{
    font-size: clamp(26px, 3.4vw, 38px);
    margin:12px 0 14px;
  }
  .gallery-head p{
    color: var(--brown-mid);
    max-width:480px;
    margin:0 auto;
    font-size:15px;
    line-height:1.7;
  }
  .grid{
    max-width:1180px;
    margin:0 auto;
    display:grid;
    grid-template-columns: repeat(3, minmax(0,1fr));
    gap:34px 30px;
  }
  .card{
    background: var(--paper);
    border-radius:4px;
    padding:14px 14px 20px;
    box-shadow: 0 1px 0 rgba(63,43,34,.06), 0 10px 24px -18px rgba(63,43,34,.4);
    transform: rotate(var(--tilt, -1.1deg));
    transition: transform .3s ease, box-shadow .3s ease;
    position:relative;
    border:1px solid rgba(63,43,34,.08);
  }
  .card:nth-child(3n+1){--tilt: -1.4deg;}
  .card:nth-child(3n+2){--tilt: 1deg;}
  .card:nth-child(3n){--tilt: -0.6deg;}
  .card:hover{
    transform: rotate(0deg) translateY(-6px);
    box-shadow: 0 18px 34px -18px rgba(63,43,34,.5);
  }
  .card-tape{
    position:absolute;
    top:-10px; left:50%;
    transform: translateX(-50%) rotate(-2deg);
    width:64px; height:22px;
    background: rgba(242,223,196,.65);
    border:1px solid rgba(63,43,34,.1);
    opacity:.85;
  }
  .card-thumb{
    aspect-ratio: 1/1;
    border-radius:2px;
    background: linear-gradient(150deg, var(--clay) 0%, var(--brown-deep) 100%);
    margin-bottom:14px;
    position:relative;
    overflow:hidden;
  }
  .card-thumb img.card-avatar{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
  }
  .card-thumb .vibe{
    position:absolute;
    bottom:10px; right:10px;
    font-size:20px;
    filter: drop-shadow(0 1px 2px rgba(0,0,0,.35));
    z-index:1;
  }
  .card-thumb .frame-no{
    position:absolute;
    top:10px; left:10px;
    font-family:'Space Mono', monospace;
    font-size:10px;
    color: rgba(255,246,232,.8);
    letter-spacing:.08em;
    z-index:1;
  }
  .card h3{
    font-size:18px;
    margin-bottom:8px;
    color: var(--ink-2);
  }
  .card p{
    font-size:13.5px;
    line-height:1.65;
    color: var(--brown-mid);
    margin-bottom:16px;
    min-height:64px;
  }
  .card a.explore{
    font-family:'Space Mono', monospace;
    font-size:11.5px;
    letter-spacing:.08em;
    text-transform:uppercase;
    color: var(--clay-2);
    border-bottom:1px solid var(--clay-2);
    padding-bottom:2px;
    display:inline-block;
    transition: color .2s;
  }
  .card a.explore:hover{color: var(--ink-2); border-color: var(--ink-2);}

  /* FOOTER */
  footer{
    background: var(--ink-2);
    padding:64px 48px 40px;
    text-align:center;
  }
  .footer-note{
    font-family:'Lora', serif;
    font-style:italic;
    color: var(--gold);
    font-size:17px;
    max-width:440px;
    margin:0 auto 34px;
    line-height:1.6;
  }
  .social-row{
    display:flex;
    justify-content:center;
    gap:18px;
    margin-bottom:36px;
    flex-wrap:wrap;
  }
  .social-btn{
    display:inline-flex;
    align-items:center;
    gap:10px;
    padding:13px 26px;
    border-radius:30px;
    border:1px solid rgba(242,223,196,.3);
    color: var(--cream-2);
    font-size:14px;
    letter-spacing:.02em;
    transition: background .2s, border-color .2s, transform .2s;
  }
  .social-btn:hover{
    background: rgba(242,223,196,.08);
    border-color: rgba(242,223,196,.6);
    transform: translateY(-2px);
  }
  .social-btn .dot{
    width:7px; height:7px;
    border-radius:50%;
    background: var(--gold);
  }
  .copyright{
    font-family:'Space Mono', monospace;
    font-size:11.5px;
    letter-spacing:.06em;
    color: rgba(255,246,232,.42);
  }

  /* RESPONSIVE */
  @media (max-width: 1024px){
    .wrap, .nav-inner, .gallery-head, .grid, .spotlight-inner{max-width: 100%;}
    .nav-inner, .hero, .spotlight, .gallery{padding-left:36px; padding-right:36px;}
    .grid{grid-template-columns: repeat(2, minmax(0,1fr));}
    .spotlight-inner{grid-template-columns: 1fr; padding:40px;}
    .spot-media{aspect-ratio: 16/9;}
    .spot-copy p{max-width:100%;}
    .hero-timestamp{display:none;}
  }

  @media (max-width: 834px){
    .nav-inner, .hero, .spotlight, .gallery{padding-left:28px; padding-right:28px;}
    .hero{padding-top:72px; padding-bottom:88px;}
    .grid{gap:28px 22px;}
  }

  @media (max-width: 600px){
    .nav-links{
      position:fixed;
      top:70px; left:0; right:0;
      flex-direction:column;
      background: var(--cream-2);
      padding: 20px 28px 28px;
      gap:18px;
      border-bottom:1px solid rgba(63,43,34,.12);
      transform: translateY(-8px);
      opacity:0;
      pointer-events:none;
      transition: opacity .2s ease, transform .2s ease;
    }
    .nav-links.open{
      opacity:1;
      transform: translateY(0);
      pointer-events:auto;
    }
    .nav-toggle{
      display:flex;
      flex-direction:column;
      gap:5px;
      background:none;
      border:none;
      cursor:pointer;
      padding:6px;
    }
    .nav-toggle span{
      width:22px; height:1.5px;
      background: var(--ink-2);
    }
    .film-rail{width:10px;}
    .nav-inner, .hero, .spotlight, .gallery{padding-left:20px; padding-right:20px;}
    .hero{padding-top:60px; padding-bottom:70px;}
    .hero h1{padding:0 4px;}
    .hero h1 .divider{display:block; height:10px; padding:0;}
    .spotlight-inner{padding:26px; border-radius:14px; gap:30px;}
    .grid{grid-template-columns: 1fr; gap:26px;}
    .card{transform: rotate(0deg) !important;}
    .card:hover{transform: translateY(-4px) !important;}
    .social-row{gap:12px;}
    .social-btn{padding:12px 20px; font-size:13px;}
  }

/* ============================================================= */
/* BUBBLE MODAL GIỚI THIỆU NHÂN VẬT                                */
/* ============================================================= */

#char-modal-overlay{
  display:none;
  position:fixed;
  inset:0;
  background: rgba(63,43,34,.55);
  backdrop-filter: blur(4px);
  z-index:9998;
}

.card, .spotlight-inner{ cursor: pointer; }

#char-modal-bubble{
  display:none;
  position:fixed;
  top:50%; left:50%;
  transform: translate(-50%,-50%);
  width:70vw;
  max-width:95vw;
  max-height:85vh;
  background: var(--paper);
  border-radius:26px;
  overflow:hidden;
  box-shadow: 0 24px 60px rgba(63,43,34,.4);
  z-index:9999;
  flex-direction: row;
}

.char-modal-close{
  position:absolute;
  top:14px; right:14px;
  width:32px; height:32px;
  border-radius:50%;
  border:none;
  background: rgba(63,43,34,.15);
  color: var(--ink-2);
  font-size:14px;
  cursor:pointer;
  z-index:2;
  display:flex;
  align-items:center;
  justify-content:center;
  transition: background .2s;
}
.char-modal-close:hover{ background: rgba(63,43,34,.3); }

/* Bên trái: ảnh/emoji đại diện nhân vật */
.char-modal-media{
  width:35%;
  flex-shrink:0;
  background: linear-gradient(160deg, var(--clay) 0%, var(--brown-deep) 100%);
  display:flex;
  align-items:center;
  justify-content:center;
}
#char-modal-emoji{
  font-size:88px;
  filter: drop-shadow(0 4px 10px rgba(0,0,0,.35));
}

/* Bên phải: nội dung bubble */
.char-modal-body{
  flex:1;
  padding:30px 28px;
  overflow-y:auto;
  display:flex;
  flex-direction:column;
}

.char-modal-header h3{
  font-size:24px;
  margin-bottom:8px;
  color: var(--ink-2);
}

.char-modal-tags{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-bottom:18px;
}
.char-modal-tag{
  font-family:'Space Mono', monospace;
  font-size:10.5px;
  letter-spacing:.06em;
  text-transform:uppercase;
  background: rgba(139,94,69,.14);
  color: var(--clay-2);
  padding:5px 11px;
  border-radius:20px;
  border:1px solid rgba(139,94,69,.25);
}

.char-modal-scene{
  background: rgba(139,94,69,.08);
  border: 1px solid rgba(139,94,69,.18);
  border-radius:14px;
  padding:16px 18px;
  margin-bottom:22px;
}
.char-modal-scene-label{
  font-family:'Space Mono', monospace;
  font-size:10.5px;
  letter-spacing:.1em;
  text-transform:uppercase;
  color: var(--rust);
  margin-bottom:8px;
}
.char-modal-scene p{
  font-size:14px;
  line-height:1.7;
  color: var(--brown-mid);
  font-style: italic;
}

.char-modal-chat-btn{
  align-self:center;
  margin-top:auto;
  display:inline-flex;
  align-items:center;
  gap:8px;
  background: var(--ink-2);
  color: var(--cream-2);
  padding:12px 28px;
  border-radius:30px;
  font-size:14px;
  font-weight:500;
  transition: transform .2s ease, background .2s ease;
}
.char-modal-chat-btn:hover{
  background: var(--clay);
  transform: translateY(-2px);
}

@media (max-width: 640px){
  #char-modal-bubble{
    flex-direction: column;
    width: 95vw;
    max-height: 90vh;
    border-radius:22px;
  }
  .char-modal-media{
    width:100%;
    height:160px;
  }
  #char-modal-emoji{ font-size:72px; }
  .char-modal-body{ padding:24px 20px; }
  .char-modal-header h3{ font-size:22px; }
  .char-modal-scene p{ font-size:15px; }
}

/* ============================================================= */
/* NSFW PASSWORD GATE                                            */
/* ============================================================= */

#nsfw-gate-overlay{
  display:none;
  position:fixed;
  inset:0;
  background: rgba(63,43,34,.55);
  backdrop-filter: blur(4px);
  z-index:9998;
  align-items:center;
  justify-content:center;
}

#nsfw-gate-overlay.show{
  display:flex;
}

.nsfw-gate-card{
  background: var(--ink-2);
  border: 2px solid var(--brown-mid);
  border-radius:24px;
  padding:50px 40px;
  max-width:550px;
  width:90%;
  text-align:center;
  box-shadow: 0 20px 40px rgba(0,0,0,0.3);
  animation: slideUp 0.4s ease;
  position:relative;
}

.nsfw-gate-close{
  position:absolute;
  top:14px; right:14px;
  width:32px; height:32px;
  border-radius:50%;
  border:none;
  background: rgba(63,43,34,.15);
  color: var(--cream-2);
  font-size:14px;
  cursor:pointer;
  z-index:2;
  display:flex;
  align-items:center;
  justify-content:center;
  transition: background .2s;
}
.nsfw-gate-close:hover{ 
  background: rgba(63,43,34,.3); 
}

@keyframes slideUp{
  from{
    opacity:0;
    transform: translateY(20px);
  }
  to{
    opacity:1;
    transform: translateY(0);
  }
}

.nsfw-gate-icon{
  font-size:48px;
  margin-bottom:20px;
}

.nsfw-gate-title{
  color: var(--gold);
  font-family:'Lora', serif;
  font-size:28px;
  font-weight:bold;
  letter-spacing:1px;
  margin:0 0 15px 0;
}

.nsfw-gate-subtitle{
  color: var(--rust);
  font-size:15px;
  line-height:1.6;
  margin:0 0 30px 0;
}

.nsfw-gate-form{
  display:flex;
  flex-direction:column;
  gap:15px;
  width:100%;
}

.nsfw-gate-input{
  padding:16px 20px;
  border-radius:12px;
  border:1px solid var(--brown-mid);
  background: var(--ink);
  color: var(--cream);
  font-size:16px;
  text-align:center;
  outline:none;
  transition: border 0.3s ease, background 0.3s ease;
  font-family:'Be Vietnam Pro', sans-serif;
}

.nsfw-gate-input:focus{
  border-color: var(--gold);
  background: rgba(255,246,232,0.05);
}

.nsfw-gate-button{
  padding:16px 20px;
  border-radius:12px;
  border:none;
  background: var(--gold);
  color: var(--ink-2);
  font-size:16px;
  font-weight:bold;
  cursor:pointer;
  transition: transform 0.2s ease, background-color 0.2s ease;
  font-family:'Be Vietnam Pro', sans-serif;
}

.nsfw-gate-button:hover{
  background: var(--cream-2);
  transform: translateY(-2px);
}

.nsfw-gate-button:active{
  transform: translateY(0);
}

.nsfw-gate-error{
  color: #ff6b6b;
  font-size:14px;
  margin-top:15px;
  font-weight:bold;
  animation: shake 0.3s ease;
}

@keyframes shake{
  0%, 100%{transform: translateX(0);}
  25%{transform: translateX(-5px);}
  75%{transform: translateX(5px);}
}

@media (max-width: 600px){
  .nsfw-gate-card{
    padding:40px 30px;
    border-radius:18px;
  }
  .nsfw-gate-title{font-size:24px;}
  .nsfw-gate-subtitle{font-size:14px;}
  .nsfw-gate-input, .nsfw-gate-button{
    font-size:15px;
    padding:14px 16px;
  }
}
