/* Self-hosted Fraunces variable font. font-display: optional eliminates CLS swap (no FOUT, no late metric shift). 4 files = roman + italic × latin + latin-ext, single variable axis covers 300-900 wght + 9..144 opsz + SOFT + WONK. 2026-05-09. */
@font-face { font-family: 'Fraunces'; font-style: italic; font-weight: 300 900; font-display: optional; src: url('/assets/fonts/Fraunces-italic-300_900-latin-ext.woff2') format('woff2'); unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF; }
@font-face { font-family: 'Fraunces'; font-style: italic; font-weight: 300 900; font-display: optional; src: url('/assets/fonts/Fraunces-italic-300_900-latin.woff2') format('woff2'); unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD; }
@font-face { font-family: 'Fraunces'; font-style: normal; font-weight: 300 900; font-display: optional; src: url('/assets/fonts/Fraunces-normal-300_900-latin-ext.woff2') format('woff2'); unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF; }
@font-face { font-family: 'Fraunces'; font-style: normal; font-weight: 300 900; font-display: optional; src: url('/assets/fonts/Fraunces-normal-300_900-latin.woff2') format('woff2'); unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD; }

/* Shared styles for every Authorly tool page (and the homepage).
   Loaded via <link rel="stylesheet" href="/tool.css">.
   Per-page <style> blocks add small overrides only. */

:root{
  color-scheme:light dark;

  /* Reference tokens */
  --ref-red:#a83232;
  --ref-red-light:#d96666;
  --ref-green:#2a7a3a;
  --ref-green-light:#5db26d;

  /* Surface */
  --paper:#faf6f0;
  --paper-2:#fefbf5;
  --rule:#e0d5c0;
  --rule-soft:#f3ede0;
  --shadow:rgba(26,24,20,.08);

  /* Ink */
  --ink:#1a1814;
  --ink-2:#3a3530;
  --ink-mute:#5d594f;

  /* Semantic accents (all sourced from --ref-red so brand color is single-edit) */
  --accent:var(--ref-red);
  --accent-soft:rgba(168,50,50,.06);
  --accent-ring:rgba(168,50,50,.18);
  --focus:var(--ref-red);
  --danger:var(--ref-red);
  --success:var(--ref-green);

  /* Noise opacity (paper ~ .04, dark mode dampens further) */
  --noise-opacity:0.04;
  --noise-r:0.42;
  --noise-g:0.39;
  --noise-b:0.32;
}

@media (prefers-color-scheme:dark){
  :root{
    /* Inverted: ink-on-paper becomes paper-on-ink. Warmer charcoal not pure black. */
    --paper:#1c1814;
    --paper-2:#23201b;
    --rule:#3a342b;
    --rule-soft:#2a2620;
    --shadow:rgba(0,0,0,.4);

    --ink:#f3eee5;
    --ink-2:#d4cfc5;
    --ink-mute:#a39d92;

    /* Accent lifts brightness so oxblood reads on charcoal */
    --accent:var(--ref-red-light);
    --accent-soft:rgba(217,102,102,.08);
    --accent-ring:rgba(217,102,102,.28);
    --focus:var(--ref-red-light);
    --danger:var(--ref-red-light);
    --success:var(--ref-green-light);

    --noise-opacity:0.025;
    --noise-r:0.85;
    --noise-g:0.82;
    --noise-b:0.74;
  }
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--paper);color:var(--ink);
  font-family:"Fraunces",Georgia,serif;
  font-variation-settings:"opsz" 14,"SOFT" 50;
  font-weight:400;line-height:1.6;font-size:18px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  /* Subtle warm paper texture — book-print feel, performance-cheap inline SVG */
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.42 0 0 0 0 0.39 0 0 0 0 0.32 0 0 0 0.04 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  background-attachment:fixed;
}
@media (prefers-color-scheme:dark){
  body{
    /* Dampen the noise to ~25% of light intensity (was tuned for paper) so it reads as a faint texture, not as visible grain on charcoal. */
    background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.85 0 0 0 0 0.82 0 0 0 0 0.74 0 0 0 0.025 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  }
}
a:focus-visible,button:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:2px}
.container{max-width:720px;margin:0 auto;padding:48px 24px}

.site-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:28px;border-bottom:1px solid var(--rule)}
.logo{font-family:"Fraunces",serif;font-variation-settings:"opsz" 144,"SOFT" 100;font-weight:600;font-size:24px;letter-spacing:-.02em;color:var(--ink);text-decoration:none;display:inline-flex;align-items:center;min-height:44px}
.logo:focus-visible{outline:2px solid var(--accent);outline-offset:4px;border-radius:4px}
.logo em{color:var(--accent);font-style:italic;font-weight:500;font-variation-settings:"opsz" 144,"WONK" 1}
.nav{display:flex;gap:24px;font-size:15px}
.nav a{color:var(--ink-mute);text-decoration:none;border-bottom:1px solid transparent;transition:border-color .2s,color .2s;display:inline-flex;align-items:center;padding:12px 8px;min-height:44px}
.nav a:hover{border-bottom-color:var(--accent);color:var(--ink)}

