  :root{
    --ln-gold:#D4AF37; --ink:#0b0f24; --card:#ffffff; --line:#b5bfd1;
    --bg1:#fef6e7; --bg2:#e8f7ff; --bg3:#eef8f1; --bg4:#f3ecff;
    --grad: conic-gradient(from 180deg at 20% 30%, var(--bg1), var(--bg2), var(--bg3), var(--bg4), var(--bg1));
    --shadow:0 20px 50px rgba(0,0,0,.14); --radius:22px;
    --base:19px; --hdrH:80px;
  }
  html[data-fs="normal"]{ --base:19px; }
  html[data-fs="large"] { --base:21px; }
  html[data-fs="xlarge"]{ --base:23px; }
  *{box-sizing:border-box}
  html{ font-size: var(--base); }
  body{ margin:0;background:var(--grad) fixed;font-family:system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;color:var(--ink);}
  a{ color:inherit }

  header{position:sticky;top:0;z-index:2;backdrop-filter:saturate(120%) blur(4px);}
  .bar{display:flex;align-items:center;gap:14px;padding:14px 20px;background:rgba(255,255,255,.92);border-bottom:1px solid var(--line)}
  .logo{width:52px;height:52px;border-radius:50%;background:center/contain no-repeat;border:2px solid var(--ln-gold)}
  .title{font-weight:900;font-size:1.25rem}
  .sub{font-weight:700;font-size:.72rem;color:#333}
  .cta{margin-left:auto;display:flex;gap:10px;flex-wrap:wrap}
  .btn{border:2px solid var(--ln-gold);background:#fff;border-radius:12px;padding:.6rem .9rem;font-weight:900;cursor:pointer;font-size:1rem}
  .fs-wrap{display:flex;align-items:center;gap:6px;margin-left:8px}
  .fs-btn{border:2px solid var(--ln-gold);background:#fff;border-radius:10px;padding:.35rem .55rem;font-weight:900;cursor:pointer;line-height:1;font-size:1rem;min-width:2.4rem;text-align:center}
  .fs-label{font-weight:900;font-size:.85rem;color:#222}

  main{max-width:1200px;margin:22px auto;padding:0 16px; padding-top:8px; padding-bottom:140px;}
  .grid{display:grid;grid-template-columns:1.2fr 1fr; gap:18px}
  @media (max-width:960px){ .grid{grid-template-columns:1fr;} }

  .panel{background:rgba(255,255,255,.95);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);position:relative;z-index:3}
  .panel h2{margin:0;padding:14px 16px;border-bottom:1px solid var(--line);font-size:1.15rem;font-weight:900;background:#fffef6;color:var(--ink)}

  .prod-head{display:flex;gap:10px;padding:12px 14px;border-bottom:1px solid var(--line);background:#fff}
  .search{flex:1;border:2px solid var(--line);border-radius:14px;padding:.8rem 1rem;font-weight:800;font-size:1.05rem;color:var(--ink)}
  .prod-list{max-height:70vh;overflow:auto;padding:12px}
  .prod{border:2px solid var(--line);border-radius:16px;background:var(--card);padding:12px 14px;margin:10px 0}
  .prod-top{display:flex;align-items:center;justify-content:space-between;gap:10px;min-width:0}
  .prod-name{font-weight:900;font-size:1.25rem;color:var(--ink)}
  .prod-tags{font-size:1.02rem;color:#0b0b0b;margin:8px 0;line-height:1.65;font-weight:700}
  .link{display:inline-block;padding:.6rem .85rem;border:2px solid var(--ln-gold);border-radius:12px;font-weight:900;text-decoration:none;background:#fff;font-size:1rem}
  .suggest-title{margin:10px 0 4px;font-size:.95rem;font-weight:900;color:#333}

  .chat-wrap{display:flex;flex-direction:column;height:calc(70vh + 96px)}
  .stream{flex:1;overflow:auto;padding:14px}
  .row{display:flex;gap:10px;margin:10px 0}
  .bubble{max-width:92%;padding:12px 14px;border-radius:14px;border:2px solid var(--line);font-size:1.05rem;font-weight:800;background:#fff;line-height:1.6}
  .row.ai .bubble{background:#fffaf0;border-color:#f1d38a}
  .card{border:2px solid #ead39a;background:#fff;border-radius:16px;padding:12px 14px;margin:10px 0}
  .card h4{margin:0 0 6px;font-size:1.05rem;font-weight:900}
  .card p{margin:6px 0;font-size:1.02rem;line-height:1.65;font-weight:700}
  .cta-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px;min-width:0}
  .prompts{padding:10px 14px;border-top:1px solid var(--line);background:#fff;position:sticky;bottom:72px}
  .chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}
  .chip{border:2px solid var(--line);background:#fff;border-radius:999px;padding:.55rem .9rem;font-size:.95rem;font-weight:900;cursor:pointer}
  .input{display:flex;gap:10px;padding:12px;border-top:1px solid var(--line);background:#fff;position:sticky;bottom:0;min-width:0}
  .ask{flex:1;border:2px solid var(--line);border-radius:14px;padding:.85rem 1rem;font-weight:800;font-size:1.05rem;color:var(--ink)}
  .send{border:2px solid var(--ln-gold);background:#fff;border-radius:12px;padding:.85rem 1rem;font-weight:900;cursor:pointer;font-size:1.05rem}

  #products, #assistant { scroll-margin-top: calc(var(--hdrH) + 16px) !important; }

  footer{max-width:1200px;margin:10px auto 40px;padding:0 16px;color:#111;font-size:.95rem}
  .disc{background:#fff;border:2px solid var(--line);border-radius:16px;padding:12px 14px;white-space:normal !important;overflow-wrap:anywhere !important;line-height:1.65;color:var(--ink)}

  .btn:focus,.fs-btn:focus,.chip:focus,.link:focus,.send:focus,.search:focus,.ask:focus{outline:3px solid #0B5FFF;outline-offset:2px}
  .bar, .prod-top, .cta-row, .input { min-width: 0; }
div#container
{
   width: 1004px;
   position: relative;
   margin: 0 auto 0 auto;
   text-align: left;
}
body
{
   background-color: #FFFFFF;
   color: #400000;
   font-family: Garamond;
   font-weight: normal;
   font-size: 13px;
   line-height: 1.1875;
   margin: 0;
   text-align: center;
}
a
{
   color: #400000;
   text-decoration: underline;
}
a:hover
{
   color: #400000;
   text-decoration: underline;
}
  /* 1) Never truncate legal text */
  footer, .disc{
    position: relative;
    display:block;
    width:100%;
    max-width:100%;
    white-space: normal !important;
    word-break: normal !important;
    overflow-wrap: anywhere !important;   /* long words wrap */
    text-wrap: wrap;                       /* modern wrap (safe to leave) */
    overflow: visible !important;
    z-index: 1;
  }

  /* 2) Prevent sticky input from covering the footer on short pages */
  main{ padding-bottom: 140px; }           /* extra scroll room */
  @media (max-width: 960px){ main{ padding-bottom: 180px; } }

  /* 3) Let flex children shrink so text can wrap instead of overflow */
  .prod-top, .cta-row, .bar, .input { min-width: 0; }
  .prod-name, .prod-tags, .bubble, .disc { line-height: 1.65; }

  /* 4) Stronger color for seniors */
  .disc{ color:#0b0f24 !important; font-size:1.02rem; }
