:root {
    --bg:#0a0804; --surface:#110f0a; --gold:#c9a84c; --gold-dim:#7a6330;
    --gold-glow:rgba(201,168,76,0.12); --cream:#e8dfc8; --muted:#6b6050; --border:rgba(201,168,76,0.18);
  }
  *{margin:0;padding:0;box-sizing:border-box;}
  body{background:var(--bg);color:var(--cream);font-family:'Cormorant Garamond',serif;min-height:100vh;display:flex;flex-direction:column;align-items:center;padding:60px 20px 80px;position:relative;overflow-x:hidden;}
  body::before{content:'';position:fixed;inset:0;background:radial-gradient(ellipse at 15% 15%,rgba(201,168,76,0.05) 0%,transparent 55%),radial-gradient(ellipse at 85% 85%,rgba(139,26,26,0.07) 0%,transparent 55%);pointer-events:none;z-index:0;}
  .container{width:100%;max-width:860px;position:relative;z-index:1;}


  /* Custom select — Nível de Treino */
  .custom-select{position:relative;user-select:none;}
  .custom-select-trigger{display:flex;align-items:center;justify-content:space-between;gap:12px;background:rgba(0,0,0,0.45);border:1px solid rgba(201,168,76,0.18);padding:10px 14px;cursor:pointer;transition:border-color 0.3s;}
  .custom-select-trigger:hover{border-color:var(--gold-dim);}
  .custom-select.open .custom-select-trigger{border-color:var(--gold-dim);}
  .custom-select-label{font-family:'Cormorant Garamond',serif;font-size:16px;color:var(--cream);}
  .custom-select-arrow{font-size:9px;color:var(--gold-dim);transition:transform 0.25s;}
  .custom-select.open .custom-select-arrow{transform:rotate(180deg);}
  .custom-select-options{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#0e0c08;border:1px solid rgba(201,168,76,0.2);z-index:50;display:none;flex-direction:column;}
  .custom-select.open .custom-select-options{display:flex;}
  .custom-select-option{font-family:'Cormorant Garamond',serif;font-size:15px;color:var(--muted);padding:10px 14px;cursor:pointer;transition:background 0.2s,color 0.2s;border-bottom:1px solid rgba(201,168,76,0.06);}
  .custom-select-option:last-child{border-bottom:none;}
  .custom-select-option:hover{background:rgba(201,168,76,0.07);color:var(--cream);}
  .custom-select-option.selected{color:var(--gold);}

  /* Flag toggles */
  .flag-toggle{display:flex;align-items:center;gap:0;cursor:pointer;position:relative;}
  .flag-toggle input[type=checkbox]{display:none;}
  .flag-toggle-btn{font-family:'Cinzel',serif;font-size:8.5px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);background:rgba(0,0,0,0.3);border:1px solid rgba(201,168,76,0.12);padding:6px 11px;cursor:pointer;transition:all 0.25s;white-space:nowrap;border-radius:1px;}
  .flag-toggle:hover .flag-toggle-btn{border-color:rgba(201,168,76,0.25);color:var(--cream);}
  .flag-toggle input:checked + .flag-toggle-btn{background:rgba(201,168,76,0.1);border-color:var(--gold-dim);color:var(--gold);}

  /* Topbar */
  .home-btn{position:fixed;top:12px;left:20px;z-index:100;display:flex;align-items:center;gap:6px;background:rgba(10,8,4,0.88);border:1px solid rgba(201,168,76,0.18);border-radius:2px;padding:7px 13px;font-family:'Cinzel',serif;font-size:8px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);text-decoration:none;backdrop-filter:blur(8px);transition:border-color 0.2s,color 0.2s;}
  .home-btn:hover{border-color:rgba(201,168,76,0.4);color:var(--gold);}
  .topbar{position:fixed;top:12px;right:20px;z-index:100;pointer-events:all;}
  .topbar-trigger{display:flex;align-items:center;gap:7px;background:rgba(10,8,4,0.88);border:1px solid rgba(201,168,76,0.18);border-radius:2px;padding:7px 13px;cursor:pointer;backdrop-filter:blur(8px);transition:border-color 0.2s;}
  .topbar-trigger:hover{border-color:rgba(201,168,76,0.4);}
  .topbar-trigger span{font-family:'Cinzel',serif;font-size:8px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);}
  .topbar-trigger .caret{font-size:8px;color:var(--gold-dim);transition:transform 0.2s;}
  .topbar.open .caret{transform:rotate(180deg);}
  .topbar-dropdown{position:absolute;top:calc(100% + 6px);right:0;background:rgba(10,8,4,0.96);border:1px solid rgba(201,168,76,0.18);border-radius:2px;padding:14px 16px;min-width:200px;backdrop-filter:blur(10px);display:none;flex-direction:column;gap:14px;}
  .topbar.open .topbar-dropdown{display:flex;}
  .dd-section{display:flex;flex-direction:column;gap:8px;}
  .dd-label{font-family:'Cinzel',serif;font-size:8px;letter-spacing:2px;text-transform:uppercase;color:var(--gold-dim);}
  .dd-sep{height:1px;background:rgba(201,168,76,0.1);}
  .dd-themes{display:flex;gap:8px;align-items:center;}
  .theme-dot{width:16px;height:16px;border-radius:50%;cursor:pointer;border:2px solid transparent;transition:all 0.2s;flex-shrink:0;}
  .theme-dot:hover{transform:scale(1.2);}
  .theme-dot.active{border-color:var(--cream);}
  .theme-name{font-family:'Cormorant Garamond',serif;font-size:12px;font-style:italic;color:var(--muted);margin-left:2px;}
  .dd-btn{background:transparent;border:1px solid rgba(201,168,76,0.15);color:var(--muted);font-family:'Cinzel',serif;font-size:8px;letter-spacing:2px;text-transform:uppercase;padding:7px 10px;cursor:pointer;border-radius:1px;transition:all 0.25s;text-align:left;text-decoration:none;display:block;}
  .dd-btn:hover{border-color:var(--gold-dim);color:var(--gold);}

  header{text-align:center;margin-bottom:44px;}
  .header-rule{display:flex;align-items:center;justify-content:center;gap:14px;color:var(--gold-dim);margin-bottom:14px;}
  .header-rule::before,.header-rule::after{content:'';width:60px;height:1px;background:linear-gradient(to right,transparent,var(--gold-dim));}
  .header-rule::after{background:linear-gradient(to left,transparent,var(--gold-dim));}
  h1{font-family:'Cinzel',serif;font-size:clamp(20px,3.5vw,30px);font-weight:600;color:var(--gold);letter-spacing:5px;text-transform:uppercase;margin-bottom:8px;}
  .subtitle{font-style:italic;font-size:16px;color:var(--muted);letter-spacing:1px;}

  .card{background:var(--surface);border:1px solid var(--border);border-radius:2px;padding:26px 28px;margin-bottom:20px;}
  .card-label{font-family:'Cinzel',serif;font-size:9px;letter-spacing:3px;text-transform:uppercase;color:var(--gold-dim);margin-bottom:20px;display:flex;align-items:center;gap:12px;}
  .card-label::after{content:'';flex:1;height:1px;background:var(--border);}

  /* Grids */
  .vars-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px;align-items:end;}
  .vars-grid-2{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-top:16px;padding-top:16px;border-top:1px solid rgba(201,168,76,0.08);align-items:end;}


  .field{display:flex;flex-direction:column;gap:7px;}
  label{font-family:'Cinzel',serif;font-size:8.5px;letter-spacing:2px;text-transform:uppercase;color:var(--gold-dim);}
  .input-row{display:flex;gap:5px;}
  .input-row input{flex:1;min-width:0;}
  .color-wrap{position:relative;flex:1;display:flex;}
  .color-wrap input{flex:1;padding-right:34px;}
  .color-dot{position:absolute;right:9px;top:50%;transform:translateY(-50%);width:11px;height:11px;border-radius:50%;border:1px solid rgba(255,255,255,0.1);background:#3a3228;opacity:0.3;transition:background 0.3s,opacity 0.3s;pointer-events:none;}
  input{width:100%;background:rgba(0,0,0,0.45);border:1px solid rgba(201,168,76,0.15);border-radius:1px;color:var(--cream);font-family:'Cormorant Garamond',serif;font-size:15px;padding:9px 11px;outline:none;transition:border-color 0.3s,box-shadow 0.3s;}
  input::placeholder{color:var(--muted);font-style:italic;font-size:14px;}
  input:focus{border-color:var(--gold-dim);box-shadow:0 0 0 2px rgba(201,168,76,0.07);}
  .btn-rand{background:rgba(201,168,76,0.06);border:1px solid rgba(201,168,76,0.15);color:var(--gold-dim);border-radius:1px;width:30px;flex-shrink:0;cursor:pointer;font-size:12px;transition:all 0.2s;display:flex;align-items:center;justify-content:center;}
  .btn-rand:hover{background:rgba(201,168,76,0.14);color:var(--gold);border-color:var(--gold-dim);}
  .btn-rand:active{transform:scale(0.9);}
  .btn-rand-all{width:100%;background:transparent;border:1px dashed rgba(201,168,76,0.22);color:var(--gold-dim);font-family:'Cinzel',serif;font-size:9px;letter-spacing:4px;text-transform:uppercase;padding:10px;cursor:pointer;transition:all 0.3s;margin-top:18px;}
  .btn-rand-all:hover{border-color:var(--gold-dim);color:var(--gold);background:rgba(201,168,76,0.04);}

  /* Adv label */
  .adv-label{font-family:'Cinzel',serif;font-size:8px;letter-spacing:2px;text-transform:uppercase;color:rgba(194,96,96,0.7);margin-bottom:8px;}

  /* Options row */
  .options-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px;}

  .option-card{background:var(--surface);border:1px solid var(--border);border-radius:2px;padding:20px 22px;}
  select{width:100%;background:rgba(0,0,0,0.5);border:1px solid rgba(201,168,76,0.15);border-radius:1px;color:var(--cream);font-family:'Cormorant Garamond',serif;font-size:15px;padding:9px 11px;outline:none;cursor:pointer;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' fill='none'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%237a6330' stroke-width='1.2'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:10px;padding-right:32px;transition:border-color 0.3s;}
  select:focus{border-color:var(--gold-dim);}
  select option{background:#1a1510;color:var(--cream);}

  /* Timer */
  .timer-controls{display:flex;gap:8px;margin-top:10px;}
  .timer-btn{flex:1;background:rgba(0,0,0,0.4);border:1px solid rgba(201,168,76,0.15);color:var(--muted);font-family:'Cinzel',serif;font-size:9px;letter-spacing:2px;padding:8px 4px;cursor:pointer;transition:all 0.3s;text-align:center;border-radius:1px;}
  .timer-btn:hover{border-color:var(--gold-dim);color:var(--gold);}
  .timer-btn.active{border-color:var(--gold);color:var(--gold);background:rgba(201,168,76,0.08);}
  .timer-display{margin-top:14px;text-align:center;font-family:'Cinzel',serif;font-size:28px;color:var(--gold);letter-spacing:4px;display:none;}
  .timer-display.running{display:block;}
  .timer-progress{height:2px;background:rgba(201,168,76,0.1);margin-top:10px;border-radius:1px;display:none;}
  .timer-progress.running{display:block;}
  .timer-bar{height:100%;background:var(--gold-dim);transition:width 1s linear;border-radius:1px;}
  .timer-actions{display:flex;gap:8px;margin-top:10px;}
  .btn-timer-start{flex:1;background:transparent;border:1px solid var(--gold-dim);color:var(--gold);font-family:'Cinzel',serif;font-size:9px;letter-spacing:3px;text-transform:uppercase;padding:9px;cursor:pointer;transition:all 0.3s;}
  .btn-timer-start:hover{background:rgba(201,168,76,0.08);}
  .btn-timer-stop{flex:1;background:transparent;border:1px solid rgba(201,168,76,0.15);color:var(--muted);font-family:'Cinzel',serif;font-size:9px;letter-spacing:3px;text-transform:uppercase;padding:9px;cursor:pointer;transition:all 0.3s;display:none;}
  .btn-timer-stop:hover{border-color:rgba(201,168,76,0.3);color:var(--cream);}

  /* Template */
  .template-area{width:100%;background:rgba(0,0,0,0.4);border:1px solid rgba(201,168,76,0.15);border-radius:1px;color:var(--cream);font-family:'Cormorant Garamond',serif;font-size:16px;line-height:1.75;padding:14px 16px;outline:none;resize:vertical;min-height:170px;transition:border-color 0.3s;}
  .template-area:focus{border-color:var(--gold-dim);}
  .template-hint{margin-top:11px;font-size:13px;color:var(--muted);font-style:italic;line-height:1.6;}
  .tags-row{display:flex;flex-wrap:wrap;gap:6px;margin-top:13px;}
  .tag{background:rgba(201,168,76,0.07);border:1px solid rgba(201,168,76,0.18);border-radius:2px;padding:3px 10px;font-family:'Cinzel',serif;font-size:9px;letter-spacing:1px;color:var(--gold);}
  .tag.adv{border-color:rgba(194,96,96,0.3);color:rgba(194,96,96,0.8);background:rgba(194,96,96,0.05);}

  /* Generate */
  .btn-generate{width:100%;background:transparent;border:1px solid var(--gold-dim);color:var(--gold);font-family:'Cinzel',serif;font-size:11px;letter-spacing:6px;text-transform:uppercase;padding:17px;cursor:pointer;transition:all 0.4s;position:relative;overflow:hidden;margin-bottom:24px;}
  .btn-generate::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,var(--gold-glow),transparent 60%);opacity:0;transition:opacity 0.4s;}
  .btn-generate:hover{border-color:var(--gold);color:var(--cream);box-shadow:0 0 40px rgba(201,168,76,0.12);}
  .btn-generate:hover::after{opacity:1;}
  .btn-generate:active{transform:scale(0.995);}

  /* Output */
  .output-card{opacity:0;transform:translateY(10px);transition:opacity 0.6s ease,transform 0.6s ease;}
  .output-card.visible{opacity:1;transform:translateY(0);}
  .output-text{font-family:'IM Fell English',serif;font-size:18px;line-height:2.1;color:var(--cream);white-space:pre-wrap;}
  .meta-pills{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px;}
  .pill{display:flex;align-items:center;gap:7px;background:rgba(0,0,0,0.3);border:1px solid rgba(201,168,76,0.14);border-radius:2px;padding:6px 14px;font-family:'Cinzel',serif;font-size:9px;letter-spacing:1.5px;color:var(--muted);}
  .pill span.val{color:var(--cream);font-size:13px;font-family:'Cormorant Garamond',serif;font-style:italic;letter-spacing:0;}
  .diff-badge{display:inline-block;font-family:'Cinzel',serif;font-size:8px;letter-spacing:2px;text-transform:uppercase;padding:3px 9px;border-radius:2px;margin-left:8px;}
  .diff-iniciante{background:rgba(60,120,70,0.2);border:1px solid rgba(60,180,80,0.3);color:#6ab87a;}
  .diff-intermediario{background:rgba(180,130,30,0.2);border:1px solid rgba(200,160,50,0.3);color:#c9a84c;}
  .diff-avancado{background:rgba(140,30,30,0.2);border:1px solid rgba(200,60,60,0.3);color:#c26060;}
  .btn-copy{margin-top:18px;float:right;background:transparent;border:1px solid rgba(201,168,76,0.18);color:var(--muted);font-family:'Cinzel',serif;font-size:9px;letter-spacing:2px;text-transform:uppercase;padding:7px 14px;cursor:pointer;transition:all 0.3s;}
  .btn-copy:hover{border-color:var(--gold-dim);color:var(--gold);}
  .btn-copy.copied{color:#6aab7a;border-color:rgba(106,171,122,0.35);}
  .clearfix::after{content:'';display:table;clear:both;}

  /* History */
  .history-list{display:flex;flex-direction:column;gap:10px;}
  .history-item{background:rgba(0,0,0,0.3);border:1px solid rgba(201,168,76,0.1);border-radius:1px;padding:12px 16px;display:flex;align-items:center;gap:14px;transition:border-color 0.3s;}
  .history-item:hover{border-color:rgba(201,168,76,0.3);}
  .history-thumb{display:flex;flex-direction:column;gap:3px;flex:1;min-width:0;}
  .history-title{font-family:'Cinzel',serif;font-size:10px;letter-spacing:1px;color:var(--gold-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
  .history-preview{font-size:13px;color:var(--muted);font-style:italic;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
  .history-load{background:transparent;border:1px solid rgba(201,168,76,0.15);color:var(--muted);font-family:'Cinzel',serif;font-size:8px;letter-spacing:2px;padding:5px 10px;cursor:pointer;transition:all 0.3s;flex-shrink:0;}
  .history-load:hover{color:var(--gold);border-color:var(--gold-dim);}
  .sep{text-align:center;color:var(--gold-dim);font-size:18px;letter-spacing:10px;margin:4px 0 20px;opacity:0.45;}
  footer{margin-top:40px;text-align:center;padding:24px 0 8px;border-top:1px solid rgba(201,168,76,0.08);width:100%;}
  footer p{font-style:italic;font-size:13px;color:var(--muted);margin-bottom:8px;}
  footer a{font-family:'Cinzel',serif;font-size:10px;letter-spacing:2px;color:var(--gold-dim);text-decoration:none;border-bottom:1px solid rgba(201,168,76,0.2);padding-bottom:1px;transition:color 0.3s,border-color 0.3s;}
  footer a:hover{color:var(--gold);border-color:var(--gold-dim);}
  /* Tooltip */
  .tooltip-wrap{position:relative;display:inline-flex;align-items:center;}
  .tooltip-icon{width:14px;height:14px;border-radius:50%;border:1px solid rgba(201,168,76,0.3);color:var(--gold-dim);font-family:'Cinzel',serif;font-size:8px;display:inline-flex;align-items:center;justify-content:center;cursor:help;flex-shrink:0;margin-left:5px;transition:border-color 0.2s,color 0.2s;}
  .tooltip-icon:hover{border-color:var(--gold);color:var(--gold);}
  .tooltip-box{position:absolute;left:50%;bottom:calc(100% + 7px);transform:translateX(-50%);background:#1a1610;border:1px solid rgba(201,168,76,0.25);border-radius:2px;padding:8px 12px;font-family:'Cormorant Garamond',serif;font-size:13px;font-style:italic;color:var(--cream);line-height:1.5;width:220px;pointer-events:none;opacity:0;transition:opacity 0.2s;z-index:100;text-align:left;}
  .tooltip-box::after{content:'';position:absolute;top:100%;left:50%;transform:translateX(-50%);border:5px solid transparent;border-top-color:#1a1610;}
  .tooltip-wrap:hover .tooltip-box{opacity:1;}

  /* Flags */
  .flags-row{display:flex;flex-direction:column;gap:8px;margin-top:14px;padding-top:14px;border-top:1px solid rgba(201,168,76,0.08);}
  .flag-item{display:flex;align-items:center;gap:9px;cursor:pointer;user-select:none;}
  .flag-item input[type=checkbox]{width:13px;height:13px;accent-color:var(--gold-dim);cursor:pointer;flex-shrink:0;}
  .flag-item span{font-family:'Cinzel',serif;font-size:8.5px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);transition:color 0.2s;}
  .flag-item:hover span{color:var(--gold);}
  .flag-item input:checked + span{color:var(--gold-dim);}
  .flag-badge{font-size:9px;margin-left:4px;opacity:0.5;}
  .obj-count-btn{background:rgba(0,0,0,0.4);border:1px solid rgba(201,168,76,0.15);color:var(--muted);font-family:'Cinzel',serif;font-size:8px;letter-spacing:0;padding:4px 7px;cursor:pointer;border-radius:1px;transition:all 0.2s;white-space:nowrap;}
  .obj-count-btn:hover{border-color:var(--gold-dim);color:var(--gold);}
  .obj-count-btn.active{border-color:var(--gold);color:var(--gold);background:rgba(201,168,76,0.08);}
  .flag-item-wide{flex-direction:row;align-items:center;flex-wrap:nowrap;gap:8px;grid-column:1/-1;white-space:nowrap;}
  .obj-count-row{display:none;gap:4px;align-items:center;flex-shrink:0;}
  .obj-count-row.enabled{display:flex;}


  .btn-io{background:transparent;border:1px solid rgba(201,168,76,0.2);color:var(--muted);font-family:'Cinzel',serif;font-size:9px;letter-spacing:3px;text-transform:uppercase;padding:9px 18px;cursor:pointer;border-radius:1px;transition:all 0.3s;}
  .btn-io:hover{border-color:var(--gold-dim);color:var(--gold);background:rgba(201,168,76,0.04);}
  .footer-row{display:flex;align-items:center;justify-content:center;gap:24px;flex-wrap:wrap;margin-bottom:12px;}
  .footer-block{display:flex;flex-direction:column;align-items:center;gap:5px;}
  .footer-sep{color:var(--gold-dim);font-size:12px;opacity:0.4;}
  .footer-version{font-family:'Cinzel',serif;font-size:9px;letter-spacing:3px;color:rgba(122,99,48,0.35);}

  .mods-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px 16px;}
  .obj-adicional-row{display:flex;flex-direction:row;align-items:center;gap:8px;flex-wrap:nowrap;grid-column:1/-1;}
  .intencao-obj-row{display:flex;flex-direction:row;align-items:flex-start;gap:12px;flex-wrap:wrap;grid-column:1/-1;padding-top:4px;}

  /* ── Responsive ──────────────────────────────────────────────────────────── */
  @media(max-width:740px){
    body{padding:56px 14px 60px;}

    /* Grids de variáveis: 2 colunas */
    .vars-grid{grid-template-columns:repeat(2,1fr);}
    .vars-grid-2{grid-template-columns:repeat(2,1fr);}

    /* Options row empilha */
    .options-row{grid-template-columns:1fr;}

    /* Cards com padding menor */
    .card{padding:18px 16px;}

    /* Header menor */
    h1{font-size:20px;letter-spacing:3px;}
    .subtitle{font-size:14px;}

    /* Timer buttons menores */
    .timer-btn{font-size:8px;padding:7px 2px;}

    /* Topbar: reduz padding */
    .home-btn{top:8px;left:12px;padding:6px 10px;z-index:101;}
    .topbar{top:8px;right:12px;left:auto;display:flex;justify-content:flex-end;}
    .topbar-trigger{padding:6px 10px;}
    .topbar-dropdown{right:0;left:auto;min-width:0;width:calc(100vw - 24px);max-width:320px;}

    /* Modificadores: 2 colunas */
    .flag-toggle-btn{font-size:8px;padding:6px 9px;}

    /* Objetos adicionais inline pode quebrar em telas muito pequenas */
    .obj-count-btn{padding:4px 6px;font-size:8px;}

    /* Output text menor */
    .output-text{font-size:16px;line-height:1.9;}

    /* Meta pills: wrap */
    .meta-pills{gap:6px;}
    .pill{font-size:8px;padding:5px 10px;}

    /* Histórico */
    .history-title{font-size:9px;}
    .history-preview{font-size:12px;}

    /* Footer empilha */
    .footer-row{gap:14px;}

    /* Custom select */
    .custom-select-label{font-size:15px;}
    .custom-select-option{font-size:14px;padding:9px 12px;}
  }

  @media(max-width:420px){
    /* Grids de variáveis: 1 coluna em telas muito pequenas */
    .vars-grid{grid-template-columns:1fr;}
    .vars-grid-2{grid-template-columns:1fr;}

    /* Botões do timer em 2 linhas */
    .timer-controls{flex-wrap:wrap;}
    .timer-btn{flex:1 1 40%;}

    /* Modificadores: 1 coluna */
    div[style*="repeat(auto-fill,minmax(180px"]{grid-template-columns:1fr!important;}

    /* Objetos adicionais: botões menores */
    .obj-count-btn{padding:4px 5px;}

    /* Histórico: esconde preview */
    .history-preview{display:none;}
    .mods-grid{grid-template-columns:repeat(2,1fr)!important;}
    .obj-adicional-row{flex-wrap:wrap;}
    .obj-count-row{flex-wrap:wrap;}
  }
/* ── Home page ───────────────────────────────────────────────────────────────── */
body { justify-content: flex-start; }

.home-container {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding-top: 20px;
  padding-bottom: 80px;
  gap: 0;
}

/* Banner */
.banner-wrap {
  position: relative;
  width: 100%;
  max-width: 560px;
  height: 160px;
  overflow: hidden;
  margin-bottom: 32px;
  border: 1px solid rgba(201,168,76,0.18);
}

.banner-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 30%;
  display: block;
  filter: sepia(0.4) contrast(1.1) brightness(0.75) grayscale(0.2);
}

.banner-vignette {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(to right, var(--bg) 0%, transparent 18%, transparent 82%, var(--bg) 100%),
    linear-gradient(to bottom, var(--bg) 0%, transparent 30%, transparent 70%, var(--bg) 100%);
  pointer-events: none;
}

/* Title */
.home-title-wrap {
  text-align: center;
  margin-bottom: 48px;
}

.home-title {
  font-family: 'Cinzel', serif;
  font-size: clamp(26px, 5vw, 42px);
  font-weight: 600;
  color: var(--gold);
  letter-spacing: 6px;
  text-transform: uppercase;
  margin-bottom: 10px;
}

.home-subtitle {
  font-family: 'IM Fell English', serif;
  font-style: italic;
  font-size: 16px;
  color: var(--muted);
  letter-spacing: 3px;
}

/* Nav buttons */
.home-nav {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
  width: 100%;
  max-width: 400px;
}

.home-nav-btn {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  background: transparent;
  border: 1px solid var(--gold-dim);
  color: var(--gold);
  font-family: 'Cinzel', serif;
  font-size: 11px;
  letter-spacing: 4px;
  text-transform: uppercase;
  padding: 18px 24px;
  text-decoration: none;
  cursor: pointer;
  transition: all 0.4s;
  position: relative;
  overflow: hidden;
}

.home-nav-btn::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, var(--gold-glow), transparent 60%);
  opacity: 0;
  transition: opacity 0.4s;
}

.home-nav-btn:hover {
  border-color: var(--gold);
  color: var(--cream);
  box-shadow: 0 0 40px rgba(201,168,76,0.12);
}

.home-nav-btn:hover::after { opacity: 1; }
.home-nav-btn:active { transform: scale(0.998); }

.home-nav-arrow {
  font-size: 14px;
  opacity: 0.6;
  transition: transform 0.3s, opacity 0.3s;
}

.home-nav-btn:hover .home-nav-arrow {
  transform: translateX(4px);
  opacity: 1;
}

@media(max-width:740px){
  .home-title { font-size: 24px; letter-spacing: 4px; }
  .home-nav-btn { font-size: 10px; padding: 16px 18px; }
}


/* ── Modules grid ────────────────────────────────────────────────────────── */
.modules-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 16px;
  width: 100%;
  max-width: 640px;
  margin-top: 8px;
}

.module-card {
  display: flex;
  align-items: center;
  gap: 18px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 2px;
  padding: 22px 20px;
  text-decoration: none;
  color: var(--cream);
  transition: border-color 0.3s, box-shadow 0.3s;
  position: relative;
  overflow: hidden;
}

.module-card::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, var(--gold-glow), transparent 60%);
  opacity: 0;
  transition: opacity 0.4s;
}

.module-card:not(.module-locked):hover {
  border-color: var(--gold-dim);
  box-shadow: 0 0 30px rgba(201,168,76,0.08);
}
.module-card:not(.module-locked):hover::after { opacity: 1; }

.module-locked {
  opacity: 0.4;
  cursor: default;
}

.module-icon {
  font-size: 22px;
  color: var(--gold-dim);
  flex-shrink: 0;
  width: 32px;
  text-align: center;
  line-height: 1;
}

.module-info {
  flex: 1;
  min-width: 0;
}

.module-name {
  font-family: 'Cinzel', serif;
  font-size: 11px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 6px;
}

.module-desc {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  font-size: 13px;
  color: var(--muted);
  line-height: 1.5;
}

.module-arrow {
  font-size: 16px;
  color: var(--gold-dim);
  flex-shrink: 0;
  transition: transform 0.3s, color 0.3s;
}
.module-card:not(.module-locked):hover .module-arrow {
  transform: translateX(4px);
  color: var(--gold);
}

.module-lock {
  font-size: 12px;
  color: var(--muted);
  flex-shrink: 0;
  opacity: 0.5;
}

@media(max-width:740px){
  .modules-grid { grid-template-columns: 1fr; max-width: 100%; }
  .module-card  { padding: 18px 16px; gap: 14px; }
  .module-desc  { display: none; }
}