.hero{padding:64px 0 32px;text-align:center}
.eyebrow{font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);font-weight:500;margin-bottom:14px}
.hero h1{font-family:"Fraunces",serif;font-variation-settings:"opsz" 144,"SOFT" 30,"WONK" 1;font-weight:400;font-size:clamp(40px,7vw,64px);line-height:1.05;letter-spacing:-.025em;margin:0 0 24px;color:var(--ink)}
.hero h1 em{font-style:italic;color:var(--accent);font-weight:400}
.hero-sub{font-size:19px;color:var(--ink-2);max-width:560px;margin:0 auto;line-height:1.55}

.ornament{display:flex;align-items:center;gap:18px;max-width:200px;margin:48px auto}
.ornament::before,.ornament::after{content:"";flex:1;height:1px;background:var(--rule)}
.ornament span{font-family:"Fraunces",serif;font-style:italic;color:var(--accent);font-size:22px;line-height:1}

.tool-card{background:var(--paper-2);border:1px solid var(--rule);border-radius:4px;padding:40px;box-shadow:0 1px 0 var(--shadow)}
.tool-label{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-mute);margin-bottom:10px}
.tool-title{font-family:"Fraunces",serif;font-variation-settings:"opsz" 144,"SOFT" 50;font-weight:500;font-size:30px;letter-spacing:-.015em;margin:0 0 8px}
.tool-desc{color:var(--ink-2);font-size:16px;margin:0 0 28px;line-height:1.55}

