
  :root{
    --bg-deep:#13102A;
    --bg-panel:#1F1A40;
    --bg-panel-2:#251F4D;
    --text-primary:#EDE7F6;
    --text-muted:#A89BC4;
    --accent-gold:#E8C896;
    /* softer, layered depth (premium look) */
    --line:rgba(237,231,245,0.06);
    --line-strong:rgba(237,231,245,0.13);
    --panel-glass:rgba(33,28,68,0.55);
    --shadow-card:0 14px 44px rgba(8,5,26,0.40);
    --shadow-soft:0 8px 24px rgba(8,5,26,0.28);
    --glow-gold:rgba(232,200,150,0.22);
    --radius:20px;
  }
  *{box-sizing:border-box;}
  body{
    margin:0; min-height:100vh; color:var(--text-primary);
    font-family:'Noto Sans JP', 'Noto Sans SC', sans-serif; font-weight:300;
    font-size:16px; line-height:1.65; position:relative; overflow-x:hidden;
    background:
      radial-gradient(125% 80% at 50% -12%, rgba(150,130,230,0.18), transparent 55%),
      radial-gradient(90% 60% at 85% 115%, rgba(91,127,181,0.12), transparent 60%),
      linear-gradient(180deg, #13102A 0%, #0E0B22 100%);
    background-attachment:fixed;
  }
  /* faint film-grain / noise texture for depth */
  body::before{
    content:""; position:fixed; inset:0; z-index:0; pointer-events:none; opacity:0.04;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  }
  .fog{position:fixed;border-radius:50%;filter:blur(70px);z-index:0;pointer-events:none;opacity:0.45;}
  .fog-1{width:440px;height:440px;background:radial-gradient(circle, #6F5FB0 0%, transparent 70%);top:-130px;left:-110px;animation:drift1 26s ease-in-out infinite;}
  .fog-2{width:480px;height:480px;background:radial-gradient(circle, #5B7FB5 0%, transparent 70%);bottom:-160px;right:-120px;animation:drift2 32s ease-in-out infinite;}
  .fog-3{width:300px;height:300px;background:radial-gradient(circle, var(--accent-gold) 0%, transparent 70%);top:38%;left:62%;opacity:0.22;animation:drift3 38s ease-in-out infinite;}
  @keyframes drift1{0%,100%{transform:translate(0,0) scale(1);}50%{transform:translate(60px,40px) scale(1.15);}}
  @keyframes drift2{0%,100%{transform:translate(0,0) scale(1);}50%{transform:translate(-50px,-30px) scale(1.1);}}
  @keyframes drift3{0%,100%{transform:translate(0,0) scale(1);}50%{transform:translate(-40px,30px) scale(1.2);}}
  @media (prefers-reduced-motion: reduce){.fog{animation:none;}}

  .wrap{position:relative;z-index:1;max-width:660px;margin:0 auto;padding:60px 22px 96px;}

  .lang-switch{position:absolute;top:18px;right:20px;z-index:30;}
  .lang-chip{display:flex;align-items:center;gap:5px;background:rgba(255,255,255,0.05);border:1px solid var(--line);color:var(--text-muted);border-radius:999px;padding:5px 12px;font-size:12px;cursor:pointer;font-family:'Noto Sans JP','Noto Sans SC',sans-serif;transition:all .15s;}
  .lang-chip:hover{color:var(--text-primary);border-color:var(--accent-gold);}
  .lang-menu{position:absolute;top:calc(100% + 6px);right:0;display:none;flex-direction:column;background:var(--bg-panel);border:1px solid var(--line-strong);border-radius:12px;padding:5px;min-width:108px;box-shadow:var(--shadow-card);}
  .lang-switch.open .lang-menu{display:flex;}
  .lang-opt{background:none;border:none;color:var(--text-muted);text-align:left;padding:8px 12px;border-radius:8px;font-size:13px;cursor:pointer;font-family:'Noto Sans JP','Noto Sans SC',sans-serif;white-space:nowrap;transition:all .12s;}
  .lang-opt:hover{background:rgba(232,200,150,0.10);color:var(--text-primary);}
  .lang-opt.active{color:var(--accent-gold);font-weight:600;}

  header{text-align:center;margin-bottom:40px;padding-top:12px;}
  .logo-mark{width:92px;height:92px;border-radius:50%;display:block;margin:0 auto 22px;filter:drop-shadow(0 0 30px rgba(150,130,230,0.5));}
  .eyebrow{font-family:'Noto Serif JP','Noto Serif SC',serif;font-size:19px;letter-spacing:0.18em;color:var(--text-primary);margin-bottom:18px;font-weight:700;text-shadow:0 0 22px rgba(150,130,230,0.32);}
  h1{font-family:'Noto Serif JP','Noto Serif SC', serif;font-weight:700;font-size:32px;line-height:1.3;margin:0 0 16px;letter-spacing:0.02em;color:var(--accent-gold);text-shadow:0 0 36px rgba(232,200,150,0.30);}
  .sub{color:var(--text-muted);font-size:14.5px;line-height:1.85;max-width:440px;margin:0 auto;}

  nav.tabs{display:flex;justify-content:center;gap:4px;margin-bottom:36px;border-bottom:1px solid var(--line);flex-wrap:wrap;}
  .tab-btn{
    background:none;border:none;color:var(--text-muted);font-family:'Noto Sans JP','Noto Sans SC',sans-serif;
    font-size:14px;padding:11px 16px;cursor:pointer;border-bottom:2px solid transparent;transition:color .2s, border-color .2s;position:relative;top:1px;
  }
  .tab-btn.active{color:var(--text-primary);border-bottom-color:var(--accent-gold);font-weight:500;}
  .tab-btn:hover{color:var(--text-primary);}
  .tab-panel{display:none;}
  .tab-panel.active{display:block;animation:fadeUp .4s ease;}
  @keyframes fadeUp{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:none;}}

  .card{background:var(--panel-glass);border:1px solid var(--line);border-radius:var(--radius);padding:30px;margin-bottom:22px;box-shadow:var(--shadow-card);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);}
  label.field-label{display:block;font-size:13px;color:var(--text-muted);margin-bottom:10px;letter-spacing:0.04em;}
  textarea{
    width:100%;min-height:110px;background:var(--bg-deep);border:1px solid var(--line);border-radius:12px;
    color:var(--text-primary);font-family:'Noto Sans JP','Noto Sans SC', sans-serif;font-size:15px;line-height:1.7;
    padding:14px 16px;resize:vertical;outline:none;transition:border-color .2s;
  }
  textarea::placeholder{color:rgba(168,155,196,0.55);}
  textarea:focus{border-color:var(--accent-gold);}
  .counter{text-align:right;font-size:12px;color:var(--text-muted);margin-top:6px;}
  .dream-date{background:var(--bg-deep);border:1px solid var(--line);border-radius:10px;color:var(--text-primary);font-size:14px;padding:9px 13px;outline:none;font-family:'Noto Sans JP','Noto Sans SC',sans-serif;color-scheme:dark;}
  .dream-date:focus{border-color:var(--accent-gold);}

  .perspectives{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:12px;}
  .p-card{
    border:1px solid var(--line);border-radius:16px;padding:16px;cursor:pointer;
    transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease, background .2s ease;
    background:rgba(19,16,42,0.5);box-shadow:var(--shadow-soft);
  }
  .p-card:hover{border-color:rgba(237,231,245,0.22);transform:translateY(-2px);box-shadow:0 14px 34px rgba(8,5,26,0.4);}
  .p-card .mark{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;margin-bottom:8px;background:var(--accent-soft);color:var(--accent);}
  .p-card .p-title{font-family:'Noto Serif JP','Noto Serif SC', serif;font-weight:700;font-size:15px;margin-bottom:3px;transition:color .2s;}
  .p-card .p-desc{font-size:11.5px;color:var(--text-muted);line-height:1.5;}
  .p-card.selected{border-color:var(--accent);background:var(--accent-soft);}
  .p-card.selected .p-title{color:var(--accent);}

  .actions{margin-top:26px;text-align:center;}
  button.primary{
    background:linear-gradient(135deg,#F0D6A8,#E8C896);color:#1A1330;border:none;border-radius:999px;padding:14px 38px;
    font-size:15px;font-weight:600;font-family:'Noto Sans JP','Noto Sans SC', sans-serif;cursor:pointer;
    box-shadow:0 6px 20px rgba(232,200,150,0.18);transition:transform .2s ease, box-shadow .2s ease, opacity .2s;
  }
  button.primary:disabled{opacity:0.3;cursor:not-allowed;box-shadow:none;}
  button.primary:not(:disabled):hover{transform:translateY(-2px) scale(1.02);box-shadow:0 12px 32px rgba(232,200,150,0.38);}
  button.ghost{
    background:rgba(237,231,245,0.03);border:1px solid var(--line-strong);color:var(--text-muted);border-radius:999px;
    padding:10px 22px;font-size:13px;cursor:pointer;font-family:'Noto Sans JP','Noto Sans SC', sans-serif;margin:4px;transition:all .2s ease;
  }
  button.ghost:hover{color:var(--text-primary);border-color:rgba(232,200,150,0.45);background:rgba(232,200,150,0.06);transform:translateY(-1px);}

  .state{text-align:center;padding:26px 10px;color:var(--text-muted);font-size:14px;display:none;}
  .state.show{display:block;}
  .loader-ring{width:42px;height:42px;margin:0 auto 14px;border-radius:50%;border:2px solid rgba(232,200,150,0.25);border-top-color:var(--accent-gold);animation:spin 1.1s linear infinite;}
  @keyframes spin{to{transform:rotate(360deg);}}

  .result{display:none;}
  .result.show{display:block;}
  .result-head{display:flex;align-items:center;gap:10px;margin-bottom:6px;padding-bottom:14px;border-bottom:1px solid var(--line);}
  .result-head .mark{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:15px;background:var(--accent-soft);color:var(--accent);}
  .result-head .name{font-family:'Noto Serif JP','Noto Serif SC', serif;font-weight:700;font-size:17px;flex:1;color:var(--accent);}
  .emo-chip{font-size:11.5px;padding:4px 10px;border-radius:999px;background:rgba(237,231,245,0.08);color:var(--text-muted);}
  .result-body{font-size:14.5px;line-height:1.85;color:var(--text-primary);white-space:pre-wrap;margin-top:14px;}

  .plus-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin-top:18px;padding-top:16px;border-top:1px solid var(--line);}

  .image-box{margin-top:16px;text-align:center;display:none;}
  .image-box.show{display:block;}
  .image-box svg,.image-box .dream-img{width:100%;max-width:320px;border-radius:14px;}

  .card-preview{margin-top:16px;text-align:center;display:none;}
  .card-preview.show{display:block;}
  .card-preview canvas{max-width:100%;border-radius:12px;}
  .card-preview a.dl{display:inline-block;margin-top:10px;font-size:13px;color:var(--accent-gold);text-decoration:none;border-bottom:1px dotted var(--accent-gold);}

  .disclaimer{margin-top:18px;font-size:11.5px;color:var(--text-muted);line-height:1.6;border-top:1px solid var(--line);padding-top:14px;}

  .next-steps{margin-top:18px;padding-top:16px;border-top:1px solid var(--line);}
  .next-steps .ns-title{font-size:13px;color:var(--accent-gold);font-weight:600;letter-spacing:0.04em;margin-bottom:12px;}
  .next-steps .ns-grid{display:flex;flex-direction:column;gap:8px;}
  .next-steps .ns-card{display:flex;gap:12px;align-items:flex-start;border:1px dashed rgba(237,231,245,0.16);border-radius:12px;padding:12px 14px;background:rgba(237,231,245,0.02);transition:border-color .2s;}
  .next-steps .ns-card:hover{border-color:rgba(232,200,150,0.4);}
  .next-steps .ns-icon{font-size:19px;line-height:1.3;flex-shrink:0;}
  .next-steps .ns-name{font-size:13.5px;color:var(--text-primary);font-weight:600;display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
  .next-steps .ns-badge{font-size:10px;color:var(--accent-gold);border:1px solid rgba(232,200,150,0.4);border-radius:999px;padding:1px 8px;font-weight:400;letter-spacing:0.02em;}
  .next-steps .ns-badge-ready{color:#88C8A0;border-color:rgba(136,200,160,0.5);}
  .next-steps .ns-desc{font-size:11.5px;color:var(--text-muted);line-height:1.5;margin-top:3px;}
  .next-steps .ns-card-ready{cursor:pointer;border-style:solid;border-color:rgba(136,200,160,0.35);}
  .next-steps .ns-card-ready:hover{border-color:rgba(136,200,160,0.7);background:rgba(136,200,160,0.06);}

  .error-box{color:#E08A8A;font-size:13.5px;text-align:center;padding:18px 10px;display:none;}
  .error-box.show{display:block;}

  .feedback{margin-top:18px;text-align:center;display:none;}
  .feedback.show{display:block;}
  .feedback p{font-size:12px;color:var(--text-muted);margin-bottom:8px;}
  .feedback .opts{display:flex;gap:8px;justify-content:center;}
  .feedback button.fb{background:transparent;border:1px solid var(--line);color:var(--text-muted);border-radius:999px;padding:7px 14px;font-size:12.5px;cursor:pointer;font-family:'Noto Sans JP','Noto Sans SC', sans-serif;transition:all .15s;}
  .feedback button.fb:hover{border-color:var(--accent-gold);color:var(--text-primary);}
  .feedback .thanks{font-size:12.5px;color:var(--accent-gold);}

  .history-item{border:1px solid var(--line);border-radius:14px;padding:16px;margin-bottom:12px;cursor:pointer;}
  .history-item .h-top{display:flex;align-items:center;gap:8px;margin-bottom:6px;}
  .history-item .h-dot{width:8px;height:8px;border-radius:50%;}
  .history-item .h-name{font-size:12.5px;color:var(--text-muted);flex:1;}
  .history-item .h-date{font-size:11px;color:var(--text-muted);}
  .history-item .h-excerpt{font-size:14px;color:var(--text-primary);line-height:1.6;}
  .history-item .h-full{display:none;margin-top:10px;font-size:13.5px;color:var(--text-primary);line-height:1.8;white-space:pre-wrap;border-top:1px solid var(--line);padding-top:10px;}
  .history-item.open .h-full{display:block;}

  /* grouped history: one card per dream, multiple perspective readings inside */
  .history-group{border:1px solid var(--line);border-radius:14px;padding:14px 16px;margin-bottom:12px;}
  .history-group .hg-top{display:flex;align-items:center;gap:10px;cursor:pointer;}
  .history-group .hg-seq{font-size:12px;color:var(--accent-gold);font-weight:500;font-variant-numeric:tabular-nums;flex-shrink:0;min-width:24px;}
  .history-group .hg-dream{font-size:14px;font-weight:400;color:var(--text-primary);line-height:1.5;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
  .history-group .hg-marks{display:flex;gap:4px;flex-shrink:0;}
  .history-group .hg-marks .m{width:8px;height:8px;border-radius:50%;}
  .history-group .hg-date{font-size:11px;color:var(--text-muted);flex-shrink:0;}
  .history-group .hg-body{display:none;margin-top:12px;}
  .history-group.open .hg-body{display:block;}
  .history-group .hg-fulldream{font-size:13.5px;color:var(--text-primary);line-height:1.8;white-space:pre-wrap;background:rgba(237,231,245,0.04);border-left:2px solid rgba(232,200,150,0.55);border-radius:0 10px 10px 0;padding:12px 14px;margin-bottom:4px;}
  .history-group .hg-reading{border-top:1px solid var(--line);padding-top:12px;margin-top:12px;}
  .history-group .hr-top{display:flex;align-items:center;gap:8px;cursor:pointer;}
  .history-group .hr-top .h-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;}
  .history-group .hr-name{font-size:12.5px;color:var(--text-muted);flex:1;}
  .history-group .hr-pname{font-weight:700;font-size:13.5px;}
  .history-group .hr-caret{font-size:10px;color:var(--text-muted);transition:transform .15s;flex-shrink:0;}
  .history-group .hg-reading.open .hr-caret{transform:rotate(180deg);}
  .history-group .hr-body{display:none;font-size:13.5px;color:var(--text-primary);line-height:1.8;white-space:pre-wrap;margin-top:8px;}
  .history-group .hg-reading.open .hr-body{display:block;}
  .history-group .hg-caret{font-size:11px;color:var(--text-muted);transition:transform .15s;flex-shrink:0;}
  .history-group.open .hg-caret{transform:rotate(90deg);}
  .history-group .hr-del,.history-group .hg-del{background:none;border:1px solid var(--line);color:var(--text-muted);font-size:11px;padding:3px 10px;border-radius:8px;cursor:pointer;flex-shrink:0;}
  .history-group .hr-del:hover,.history-group .hg-del:hover{border-color:#E08A8A;color:#E08A8A;}

  /* calendar (my records) */
  .cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
  .cal-title{font-family:'Noto Serif JP','Noto Serif SC',serif;font-weight:600;font-size:15px;color:var(--text-primary);letter-spacing:0.04em;}
  .cal-nav{background:transparent;border:1px solid var(--line);color:var(--text-muted);width:32px;height:32px;border-radius:50%;cursor:pointer;font-size:17px;line-height:1;transition:all .15s;}
  .cal-nav:hover{color:var(--text-primary);border-color:var(--accent-gold);}
  .cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;}
  .cal-wdrow{margin-bottom:6px;}
  .cal-wd{text-align:center;font-size:11px;color:var(--text-muted);padding:4px 0;}
  .cal-cell{position:relative;aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;font-size:13px;color:var(--text-muted);border-radius:10px;transition:background .15s;}
  .cal-empty{visibility:hidden;}
  .cal-cell.today{color:var(--text-primary);box-shadow:inset 0 0 0 1px var(--line);}
  .cal-cell.has{color:var(--text-primary);cursor:pointer;background:rgba(232,200,150,0.08);}
  .cal-cell.has:hover{background:rgba(232,200,150,0.18);}
  .cal-cell.sel{background:var(--accent-gold);color:#1A1330;font-weight:600;}
  .cal-dot{position:absolute;bottom:5px;left:50%;transform:translateX(-50%);width:5px;height:5px;border-radius:50%;background:var(--accent-gold);}
  .cal-cell.sel .cal-dot{background:#1A1330;}
  #dayDetail{margin-top:18px;}

  /* dream book */
  .db-card{text-align:center;}
  .db-title{font-family:'Noto Serif JP','Noto Serif SC',serif;font-weight:700;font-size:22px;color:var(--accent-gold);margin-bottom:8px;text-shadow:0 0 24px rgba(232,200,150,0.25);}
  .db-desc{font-size:13px;color:var(--text-muted);line-height:1.7;margin-bottom:22px;}
  .db-squares{display:flex;flex-wrap:wrap;gap:7px;justify-content:center;max-width:330px;margin:0 auto 16px;}
  .db-sq{width:22px;height:22px;border-radius:5px;border:1px solid var(--line);background:rgba(237,231,245,0.03);}
  .db-sq.on{background:linear-gradient(135deg,rgba(155,138,210,0.85),var(--accent-gold));border-color:transparent;}
  .db-sq-mile{box-shadow:0 0 0 2px var(--accent-gold);}
  .db-count{font-size:15px;color:var(--text-primary);font-weight:600;font-variant-numeric:tabular-nums;margin-bottom:18px;}
  .db-status{font-size:13px;color:var(--text-muted);}
  .db-status.done{color:#88C8A0;margin-bottom:14px;}
  .db-chapter .db-ch-head{display:flex;align-items:baseline;gap:10px;margin-bottom:10px;}
  .db-chapter .db-ch-no{font-family:'Noto Serif JP','Noto Serif SC',serif;font-weight:700;font-size:15px;color:var(--accent-gold);}
  .db-chapter .db-ch-range{font-size:11.5px;color:var(--text-muted);}
  .db-chapter .db-story-text{font-size:14px;line-height:1.95;color:var(--text-primary);white-space:pre-wrap;margin-bottom:12px;}
  .db-chapter .db-story-actions{display:flex;gap:8px;flex-wrap:wrap;}
  .db-gen{display:inline-flex;align-items:center;gap:7px;}
  .db-gen .ns-badge{font-size:10px;background:rgba(26,19,48,0.18);border:1px solid rgba(26,19,48,0.3);color:#1A1330;border-radius:999px;padding:1px 8px;font-weight:500;}

  .empty-state{text-align:center;color:var(--text-muted);font-size:13.5px;padding:40px 10px;}

  .trend-range{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px;}
  .trend-range .tr-btn{background:transparent;border:1px solid var(--line);color:var(--text-muted);border-radius:999px;padding:5px 12px;font-size:11.5px;cursor:pointer;font-family:'Noto Sans JP','Noto Sans SC',sans-serif;transition:all .15s;}
  .trend-range .tr-btn.active{color:var(--text-primary);border-color:var(--accent-gold);background:rgba(232,200,150,0.12);}
  .trend-range .tr-btn:hover{color:var(--text-primary);}

  .trend-row{display:flex;align-items:center;gap:10px;margin-bottom:14px;}
  .trend-label{width:76px;font-size:13px;color:var(--text-primary);font-weight:400;flex-shrink:0;}
  .trend-bar-bg{flex:1;height:10px;background:rgba(237,231,245,0.06);border-radius:6px;overflow:hidden;}
  .trend-bar-fill{height:100%;border-radius:6px;background:linear-gradient(90deg,rgba(155,138,210,0.7),var(--accent-gold));}
  .trend-count{width:30px;text-align:right;font-size:12.5px;color:var(--accent-gold);font-variant-numeric:tabular-nums;}

  .pick-item{display:flex;align-items:flex-start;gap:10px;border:1px solid var(--line);border-radius:12px;padding:12px;margin-bottom:8px;cursor:pointer;transition:all .15s;}
  .pick-item:hover{border-color:rgba(237,231,245,0.25);}
  .pick-item.selected{border-color:var(--accent-gold);background:rgba(232,200,150,0.08);}
  .pick-item input{margin-top:3px;pointer-events:none;}
  .pick-item .pi-meta{font-size:11px;color:var(--accent-gold);font-weight:500;margin-bottom:4px;font-variant-numeric:tabular-nums;}
  .pick-item .pi-text{font-size:13.5px;color:var(--text-primary);line-height:1.6;}

  /* create picker: selected chips + search + load more */
  .create-selected:not(:empty){margin-bottom:12px;}
  .create-selected .sel-count{font-size:12px;color:var(--accent-gold);font-weight:500;margin-bottom:8px;}
  .create-selected .sel-chips{display:flex;flex-wrap:wrap;gap:6px;}
  .create-selected .sel-chip{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--text-primary);background:rgba(232,200,150,0.12);border:1px solid rgba(232,200,150,0.4);border-radius:999px;padding:4px 10px;cursor:pointer;transition:all .15s;}
  .create-selected .sel-chip:hover{border-color:#E08A8A;}
  .create-selected .chip-x{color:var(--text-muted);font-weight:400;}
  .create-selected .sel-chip:hover .chip-x{color:#E08A8A;}
  .create-search{width:100%;background:var(--bg-deep);border:1px solid var(--line);border-radius:10px;color:var(--text-primary);font-size:13.5px;padding:10px 13px;outline:none;margin-bottom:12px;font-family:'Noto Sans JP','Noto Sans SC',sans-serif;transition:border-color .2s;}
  .create-search:focus{border-color:var(--accent-gold);}
  .create-search::placeholder{color:rgba(168,155,196,0.5);}
  .create-more{width:100%;margin:4px 0 0;}

  /* date-grouped table of contents (create picker + dream book) */
  .toc-day{font-size:11.5px;color:var(--accent-gold);font-weight:600;letter-spacing:0.04em;margin:14px 0 6px;}
  .toc-day:first-child{margin-top:0;}
  .pick-item.toc-item{align-items:center;}
  .pick-item.toc-item .pi-text{font-size:14px;}
  .db-toc{margin-top:16px;}
  .db-toc .db-toc-head{font-family:'Noto Serif JP','Noto Serif SC',serif;font-weight:700;font-size:15px;color:var(--text-primary);margin-bottom:14px;letter-spacing:0.04em;}
  .db-toc .toc-line{display:flex;align-items:baseline;gap:10px;padding:7px 0;border-bottom:1px solid var(--line);}
  .db-toc .toc-line:last-child{border-bottom:none;}
  .db-toc .toc-no{font-size:11px;color:var(--text-muted);font-variant-numeric:tabular-nums;min-width:20px;}
  .db-toc .toc-t{font-size:13.5px;color:var(--text-primary);}

  .scene-card{border:1px solid var(--line);border-radius:14px;padding:16px;margin-bottom:12px;}
  .scene-card .s-title{font-family:'Noto Serif JP','Noto Serif SC',serif;font-weight:700;font-size:15px;margin-bottom:6px;}
  .scene-card .s-narration{font-size:13.5px;color:var(--text-muted);line-height:1.7;margin-bottom:10px;}
  .scene-card .s-loading{font-size:12px;color:var(--text-muted);display:none;}
  .scene-card .s-loading.show{display:block;}
  .scene-card .s-image{display:none;}
  .scene-card .s-image.show{display:block;text-align:center;}
  .scene-card .s-image svg,.scene-card .s-image .dream-img{width:100%;max-width:240px;border-radius:10px;}
  /* per-scene editor (video flow) */
  .scene-card .s-flabel{display:block;font-size:11px;color:var(--text-muted);letter-spacing:0.04em;margin:10px 0 5px;}
  .scene-card .s-prompt{width:100%;background:var(--bg-deep);border:1px solid var(--line);border-radius:10px;color:var(--text-primary);font-size:13px;line-height:1.6;padding:9px 12px;outline:none;resize:vertical;font-family:'Noto Sans JP','Noto Sans SC',sans-serif;transition:border-color .2s;}
  .scene-card .s-prompt:focus{border-color:var(--accent-gold);}
  .scene-card .s-row{display:flex;align-items:center;gap:8px;margin-top:10px;flex-wrap:wrap;}
  .scene-card .s-row .s-flabel{margin:0;}
  .scene-card .s-duration{background:var(--bg-deep);border:1px solid var(--line);color:var(--text-primary);border-radius:8px;padding:6px 10px;font-size:12.5px;outline:none;cursor:pointer;}
  .scene-card .s-genvideo{margin-left:auto;}
  .scene-card .s-video{margin-top:10px;}
  .scene-card .s-video-stub{font-size:12px;color:var(--text-muted);background:rgba(237,231,245,0.03);border:1px dashed rgba(237,231,245,0.16);border-radius:10px;padding:14px;text-align:center;}
  .scene-card .s-video-el{width:100%;max-width:360px;border-radius:10px;display:block;margin:0 auto;}
  .scene-card .s-head{display:flex;align-items:center;gap:8px;}
  .scene-card .s-head .s-title{flex:1;margin-bottom:0;}
  .scene-card .s-no{font-size:12px;color:var(--accent-gold);font-weight:600;flex-shrink:0;}
  .scene-card .s-title-in{flex:1;min-width:0;background:transparent;border:none;border-bottom:1px solid var(--line);color:var(--text-primary);font-family:'Noto Serif JP','Noto Serif SC',serif;font-weight:600;font-size:14.5px;padding:2px 0;outline:none;}
  .scene-card .s-title-in:focus{border-color:var(--accent-gold);}
  .scene-card .s-narr,.scene-card .s-prompt{width:100%;background:var(--bg-deep);border:1px solid var(--line);border-radius:10px;color:var(--text-primary);font-size:13px;line-height:1.6;padding:9px 12px;outline:none;resize:vertical;font-family:'Noto Sans JP','Noto Sans SC',sans-serif;transition:border-color .2s;}
  .scene-card .s-narr:focus,.scene-card .s-prompt:focus{border-color:var(--accent-gold);}
  .s-addscene{width:100%;border-style:dashed;}
  .scene-card .s-del{background:none;border:1px solid var(--line);color:var(--text-muted);width:24px;height:24px;border-radius:7px;cursor:pointer;font-size:12px;line-height:1;flex-shrink:0;}
  .scene-card .s-del:hover{border-color:#E08A8A;color:#E08A8A;}
  .scene-card .s-duration{width:64px;background:var(--bg-deep);border:1px solid var(--line);color:var(--text-primary);border-radius:8px;padding:6px 8px;font-size:12.5px;outline:none;}
  .scene-card .s-unit{font-size:11px;color:var(--text-muted);}
  .scene-card .s-video-actions{display:flex;gap:8px;justify-content:center;margin-top:8px;flex-wrap:wrap;}
  .film-result:not(:empty){margin-top:14px;text-align:center;}
  .film-result .s-video-el{width:100%;max-width:420px;border-radius:12px;display:block;margin:0 auto;}
  .film-result .s-video-actions{display:flex;gap:8px;justify-content:center;margin-top:10px;flex-wrap:wrap;}
  .film-result .s-video-stub{font-size:12.5px;color:var(--text-muted);background:rgba(237,231,245,0.03);border:1px dashed rgba(237,231,245,0.16);border-radius:10px;padding:16px;text-align:center;}

  /* image lightbox */
  .img-lightbox{position:fixed;inset:0;background:rgba(8,5,20,0.92);z-index:120;display:none;align-items:center;justify-content:center;padding:24px;cursor:zoom-out;}
  .img-lightbox.show{display:flex;}
  .img-lightbox img{max-width:92vw;max-height:88vh;border-radius:12px;box-shadow:0 20px 60px rgba(0,0,0,0.5);}
  .img-lightbox .il-close{position:absolute;top:18px;right:22px;font-size:22px;color:rgba(237,231,245,0.8);cursor:pointer;}

  /* character panel */
  #characterPanel{border:1px solid var(--line);border-radius:14px;padding:14px;margin-bottom:16px;background:rgba(237,231,245,0.02);}
  #characterPanel .char-head{font-family:'Noto Serif JP','Noto Serif SC',serif;font-weight:700;font-size:15px;color:var(--text-primary);margin-bottom:4px;}
  #characterPanel .char-hint{font-size:11.5px;color:var(--text-muted);line-height:1.5;margin-bottom:10px;}
  /* style library bar */
  #styleBar{margin-bottom:16px;}
  #styleBar .style-title{font-size:12px;color:var(--text-muted);letter-spacing:0.04em;margin-bottom:8px;}
  #styleBar .style-chips{display:flex;flex-wrap:wrap;gap:7px;}
  #styleBar .style-chip{background:transparent;border:1px solid var(--line);color:var(--text-muted);border-radius:999px;padding:6px 13px;font-size:12px;cursor:pointer;font-family:'Noto Sans JP','Noto Sans SC',sans-serif;transition:all .15s;}
  #styleBar .style-chip.active{color:var(--text-primary);border-color:var(--accent-gold);background:rgba(232,200,150,0.12);}
  #styleBar .style-chip:hover{color:var(--text-primary);}

  #characterPanel .char-cards{display:flex;flex-direction:column;gap:10px;margin-bottom:10px;}
  #characterPanel .char-card{display:flex;gap:10px;border:1px solid var(--line);border-radius:12px;padding:10px;background:var(--bg-deep);}
  #characterPanel .char-card.primary{border-color:var(--accent-gold);}
  #characterPanel .cc-thumb{position:relative;width:96px;height:128px;border-radius:12px;overflow:hidden;flex-shrink:0;background:rgba(237,231,245,0.05);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-soft);}
  #characterPanel .cc-thumb img{width:100%;height:100%;object-fit:cover;display:block;}
  #characterPanel .cc-thumb.has{cursor:zoom-in;}
  #characterPanel .cc-thumb .cc-zoom{position:absolute;right:3px;bottom:3px;font-size:11px;color:#fff;background:rgba(0,0,0,0.45);border-radius:5px;padding:0 4px;}
  #characterPanel .cc-ph{font-size:24px;opacity:0.5;}
  #characterPanel .cc-body{flex:1;min-width:0;}
  #characterPanel .cc-role{width:100%;background:transparent;border:none;border-bottom:1px solid var(--line);color:var(--text-primary);font-size:13.5px;font-weight:600;padding:2px 0;margin-bottom:6px;outline:none;}
  #characterPanel .cc-role:focus{border-color:var(--accent-gold);}
  #characterPanel .cc-prompt{width:100%;background:var(--bg-panel);border:1px solid var(--line);border-radius:8px;color:var(--text-primary);font-size:12.5px;line-height:1.5;padding:7px 9px;outline:none;resize:vertical;font-family:'Noto Sans JP','Noto Sans SC',sans-serif;}
  #characterPanel .cc-prompt:focus{border-color:var(--accent-gold);}
  #characterPanel .cc-actions{display:flex;gap:6px;flex-wrap:wrap;margin-top:7px;}
  #characterPanel .cc-actions .ghost{padding:5px 12px;font-size:11.5px;margin:0;}
  #characterPanel .char-add{width:100%;}

  .player-overlay{position:fixed;inset:0;background:rgba(10,7,24,0.85);z-index:50;display:none;align-items:center;justify-content:center;padding:24px;}
  .player-overlay.show{display:flex;}
  .player-box{background:var(--bg-panel);border:1px solid var(--line);border-radius:18px;padding:24px;max-width:360px;width:100%;text-align:center;}
  .player-image{min-height:200px;display:flex;align-items:center;justify-content:center;transition:opacity .3s;}
  .player-image svg,.player-image .dream-img{width:100%;max-width:260px;border-radius:14px;}
  .player-narration{margin-top:14px;font-size:14px;line-height:1.8;color:var(--text-primary);min-height:60px;}
  .player-controls{display:flex;gap:8px;justify-content:center;margin-top:14px;flex-wrap:wrap;}

  footer{text-align:center;margin-top:26px;}
  footer a{font-size:11px;color:var(--text-muted);text-decoration:none;border-bottom:1px dotted rgba(168,155,196,0.4);cursor:pointer;}
  .stats-box{margin-top:12px;font-size:12px;color:var(--text-muted);display:none;}
  .stats-box.show{display:block;}

  /* tablets / large phones: tighten the tab row so 5 tabs fit on one line */
  @media (max-width:600px){
    .wrap{padding:66px 18px 64px;}
    nav.tabs{gap:0;}
    .tab-btn{font-size:13px;padding:10px 11px;}
  }

  @media (max-width:480px){
    h1{font-size:22px;}
    .eyebrow{font-size:16px;letter-spacing:0.12em;}
    .sub{font-size:13px;line-height:1.7;}
    .wrap{padding:72px 16px 56px;}
    .perspectives{grid-template-columns:1fr 1fr;}
    .logo-mark{width:72px;height:72px;margin-bottom:16px;}
    header{margin-bottom:28px;}
    /* top bars: shrink + free up room so the badge can't collide with the lang switch */
    .lang-switch{top:13px;right:12px;}
    .lang-chip{padding:4px 10px;font-size:11px;}
    .user-badge{top:13px;left:12px;gap:6px;}
    .user-name{display:none;}
    .points-pill,.recharge-pill{margin-left:0;padding:4px 9px;font-size:11px;}
    nav.tabs{margin-bottom:26px;}
    .tab-btn{font-size:12.5px;padding:9px 8px;}
  }

  /* ===== AUTH OVERLAY ===== */
  .auth-overlay{
    position:fixed;inset:0;background:var(--bg-deep);z-index:100;
    display:flex;align-items:center;justify-content:center;padding:24px;
  }
  .auth-overlay.hidden{display:none;}
  .auth-box{
    background:var(--bg-panel);border:1px solid var(--line);border-radius:22px;
    padding:36px 32px;max-width:380px;width:100%;text-align:center;position:relative;
  }
  .auth-box .auth-logo{width:72px;height:72px;border-radius:50%;margin:0 auto 16px;display:block;filter:drop-shadow(0 0 18px rgba(150,130,230,0.45));}
  .auth-box h2{font-family:'Noto Serif JP','Noto Serif SC',serif;font-size:28px;font-weight:700;color:var(--accent-gold);margin:0 0 6px;letter-spacing:0.04em;text-shadow:0 0 26px rgba(232,200,150,0.28);}
  .auth-box .auth-sub{font-size:13px;color:var(--text-muted);margin-bottom:28px;line-height:1.6;}
  .auth-tabs{display:flex;gap:0;border:1px solid var(--line);border-radius:10px;margin-bottom:24px;overflow:hidden;}
  .auth-tab{flex:1;background:none;border:none;color:var(--text-muted);font-size:14px;padding:9px;cursor:pointer;font-family:'Noto Sans JP','Noto Sans SC',sans-serif;transition:all .15s;}
  .auth-tab.active{background:rgba(232,200,150,0.15);color:var(--accent-gold);}
  .auth-methods{display:flex;gap:6px;margin-bottom:20px;justify-content:center;}
  .auth-method{background:transparent;border:1px solid var(--line);color:var(--text-muted);border-radius:999px;padding:6px 14px;font-size:12px;cursor:pointer;font-family:'Noto Sans JP','Noto Sans SC',sans-serif;transition:all .15s;}
  .auth-method.active{color:var(--text-primary);border-color:var(--accent-gold);background:rgba(232,200,150,0.12);}
  .auth-method:hover{color:var(--text-primary);}
  .auth-field{margin-bottom:14px;text-align:left;}
  .auth-field label{display:block;font-size:12px;color:var(--text-muted);margin-bottom:6px;letter-spacing:0.04em;}
  .auth-field input{
    width:100%;background:var(--bg-deep);border:1px solid var(--line);border-radius:10px;
    color:var(--text-primary);font-size:14px;padding:11px 14px;outline:none;
    font-family:'Noto Sans JP','Noto Sans SC',sans-serif;transition:border-color .2s;
  }
  .auth-field input:focus{border-color:var(--accent-gold);}
  .auth-field input::placeholder{color:rgba(168,155,196,0.45);}
  .auth-submit{width:100%;margin-top:6px;background:var(--accent-gold);color:#1A1330;border:none;border-radius:999px;padding:13px;font-size:15px;font-weight:600;cursor:pointer;font-family:'Noto Sans JP','Noto Sans SC',sans-serif;transition:opacity .15s;}
  .auth-submit:hover{opacity:0.88;}
  .auth-submit:disabled{opacity:0.35;cursor:not-allowed;}
  .auth-note{color:var(--text-muted);font-size:11px;margin-top:6px;line-height:1.5;}
  .auth-error{color:#E08A8A;font-size:12.5px;margin-top:10px;min-height:18px;}
  .auth-success{color:#88C8A0;font-size:12.5px;margin-top:10px;min-height:18px;}

  /* user badge top-right */
  .user-badge{
    position:absolute;top:18px;left:20px;display:none;align-items:center;gap:8px;z-index:2;
  }
  .user-badge.show{display:flex;}
  .user-avatar{width:28px;height:28px;border-radius:50%;background:rgba(232,200,150,0.2);border:1px solid var(--accent-gold);display:flex;align-items:center;justify-content:center;font-size:13px;color:var(--accent-gold);font-weight:600;}
  .user-name{font-size:12.5px;color:var(--text-muted);max-width:90px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
  .logout-btn{font-size:11px;color:rgba(168,155,196,0.6);background:none;border:none;cursor:pointer;padding:0;font-family:'Noto Sans JP','Noto Sans SC',sans-serif;}
  .logout-btn:hover{color:var(--text-muted);}
  @media(max-width:480px){.auth-box{padding:28px 20px;}}

  /* ── v2 premium polish: breathing room + soft depth ── */
  .history-group,.scene-card{box-shadow:var(--shadow-soft);border-radius:16px;}
  .scene-card{padding:18px;margin-bottom:16px;}
  .history-group{padding:16px 18px;margin-bottom:14px;}
  .field-label{font-size:13px;letter-spacing:0.05em;}
  .toc-day{margin:18px 0 8px;}
  .db-card,.db-chapter{padding:30px;}

  /* ── Points pill + ledger ── */
  .points-pill{margin-left:6px;background:rgba(232,200,150,0.12);border:1px solid rgba(232,200,150,0.4);color:var(--accent-gold);border-radius:999px;padding:5px 12px;font-size:12.5px;font-weight:600;cursor:pointer;font-family:'Noto Sans JP','Noto Sans SC',sans-serif;transition:all .15s;}
  .points-pill:hover{background:rgba(232,200,150,0.22);transform:translateY(-1px);}
  .ledger-overlay{position:fixed;inset:0;background:rgba(8,5,20,0.72);backdrop-filter:blur(5px);z-index:110;display:none;align-items:center;justify-content:center;padding:24px;}
  .ledger-overlay.show{display:flex;}
  .ledger-box{background:var(--bg-panel);border:1px solid var(--line-strong);border-radius:18px;padding:22px 24px;max-width:420px;width:100%;max-height:80vh;display:flex;flex-direction:column;box-shadow:var(--shadow-card);}
  .ledger-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px;}
  .ledger-title{font-family:'Noto Serif JP','Noto Serif SC',serif;font-weight:700;font-size:16px;color:var(--text-primary);}
  .ledger-close{cursor:pointer;color:var(--text-muted);font-size:18px;}
  .ledger-balance{font-size:22px;color:var(--accent-gold);font-weight:700;margin-bottom:14px;}
  .ledger-list{overflow-y:auto;}
  .ledger-row{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--line);font-size:13px;}
  .ledger-row .lr-reason{flex:1;color:var(--text-primary);}
  .ledger-row .lr-when{color:var(--text-muted);font-size:11px;flex-shrink:0;}
  .ledger-row .lr-delta{font-variant-numeric:tabular-nums;font-weight:600;min-width:42px;text-align:right;flex-shrink:0;}
  .ledger-row .lr-delta.pos{color:#88C8A0;}
  .ledger-row .lr-delta.neg{color:var(--accent-gold);}

  /* ── Recharge ── */
  .recharge-pill{margin-left:6px;background:linear-gradient(135deg,var(--accent-gold),#d9a86b);border:none;color:#3a2a10;border-radius:999px;padding:5px 12px;font-size:12.5px;font-weight:700;cursor:pointer;font-family:'Noto Sans JP','Noto Sans SC',sans-serif;transition:all .15s;box-shadow:0 2px 10px rgba(232,200,150,0.25);}
  .recharge-pill:hover{transform:translateY(-1px);box-shadow:0 4px 14px rgba(232,200,150,0.4);}
  .recharge-overlay{position:fixed;inset:0;background:rgba(8,5,20,0.72);backdrop-filter:blur(5px);z-index:120;display:none;align-items:center;justify-content:center;padding:24px;}
  .recharge-overlay.show{display:flex;}
  .recharge-box{background:var(--bg-panel);border:1px solid var(--line-strong);border-radius:18px;padding:22px 24px;max-width:440px;width:100%;max-height:86vh;overflow-y:auto;display:flex;flex-direction:column;box-shadow:var(--shadow-card);}
  .recharge-sub{font-size:12.5px;color:var(--text-muted);margin:2px 0 14px;}
  .recharge-cur{display:flex;gap:8px;margin-bottom:16px;}
  .rc-cur-btn{flex:1;background:rgba(255,255,255,0.04);border:1px solid var(--line);color:var(--text-muted);border-radius:10px;padding:8px 6px;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s;font-family:inherit;}
  .rc-cur-btn.active{background:rgba(232,200,150,0.14);border-color:rgba(232,200,150,0.5);color:var(--accent-gold);}
  .recharge-packs{display:flex;flex-direction:column;gap:10px;}
  .rc-pack{display:flex;align-items:center;justify-content:space-between;gap:12px;background:rgba(255,255,255,0.04);border:1px solid var(--line);border-radius:12px;padding:14px 16px;cursor:pointer;transition:all .15s;font-family:inherit;}
  .rc-pack:hover{border-color:rgba(232,200,150,0.5);background:rgba(232,200,150,0.08);transform:translateY(-1px);}
  .rc-pack-pts{font-size:14.5px;font-weight:600;color:var(--text-primary);}
  .rc-pack-price{font-size:16px;font-weight:700;color:var(--accent-gold);font-variant-numeric:tabular-nums;}
  .rc-bonus{display:inline-block;margin-left:6px;font-size:11px;font-weight:700;color:#88C8A0;background:rgba(136,200,160,0.14);border-radius:6px;padding:1px 6px;}
  .recharge-pay{margin-top:16px;display:flex;flex-direction:column;align-items:center;gap:10px;}
  .rc-qr{width:200px;height:200px;border-radius:12px;background:#fff;padding:8px;}
  .rc-note{font-size:12.5px;color:var(--text-muted);text-align:center;}
  .rc-status{font-size:13px;font-weight:600;color:var(--accent-gold);}
  .rc-status.ok{color:#88C8A0;}
  .rc-open{font-size:12.5px;color:var(--accent-gold);text-decoration:underline;}

  /* ── Insights sub-navigation ── */
  .sub-nav{display:flex;gap:4px;justify-content:center;margin:0 auto 24px;background:rgba(255,255,255,0.04);border:1px solid var(--line);border-radius:999px;padding:4px;width:fit-content;max-width:100%;flex-wrap:wrap;}
  .sub-btn{background:none;border:none;color:var(--text-muted);font-family:'Noto Sans JP','Noto Sans SC',sans-serif;font-size:13px;padding:7px 18px;border-radius:999px;cursor:pointer;transition:all .15s;white-space:nowrap;}
  .sub-btn:hover{color:var(--text-primary);}
  .sub-btn.active{background:rgba(232,200,150,0.16);color:var(--accent-gold);font-weight:600;}
  .sub-panel{display:none;}
  .sub-panel.active{display:block;}

  /* ── Dream Persona ── */
  .persona-intro{color:var(--text-muted);font-size:13.5px;line-height:1.8;margin-bottom:16px;text-align:center;}
  .persona-body{margin-top:20px;line-height:1.95;font-size:14.5px;color:var(--text-primary);}
  .persona-body strong{display:inline-block;margin-top:16px;margin-bottom:2px;color:var(--accent-gold);font-weight:700;font-family:'Noto Serif JP','Noto Serif SC',serif;font-size:15px;}

  /* dream title summary atop the reading result */
  .result-dream-title{font-family:'Noto Serif JP','Noto Serif SC',serif;font-weight:700;font-size:18px;color:var(--accent-gold);text-align:center;letter-spacing:0.02em;margin-bottom:16px;}
  .result-dream-title:empty{display:none;}