.input-label{display:block;font-size:13px;font-weight:600;letter-spacing:.04em;color:var(--ink);margin-bottom:8px;margin-top:18px}
.input-label:first-of-type{margin-top:0}
.input-label .opt{font-weight:400;color:var(--ink-mute);font-size:12px}
input[type=text]{width:100%;padding:14px 16px;background:var(--paper);border:1px solid var(--rule);border-radius:3px;color:var(--ink);font-family:"Fraunces",serif;font-size:18px;line-height:1.5;transition:border-color .2s,box-shadow .2s}
input[type=text]:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}
textarea{width:100%;min-height:160px;padding:16px;background:var(--paper);border:1px solid var(--rule);border-radius:3px;color:var(--ink);font-family:"Fraunces",serif;font-size:16px;line-height:1.6;resize:vertical;transition:border-color .2s,box-shadow .2s}
textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}
input::placeholder,textarea::placeholder{color:#8a857d;opacity:1;font-style:italic}
@media (prefers-color-scheme:dark){input::placeholder,textarea::placeholder{color:#7a7468}}
.char-count{text-align:right;font-size:12px;color:var(--ink-mute);margin-top:6px}
.char-count.is-below-min{color:var(--accent);font-weight:500}
.char-count.is-warning{color:var(--accent)}
.char-count.is-over{color:var(--accent);font-weight:600}

.genre-row{display:flex;gap:8px;margin-top:14px;flex-wrap:wrap;align-items:flex-start}

/* Universal tap-target wrapper — 44px floor for native radios/checkboxes
   and small inline controls per WCAG 2.5.5 + Apple HIG. */
.option-row{display:flex;align-items:center;gap:8px;min-height:44px;padding:6px 0;cursor:pointer}
.option-row input[type="radio"],
.option-row input[type="checkbox"]{width:18px;height:18px;margin:0;flex-shrink:0;cursor:pointer}
.option-row label,
.option-row > span{flex:1;cursor:pointer;line-height:1.4}

.genre-chip{padding:10px 16px;min-height:44px;display:inline-flex;align-items:center;background:var(--paper-2);border:1px solid var(--rule);border-radius:999px;font-family:"Fraunces",serif;font-size:13px;color:var(--ink-mute);cursor:pointer;transition:all .2s}
.genre-chip:hover{border-color:var(--accent);color:var(--ink)}
.genre-chip.active{background:var(--accent);color:var(--paper);border-color:var(--accent);font-weight:600}

/* Tiered genre chips: parent groups (Romance / Fantasy / Mystery / etc.) collapse
   their sub-genres into a <details> wrapper. Click the parent to expand sub-chips.
   Default expanded group (Romance) is open via [open] attribute in HTML. */
.genre-cluster{display:inline-block;margin:0;padding:0}
.genre-cluster>summary{list-style:none;cursor:pointer;padding:10px 14px;min-height:44px;background:var(--paper-2);border:1px solid var(--rule);border-radius:999px;font-family:"Fraunces",serif;font-size:13px;color:var(--ink-mute);transition:all .2s;display:inline-flex;align-items:center;gap:6px;-webkit-user-select:none;user-select:none}
.genre-cluster>summary::-webkit-details-marker{display:none}
.genre-cluster>summary::marker{content:""}
.genre-cluster>summary:hover{border-color:var(--accent);color:var(--ink)}
.genre-cluster[open]>summary{background:var(--rule-soft);border-color:var(--accent);color:var(--ink);font-weight:600}
.genre-cluster>summary .caret{font-style:normal;font-size:10px;line-height:1;transition:transform .2s}
.genre-cluster[open]>summary .caret{transform:rotate(180deg)}
.genre-sub-row{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px;margin-bottom:4px;padding:8px 10px;background:var(--rule-soft);border-radius:6px;width:100%}
.genre-sub-row .genre-chip{font-size:12px;padding:10px 12px;min-height:44px}

/* Cultural-anchor select (comp finder + tropes finder) — matches the chip aesthetic */
.cultural-anchor-select{display:block;margin-top:14px;padding:11px 14px;min-height:44px;background:var(--paper);border:1px solid var(--rule);border-radius:6px;font-family:"Fraunces",serif;font-size:16px;color:var(--ink);max-width:420px;width:100%;cursor:pointer}
.cultural-anchor-select:hover,.cultural-anchor-select:focus{border-color:var(--accent);outline:none}
.cultural-anchor-select:focus-visible{outline:2px solid var(--accent);outline-offset:3px}

/* Author-profile strip (Fix 2) — the small "Profile: ..." pill near the top of every tool */
.author-profile-strip{margin:14px 0 8px;padding:0;color:var(--ink-mute);font-size:13px}
.author-profile-strip>summary{cursor:pointer;list-style:none;display:inline-flex;align-items:center;gap:8px;padding:6px 12px;background:var(--rule-soft);border:1px dashed var(--rule);border-radius:999px;font-family:"Fraunces",serif;-webkit-user-select:none;user-select:none}
.author-profile-strip>summary::-webkit-details-marker{display:none}
.author-profile-strip>summary::marker{content:""}
.author-profile-strip>summary:hover{border-color:var(--accent);color:var(--ink)}
.author-profile-strip[open]>summary{border-style:solid;border-color:var(--accent);color:var(--ink)}
.author-profile-strip .ap-summary-prefix{font-weight:600;color:var(--ink)}
.author-profile-strip .ap-saved-pill{display:inline-block;padding:2px 8px;background:var(--paper);border:1px solid var(--rule);border-radius:4px;font-size:12px;color:var(--ink-2)}
.author-profile-panel{margin-top:12px;padding:14px 16px;background:var(--paper-2);border:1px solid var(--rule);border-radius:6px;max-width:520px}
.author-profile-panel .ap-field{margin-bottom:10px;display:flex;flex-direction:column;gap:4px}
.author-profile-panel .ap-field>label{font-size:12px;color:var(--ink-mute);font-weight:600}
.author-profile-panel .ap-field>input,.author-profile-panel .ap-field>select{padding:10px 12px;min-height:44px;background:var(--paper);border:1px solid var(--rule);border-radius:4px;font-family:"Fraunces",serif;font-size:16px;color:var(--ink)}
.author-profile-panel .ap-field>input:focus,.author-profile-panel .ap-field>select:focus{border-color:var(--accent);outline:none}
.author-profile-panel .ap-field>label.ap-checkbox{flex-direction:row;display:inline-flex;align-items:center;gap:6px;font-weight:400;color:var(--ink-2);font-size:13px}
.author-profile-panel .ap-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}
.author-profile-panel .ap-btn{padding:10px 16px;min-height:44px;display:inline-flex;align-items:center;background:var(--ink);color:var(--paper);border:1px solid var(--ink);border-radius:3px;font-family:"Fraunces",serif;font-size:13px;cursor:pointer;transition:background .15s}
.author-profile-panel .ap-btn:hover{background:var(--accent);border-color:var(--accent)}
.author-profile-panel .ap-btn-secondary{background:var(--paper);color:var(--ink-mute);border-color:var(--rule)}
.author-profile-panel .ap-btn-secondary:hover{color:var(--ink);background:var(--paper);border-color:var(--accent)}
.author-profile-panel .ap-btn-danger{background:var(--paper);color:var(--ink-mute);border-color:var(--rule)}
.author-profile-panel .ap-btn-danger:hover{color:var(--accent);border-color:var(--accent);background:var(--paper)}
.author-profile-panel .ap-privacy{font-size:11px;color:var(--ink-mute);margin-top:8px;line-height:1.4}

.btn{display:inline-flex;align-items:center;gap:10px;padding:14px 28px;background:var(--ink);color:var(--paper);border:none;border-radius:3px;font-family:"Fraunces",serif;font-weight:500;font-size:16px;letter-spacing:.02em;cursor:pointer;transition:background .2s,color .2s,transform .1s;margin-top:24px}
.btn:hover{background:var(--accent)}
.btn:active{transform:translateY(1px)}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}
.btn-arrow{font-style:italic;transition:transform .2s}
.btn:hover .btn-arrow{transform:translateX(3px)}

.output{margin-top:32px;padding:32px 0 0 24px;border-top:1px solid var(--rule);border-left:3px solid var(--accent);display:none;position:relative;background:transparent}
.output.visible{display:block;animation:fadeIn .3s ease-out}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.output-title{font-family:"Fraunces",serif;font-variation-settings:"opsz" 144;font-weight:500;font-size:22px;margin:0 0 18px}
.output-body{font-size:17px;line-height:1.7;color:var(--ink)}
.output-body h2{font-family:"Fraunces",serif;font-weight:600;font-size:17px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-mute);margin:28px 0 14px}
.output-body h2:first-child{margin-top:0}
.output-body h3{font-family:"Fraunces",serif;font-variation-settings:"opsz" 144;font-weight:500;font-size:21px;margin:24px 0 10px;color:var(--ink);letter-spacing:-.005em}
.output-body p{margin:0 0 14px}
.output-body ol{padding-left:0;counter-reset:comp;list-style:none;margin:0 0 18px}
.output-body ol li{counter-increment:comp;margin-bottom:18px;padding-left:36px;position:relative}
.output-body ol li::before{content:counter(comp);position:absolute;left:0;top:0;font-family:"Fraunces",serif;font-style:italic;font-size:20px;color:var(--accent);font-weight:500;line-height:1.7}
.output-body ul{padding-left:0;list-style:none;margin:0 0 18px}
.output-body ul li{margin-bottom:12px;padding-left:20px;position:relative}
.output-body ul li::before{content:"\00A7";position:absolute;left:0;top:0;font-family:"Fraunces",serif;font-style:italic;color:var(--accent);line-height:1.7}
.output-body em{font-style:italic;color:var(--ink-2)}
.output-body strong{font-weight:600;color:var(--ink)}

.copy-btn{display:inline-block;margin-left:6px;padding:6px 11px;background:transparent;border:1px solid var(--rule);border-radius:3px;font-family:"Fraunces",serif;font-size:12px;color:var(--ink-mute);cursor:pointer;transition:all .2s;vertical-align:baseline;min-height:24px}
.copy-btn:hover{border-color:var(--accent);color:var(--accent)}
.copy-btn.copied{color:var(--success);border-color:var(--success)}
.copy-all-btn{display:inline-block;margin:8px 0 14px;padding:6px 14px;background:transparent;border:1px solid var(--accent);border-radius:3px;font-family:"Fraunces",serif;font-size:13px;color:var(--accent);cursor:pointer;transition:all .2s}
.copy-all-btn:hover{background:var(--accent);color:var(--paper)}
.copy-all-btn.copied{background:var(--success);border-color:var(--success);color:var(--paper)}

.sample{margin:0 0 24px;border:1px dashed var(--rule);border-radius:3px}
.sample summary{padding:12px 16px;cursor:pointer;font-size:14px;color:var(--ink-mute);font-weight:500;list-style:none;user-select:none;display:flex;align-items:center;justify-content:space-between;gap:8px}
.sample summary::-webkit-details-marker{display:none}
.sample summary::after{content:"\002B";font-family:"Fraunces",serif;font-variation-settings:"opsz" 14;font-size:14px;color:var(--ink-mute);font-style:normal;line-height:1}
.sample[open] summary::after{content:"\2212"}
.sample summary:hover,.sample summary:hover::after{color:var(--accent)}
.sample-body{padding:6px 16px 16px;font-size:15px;line-height:1.65;color:var(--ink-2)}
.sample-body h2{font-family:"Fraunces",serif;font-weight:600;font-size:13px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-mute);margin:16px 0 10px}
.sample-body h2:first-of-type{margin-top:6px}
.sample-body h3{font-family:"Fraunces",serif;font-weight:500;font-size:16px;margin:14px 0 6px;color:var(--ink)}
.sample-body p{margin:0 0 10px}
.sample-body ol,.sample-body ul{padding-left:0;margin:0 0 14px;list-style:none}
.sample-body ol{counter-reset:s}
.sample-body ol li{counter-increment:s;padding-left:24px;position:relative;margin-bottom:10px}
.sample-body ol li::before{content:counter(s);position:absolute;left:0;top:0;font-family:"Fraunces",serif;font-style:italic;font-size:15px;color:var(--accent);font-weight:500;line-height:1.65}
.sample-body ul li{padding-left:16px;position:relative;margin-bottom:8px}
.sample-body ul li::before{content:"\00A7";position:absolute;left:0;top:0;font-family:"Fraunces",serif;font-style:italic;color:var(--accent);line-height:1.65}
.sample-body strong{font-weight:600;color:var(--ink)}
.sample-body em{font-style:italic}
.sample-body .sample-meta{font-size:12px;color:var(--ink-mute);font-style:italic;margin-top:14px;padding-top:10px;border-top:1px dashed var(--rule)}

.section{margin-top:80px;padding-top:48px;border-top:1px solid var(--rule)}
.section-title{font-family:"Fraunces",serif;font-variation-settings:"opsz" 144,"SOFT" 30,"WONK" 1;font-weight:400;font-size:36px;letter-spacing:-.025em;margin:0 0 24px}
.section-lede{color:var(--ink-2);font-size:17px;line-height:1.7;margin:0 0 32px}

/* Editorial table-of-contents pattern — replaces the AI-tell "3 equal cards"
   grid. Each row reads like a chapter entry in a book's TOC: small leading
   roman numeral, title with subtitle, eyebrow tag, hairline rule between.
   Counter resets at .tool-list start; numerals render in italic accent. */
.tool-list{display:block;margin:0;padding:0;list-style:none;counter-reset:tool;border-top:1px solid var(--rule)}
.tool-list-item{display:grid;grid-template-columns:48px 1fr auto;gap:18px 24px;align-items:baseline;padding:22px 4px;border-bottom:1px solid var(--rule);text-decoration:none;color:inherit;transition:background .2s,padding-left .25s;counter-increment:tool;position:relative}
.tool-list-item::before{content:counter(tool, lower-roman) ".";font-family:"Fraunces",serif;font-style:italic;font-variation-settings:"opsz" 144,"WONK" 1;font-weight:400;font-size:18px;color:var(--accent);text-align:right;letter-spacing:.02em;line-height:1.4;align-self:start;padding-top:2px}
.tool-list-item:hover{background:var(--accent-soft);padding-left:14px}
.tool-list-item:hover .tool-list-title{color:var(--accent)}
.tool-list-item:focus-visible{outline:2px solid var(--accent);outline-offset:4px;border-radius:2px}
.tool-list-body{min-width:0}
.tool-list-title{font-family:"Fraunces",serif;font-variation-settings:"opsz" 144,"SOFT" 30;font-weight:500;font-size:22px;letter-spacing:-.01em;margin:0 0 4px;color:var(--ink);line-height:1.25;transition:color .2s}
.tool-list-desc{font-size:15px;color:var(--ink-mute);margin:0;line-height:1.5}
.tool-list-tag{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-mute);font-weight:500;font-style:normal;white-space:nowrap;align-self:start;padding-top:6px;font-variant-numeric:tabular-nums}
.tool-list-item:hover .tool-list-tag{color:var(--accent)}
.tool-list-arrow{font-style:italic;color:var(--accent);font-size:20px;transition:transform .25s;display:inline-block;margin-left:4px}
.tool-list-item:hover .tool-list-arrow{transform:translateX(4px)}
@media (max-width:600px){
  .tool-list-item{grid-template-columns:32px 1fr;grid-template-rows:auto auto;gap:6px 14px;padding:20px 0}
  .tool-list-item::before{font-size:16px;padding-top:0}
  .tool-list-tag{grid-column:2;padding-top:0;margin-top:2px;order:3}
  .tool-list-title{font-size:19px}
  .tool-list-desc{font-size:14px}
  .tool-list-item:hover{padding-left:0;background:transparent}
}

/* --- Site footer (unified across all 10 pages) ---------------------------
   Book-colophon feel: a small § ornament between two delicate rules,
   then a flexbox link nav, then the maker line with quiet emphasis. */
.site-footer{margin-top:96px;padding:0 0 56px;text-align:center;color:var(--ink-mute);font-size:13px}
.site-footer-mark{display:flex;align-items:center;justify-content:center;gap:14px;max-width:140px;margin:0 auto 30px}
.site-footer-mark::before,.site-footer-mark::after{content:"";flex:1;height:1px;background:var(--rule)}
.site-footer-mark span{font-family:"Fraunces",serif;font-style:italic;color:var(--accent);font-size:18px;line-height:1}
.site-footer-links{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:0 2px;margin:0 0 14px;line-height:2;list-style:none;padding:0}
.site-footer-links a{color:var(--ink-mute);text-decoration:none;border-bottom:1px solid transparent;padding:4px 8px;border-radius:2px;transition:color .2s,border-color .2s}
.site-footer-links a:hover{color:var(--accent);border-bottom-color:var(--accent)}
.site-footer-sep{color:var(--rule);user-select:none;font-style:normal}
.site-footer-byline{margin:0;color:var(--ink-mute);font-size:13px;letter-spacing:.01em}
.site-footer-byline strong{color:var(--ink);font-weight:500}
@media (max-width:520px){
  .site-footer{margin-top:72px;padding-bottom:36px}
  .site-footer-links a{padding:6px 6px}
}

.also-useful{margin:64px auto 0;max-width:560px;padding:24px 0 0;border-top:1px solid var(--rule);text-align:center;font-size:14px;color:var(--ink-mute);line-height:1.7}
.also-useful a{color:var(--ink-mute);text-decoration:none;border-bottom:1px solid var(--rule);padding:0 2px;transition:color .2s,border-color .2s}
.also-useful a:hover{color:var(--accent);border-bottom-color:var(--accent)}
.loading{text-align:center;padding:32px 0;color:var(--ink-mute);font-style:italic;font-size:15px}
.loading-dot{display:inline-block;animation:pulse 1.4s infinite;font-style:normal}
.loading-dot:nth-child(2){animation-delay:.2s}
.loading-dot:nth-child(3){animation-delay:.4s}
@keyframes pulse{0%,100%{opacity:.3}50%{opacity:1}}
.error{padding:14px 16px;background:var(--accent-soft);border-left:3px solid var(--accent);color:var(--ink);font-size:14px;line-height:1.5;border-radius:0 3px 3px 0}
.remaining-note{margin-top:18px;padding:10px 14px;background:var(--rule-soft);border-radius:6px;font-size:13px;color:var(--ink-mute);text-align:center}

.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--ink);color:var(--paper);padding:10px 16px;z-index:1000;text-decoration:none;font-size:14px;font-weight:500}
.skip-link:focus{left:0;outline:2px solid var(--accent);outline-offset:2px}
#content:focus,#tool:focus,.notfound:focus{outline:none}
#content:focus-visible,#tool:focus-visible,.notfound:focus-visible{outline:2px solid var(--accent);outline-offset:8px;border-radius:4px}

@media (max-width:600px){
  .container{padding:32px 20px}
  .tool-card{padding:24px}
  .hero{padding:40px 0 24px}
  body{font-size:17px}
  .nav a:nth-child(2){display:none}
}
@media (min-width:1024px){
  .container{max-width:880px}
}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
}

::selection{background:var(--accent);color:var(--paper)}

/* ---- Page-scoped styles (extracted from inline <style> for strict CSP) ---- */

/* Blurb tool — taller default textarea */
body.page-blurb textarea{min-height:200px}

/* Homepage sections + Pro waitlist */
body.page-home .about-lede{font-size:17px;line-height:1.7;color:var(--ink);margin:0 0 16px}
body.page-home .about-lede.muted{color:var(--ink-mute);margin:0 0 28px}
body.page-home .about-maker{font-size:17px;line-height:1.7;color:var(--ink);margin:32px 0 0}
body.page-home .faq-block{margin-top:48px;margin-bottom:36px}
body.page-home .faq-block h3{font-family:"Fraunces",serif;font-weight:500;font-size:24px;letter-spacing:-.01em;margin:0 0 18px;color:var(--ink)}
body.page-home .waitlist{margin-top:8px;padding:28px;background:var(--paper-2);border:1px solid var(--rule);border-radius:4px}
body.page-home .waitlist-eyebrow{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);font-weight:500;margin-bottom:8px}
body.page-home .waitlist-title{font-family:"Fraunces",serif;font-variation-settings:"opsz" 144,"SOFT" 50;font-weight:500;font-size:24px;letter-spacing:-.01em;margin:0 0 8px;color:var(--ink)}
body.page-home .waitlist-sub{color:var(--ink-mute);font-size:15px;line-height:1.55;margin:0 0 18px}
body.page-home .waitlist-form{display:flex;gap:10px;flex-wrap:wrap;align-items:stretch}
body.page-home .waitlist-form input[type=email]{flex:1;min-width:220px;padding:13px 16px;background:var(--paper);border:1px solid var(--rule);border-radius:3px;color:var(--ink);font-family:"Fraunces",serif;font-size:16px;line-height:1.4;transition:border-color .2s,box-shadow .2s}
body.page-home .waitlist-form input[type=email]:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}
body.page-home .waitlist-btn{margin-top:0;padding:13px 22px;font-size:15px}
body.page-home .waitlist-status{margin-top:14px;font-size:14px;line-height:1.55;min-height:1px}
body.page-home .waitlist-status.success{color:var(--success)}
body.page-home .waitlist-status.error{color:var(--accent)}
body.page-home .contact-link{color:var(--accent)}
body.page-home .faq-link{color:var(--accent)}
@media (max-width:520px){
  body.page-home .waitlist-form{flex-direction:column}
  body.page-home .waitlist-form input[type=email]{min-width:0}
}

/* Legal pages — privacy + terms shared layout */
body.page-legal .legal h1{font-family:"Fraunces",serif;font-variation-settings:"opsz" 144,"SOFT" 30,"WONK" 1;font-weight:400;font-size:clamp(36px,5vw,48px);line-height:1.1;letter-spacing:-.025em;margin:0 0 8px;color:var(--ink)}
body.page-legal .legal .lastmod{color:var(--ink-mute);font-size:14px;margin:0 0 36px;font-style:italic}
body.page-legal .legal h2{font-family:"Fraunces",serif;font-variation-settings:"opsz" 144,"SOFT" 50;font-weight:500;font-size:22px;letter-spacing:-.005em;line-height:1.25;margin:38px 0 12px}
body.page-legal .legal p{margin:0 0 16px;font-size:17px;line-height:1.7;color:var(--ink)}
body.page-legal .legal ul{margin:0 0 16px;padding-left:0;list-style:none}
body.page-legal .legal ul li{margin-bottom:10px;padding-left:20px;position:relative}
body.page-legal .legal ul li::before{content:"\00A7";position:absolute;left:0;top:0;font-family:"Fraunces",serif;font-style:italic;color:var(--accent);line-height:1.7}
body.page-legal .legal a{color:var(--ink);text-decoration:underline;text-decoration-color:var(--rule);text-underline-offset:2px;transition:color .2s,text-decoration-color .2s}
body.page-legal .legal a:hover{color:var(--accent);text-decoration-color:var(--accent)}
body.page-legal .legal strong{font-weight:600;color:var(--ink)}
body.page-legal .contact:empty::before{content:"hello@authorly.tools"}
body.page-legal .legal-spacer{margin-top:48px}

/* Guides — long-form editorial pages (peer-author voice).
   Reads like a magazine essay: roomier line-height, drop cap on first
   paragraph, pull-quote treatment for emphasized lines, hairline rule
   between H2 sections. Same chrome (header/footer/ornament) as tools. */
body.page-guide .container{max-width:680px}
@media (min-width:1024px){body.page-guide .container{max-width:740px}}
body.page-guide .guide-meta{font-size:13px;letter-spacing:.04em;color:var(--ink-mute);margin:0 0 28px;display:flex;flex-wrap:wrap;gap:0 14px;align-items:baseline}
body.page-guide .guide-meta .guide-tag{color:var(--accent);font-weight:500;text-transform:uppercase;letter-spacing:.16em;font-size:11px}
body.page-guide .guide-meta time{font-style:italic}
body.page-guide article h1{font-family:"Fraunces",serif;font-variation-settings:"opsz" 144,"SOFT" 30,"WONK" 1;font-weight:400;font-size:clamp(34px,5vw,46px);line-height:1.12;letter-spacing:-.025em;margin:0 0 18px;color:var(--ink)}
body.page-guide article h1 em{font-style:italic;color:var(--accent);font-weight:400}
body.page-guide article > p.lede{font-size:20px;line-height:1.55;color:var(--ink-2);margin:0 0 36px;font-style:italic;font-variation-settings:"opsz" 144,"SOFT" 50}

/* Editorial table-of-contents — sits after lede, before first h2.
   Renders as a chapter list: small italic numerals, hairline rules. */
body.page-guide .toc{margin:0 0 40px;padding:18px 22px;background:var(--paper-2);border:1px solid var(--rule);border-radius:3px}
body.page-guide .toc h2{font-family:"Fraunces",serif;font-style:italic;font-weight:400;font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-mute);margin:0 0 10px;padding:0;border:0}
body.page-guide .toc ol{counter-reset:tocli;margin:0;padding:0;list-style:none}
body.page-guide .toc ol li{counter-increment:tocli;padding:6px 0 6px 28px;position:relative;font-size:15px;line-height:1.45;border-top:1px solid var(--rule);margin:0}
body.page-guide .toc ol li:first-child{border-top:0}
body.page-guide .toc ol li::before{content:counter(tocli,lower-roman) ".";position:absolute;left:0;top:6px;font-family:"Fraunces",serif;font-style:italic;color:var(--accent);font-size:13px;letter-spacing:.04em}
body.page-guide .toc ol li a{color:var(--ink-2);text-decoration:none;border:0}
body.page-guide .toc ol li a:hover{color:var(--accent)}

body.page-guide article h2{font-family:"Fraunces",serif;font-variation-settings:"opsz" 144,"SOFT" 50;font-weight:500;font-size:26px;letter-spacing:-.01em;line-height:1.2;margin:48px 0 14px;padding-top:32px;border-top:1px solid var(--rule);color:var(--ink)}
body.page-guide article h2:first-of-type{margin-top:0;padding-top:0;border-top:0}
body.page-guide article h3{font-family:"Fraunces",serif;font-variation-settings:"opsz" 144;font-weight:500;font-size:19px;margin:28px 0 8px;color:var(--ink);letter-spacing:-.005em}
body.page-guide article p{margin:0 0 16px;font-size:18px;line-height:1.7;color:var(--ink)}
body.page-guide article p strong{font-weight:600;color:var(--ink)}
body.page-guide article p em{font-style:italic;color:var(--ink-2)}
body.page-guide article a{color:var(--ink);text-decoration:underline;text-decoration-color:var(--rule);text-underline-offset:3px;transition:color .2s,text-decoration-color .2s}
body.page-guide article a:hover{color:var(--accent);text-decoration-color:var(--accent)}
body.page-guide article ul,body.page-guide article ol{margin:0 0 18px;padding-left:0;list-style:none}
body.page-guide article ul li,body.page-guide article ol li{padding-left:22px;position:relative;margin-bottom:10px;font-size:18px;line-height:1.65;color:var(--ink)}
body.page-guide article ul li::before{content:"\00A7";position:absolute;left:0;top:0;font-family:"Fraunces",serif;font-style:italic;color:var(--accent);line-height:1.65}
body.page-guide article ol{counter-reset:gli}
body.page-guide article ol li{counter-increment:gli}
body.page-guide article ol li::before{content:counter(gli) ".";position:absolute;left:0;top:0;font-family:"Fraunces",serif;font-style:italic;color:var(--accent);font-weight:500;line-height:1.65}
body.page-guide article blockquote{margin:24px 0;padding:0 0 0 22px;border-left:3px solid var(--accent);font-style:italic;color:var(--ink-2);font-size:19px;line-height:1.6}
body.page-guide article blockquote p{font-size:19px;line-height:1.6}
body.page-guide .guide-callout{margin:32px 0;padding:22px 24px;background:var(--paper-2);border:1px solid var(--rule);border-radius:3px}
body.page-guide .guide-callout-eyebrow{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);font-weight:500;margin-bottom:6px}
body.page-guide .guide-callout p{font-size:16px;line-height:1.6;margin:0 0 8px;color:var(--ink-2)}
body.page-guide .guide-callout p:last-child{margin-bottom:0}
body.page-guide .guide-callout a.btn-inline{display:inline-block;margin-top:6px;color:var(--accent);text-decoration:none;border-bottom:1px solid var(--accent);font-weight:500;font-size:15px;letter-spacing:.01em}
body.page-guide .guide-callout a.btn-inline:hover{color:var(--ink);border-bottom-color:var(--ink)}
body.page-guide .guide-end{margin:48px 0 0;text-align:center;color:var(--accent);font-style:italic;font-size:22px;line-height:1}
body.page-guide .guide-nav{margin:48px 0 0;padding:24px 0 0;border-top:1px solid var(--rule);font-size:14px;color:var(--ink-mute);line-height:1.7;text-align:center}
body.page-guide .guide-nav a{color:var(--ink-mute);text-decoration:none;border-bottom:1px solid var(--rule);padding:0 2px;transition:color .2s,border-color .2s}
body.page-guide .guide-nav a:hover{color:var(--accent);border-bottom-color:var(--accent)}

/* Guides index — shares editorial-list structure with homepage tool list */
body.page-guides-index .guides-list{display:block;margin:0;padding:0;list-style:none;counter-reset:gtool;border-top:1px solid var(--rule)}
body.page-guides-index .guides-list-item{display:grid;grid-template-columns:48px 1fr;gap:6px 24px;align-items:baseline;padding:22px 4px;border-bottom:1px solid var(--rule);text-decoration:none;color:inherit;transition:background .2s,padding-left .25s;counter-increment:gtool;position:relative}
body.page-guides-index .guides-list-item::before{content:counter(gtool, lower-roman) ".";font-family:"Fraunces",serif;font-style:italic;font-variation-settings:"opsz" 144,"WONK" 1;font-weight:400;font-size:18px;color:var(--accent);text-align:right;letter-spacing:.02em;line-height:1.4;align-self:start;padding-top:2px;grid-row:1/3}
body.page-guides-index .guides-list-item:hover{background:var(--accent-soft);padding-left:14px}
body.page-guides-index .guides-list-item:hover .guides-list-title{color:var(--accent)}
body.page-guides-index .guides-list-title{font-family:"Fraunces",serif;font-variation-settings:"opsz" 144,"SOFT" 30;font-weight:500;font-size:22px;letter-spacing:-.01em;margin:0;color:var(--ink);line-height:1.25;transition:color .2s}
body.page-guides-index .guides-list-desc{font-size:15px;color:var(--ink-mute);margin:6px 0 0;line-height:1.55}
@media (max-width:600px){
  body.page-guides-index .guides-list-item{grid-template-columns:32px 1fr;padding:20px 0}
  body.page-guides-index .guides-list-item::before{font-size:16px;padding-top:0}
  body.page-guides-index .guides-list-title{font-size:19px}
  body.page-guides-index .guides-list-desc{font-size:14px}
  body.page-guides-index .guides-list-item:hover{padding-left:0;background:transparent}
}

/* 404 page — dark-reader-defended large italic accent treatment.
   Naturally higher specificity (body.is-404) replaces !important hammer. */
body.is-404 .notfound{padding:96px 0 64px;text-align:center}
body.is-404 .notfound-code{font-family:"Fraunces",serif;font-variation-settings:"opsz" 144,"SOFT" 30,"WONK" 1;font-size:clamp(96px,18vw,144px);line-height:1;font-weight:400;color:var(--accent);font-style:italic;margin:0 0 12px;letter-spacing:-.05em}
body.is-404 .notfound h1{font-family:"Fraunces",serif;font-variation-settings:"opsz" 144,"SOFT" 30;font-weight:500;font-size:clamp(28px,5vw,40px);line-height:1.15;letter-spacing:-.02em;margin:0 0 16px;color:var(--ink)}
body.is-404 .notfound p{margin:0 0 28px;color:var(--ink-mute);font-size:17px;line-height:1.6}
body.is-404 .notfound .cta{display:inline-flex;align-items:center;gap:10px;background:var(--ink);color:var(--paper);padding:14px 26px;border-radius:3px;text-decoration:none;font-family:"Fraunces",serif;font-size:16px;font-weight:500;letter-spacing:.02em;transition:background .2s,transform .1s}
body.is-404 .notfound .cta:hover{background:var(--accent)}
body.is-404 .notfound .cta:active{transform:translateY(1px)}
body.is-404 .notfound .cta-arrow{font-style:italic;transition:transform .2s}
body.is-404 .notfound .cta:hover .cta-arrow{transform:translateX(3px)}
@media (max-width:520px){
  body.is-404 .notfound{padding:64px 0 48px}
}

/* ============================================================================
   GUIDE LAYOUT HELPERS — replaces inline style="" in guides/*.html
   Strict CSP `style-src 'self'` blocks inline styles silently. Frontend-design
   audit 2026-05-09: 4 inline-style violations cleaned up here.
   ============================================================================ */
.section--no-top-rule {
  margin-top: 0;
  padding-top: 0;
  border-top: 0;
}
.also-useful--narrow {
  max-width: 680px;
}
.guide-meta--space-above {
  margin-top: 48px;
}

/* ============================================================================
   LOADING BUTTON ELLIPSIS PULSE
   Frontend-design audit 2026-05-09: text-swap exists, but ellipsis was static —
   subtle opacity pulse signals the button is alive during 4-8s AI calls.
   ============================================================================ */
.btn[aria-busy="true"] .btn-arrow {
  animation: btn-ellipsis-pulse 1.2s ease-in-out infinite;
}

@keyframes btn-ellipsis-pulse {
  0%, 100% { opacity: 0.35; }
  50% { opacity: 1; }
}

@media (prefers-reduced-motion: reduce) {
  .btn[aria-busy="true"] .btn-arrow {
    animation: none;
    opacity: 0.7;
  }
}

/* ============================================================================
   HERO MOTION ACCENT — italic-emphasis underline draw on "comp titles"
   Frontend-design audit 2026-05-09: one subtle motion accent so hero doesn't
   read as static. Respects prefers-reduced-motion.
   ============================================================================ */
.hero h1 em {
  position: relative;
}

.hero h1 em::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -2px;
  height: 2px;
  background: currentColor;
  transform: scaleX(0);
  transform-origin: left;
  animation: hero-underline-draw 700ms cubic-bezier(0.7, 0, 0.3, 1) 500ms forwards;
}

@keyframes hero-underline-draw {
  from { transform: scaleX(0); }
  to { transform: scaleX(1); }
}

@media (prefers-reduced-motion: reduce) {
  .hero h1 em::after {
    animation: none;
    transform: scaleX(1);
  }
}

