/* ================================================================
   Výcuc — Krémové slunce + Coral
   Design system: warm paper-like cream, coral accents, friendly type
   ================================================================ */

/* ---- Fonts: Fraunces (display serif) + Inter (body) ---- */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,500;9..144,600;9..144,700;9..144,800&family=Inter:wght@400;500;600;700&display=swap');

/* ---- Design tokens ---- */
:root {
    /* Warm cream paper palette */
    --cream-50:  #FBF7EE;
    --cream-100: #F5EFE0;
    --cream-200: #EDE3CC;
    --paper:     #FFFFFF;

    /* Coral & warm accents */
    --coral-300: #FFB5A8;
    --coral-400: #FF9786;
    --coral-500: #FF6B5C;
    --coral-600: #E54F40;
    --coral-700: #C13E32;
    --peach:     #FFC8A8;
    --peach-soft:#FFE2CC;
    --lemon:     #FFD56B;
    --lemon-soft:#FFEDB5;
    --mint:      #A4D8C4;

    /* Warm ink (text) */
    --ink-900: #2D2519;
    --ink-700: #4A3F2E;
    --ink-500: #8B7D6B;
    --ink-400: #B4A691;
    --ink-300: #D5C8B0;
    --ink-200: #E8DEC8;
    --ink-100: #F0E8D6;

    --success: #4FA37E;
    --danger:  #C15040;

    /* Warm soft shadows */
    --shadow-xs: 0 1px 2px rgba(74, 63, 46, 0.06);
    --shadow-sm: 0 2px 6px rgba(74, 63, 46, 0.08);
    --shadow-md: 0 6px 18px rgba(74, 63, 46, 0.09);
    --shadow-lg: 0 16px 40px rgba(74, 63, 46, 0.12);
    --shadow-coral: 0 8px 24px rgba(255, 107, 92, 0.28);

    /* Radii */
    --r-sm: 8px;
    --r-md: 14px;
    --r-lg: 20px;
    --r-xl: 28px;
    --r-full: 999px;

    /* Type */
    --font-display: 'Fraunces', Georgia, 'Times New Roman', serif;
    --font-body: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

    /* Motion */
    --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
    --ease-soft: cubic-bezier(0.4, 0, 0.2, 1);
}

/* ---- Base reset ---- */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }

body {
    background: var(--cream-50);
    background-image:
        radial-gradient(circle at 12% 8%, var(--peach-soft) 0%, transparent 28%),
        radial-gradient(circle at 88% 22%, var(--lemon-soft) 0%, transparent 30%),
        radial-gradient(circle at 95% 90%, var(--peach-soft) 0%, transparent 32%);
    background-attachment: fixed;
    color: var(--ink-900);
    font-family: var(--font-body);
    font-size: 16px;
    line-height: 1.55;
    min-height: 100vh;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}

a { color: var(--coral-600); text-decoration: none; }
a:hover { color: var(--coral-700); }

button {
    font-family: inherit;
    font-size: inherit;
    color: inherit;
}

::selection { background: var(--coral-300); color: var(--ink-900); }

/* ---- Layout ---- */
.wrap {
    max-width: 1040px;
    margin: 0 auto;
    padding: 32px 24px 80px;
}

.wrap-narrow {
    max-width: 460px;
    margin: 0 auto;
    padding: 80px 24px 64px;
}

/* ---- Top bar ---- */
.topbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 28px;
    gap: 16px;
}
.brand {
    display: flex;
    align-items: center;
    gap: 10px;
    font-family: var(--font-display);
    font-weight: 700;
    font-size: 22px;
    color: var(--ink-900);
    font-variation-settings: "opsz" 144;
    letter-spacing: -0.01em;
}
.brand .logo-mark {
    display: inline-block;
    width: 36px; height: 36px;
}
.user {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 13px;
    color: var(--ink-500);
}
.user .email { color: var(--ink-700); font-weight: 500; }
.user a { color: var(--ink-500); font-size: 12px; }
.user a:hover { color: var(--coral-600); }

/* ---- Hero ---- */
.hero {
    margin: 12px 0 40px;
    text-align: left;
    position: relative;
}
.hero h1 {
    font-family: var(--font-display);
    font-weight: 700;
    font-variation-settings: "opsz" 144, "SOFT" 80;
    font-size: clamp(48px, 8vw, 84px);
    line-height: 1;
    margin: 0 0 16px;
    color: var(--ink-900);
    letter-spacing: -0.02em;
}
.hero h1 .accent {
    font-style: italic;
    color: var(--coral-500);
    position: relative;
    display: inline-block;
}
.hero p {
    font-size: 19px;
    line-height: 1.45;
    color: var(--ink-700);
    margin: 0;
    max-width: 520px;
}

/* ---- Hero brand zone (big logo + Výcuc wordmark) ---- */
.hero-brand {
    margin: 20px 0 44px;
}
.hero-mark {
    display: flex;
    align-items: center;
    gap: 14px;
    margin-bottom: 18px;
}
.hero-straw {
    width: clamp(64px, 9vw, 96px);
    height: auto;
    flex-shrink: 0;
    transform-origin: 50% 30%;
    animation: straw-bob 4.5s ease-in-out infinite;
}
.hero-straw .drip {
    transform-box: fill-box;
    transform-origin: center;
    opacity: 0;
    animation: drip-fall 2.4s ease-in infinite;
}
.hero-straw .drip-2 { animation-delay: 0.8s; }
.hero-straw .drip-3 { animation-delay: 1.6s; }
.hero-wordmark {
    font-family: var(--font-display);
    font-weight: 700;
    font-variation-settings: "opsz" 144, "SOFT" 80;
    font-size: clamp(72px, 13vw, 132px);
    line-height: 0.9;
    margin: 0;
    color: var(--ink-900);
    letter-spacing: -0.035em;
}
.hero-subtitle {
    font-size: clamp(17px, 2vw, 22px);
    line-height: 1.4;
    color: var(--ink-700);
    margin: 0;
    max-width: 620px;
    font-weight: 400;
}

@keyframes straw-bob {
    0%, 100% { transform: translateY(0) rotate(-3deg); }
    50% { transform: translateY(-4px) rotate(3deg); }
}
@keyframes drip-fall {
    0% { transform: translateY(0); opacity: 0; }
    15% { opacity: 1; }
    75% { opacity: 1; }
    100% { transform: translateY(14px); opacity: 0; }
}

/* ---- Cards ---- */
.card {
    background: var(--paper);
    border: 1px solid var(--ink-100);
    border-radius: var(--r-xl);
    padding: 28px;
    box-shadow: var(--shadow-sm);
    margin-bottom: 24px;
    position: relative;
}
.card h2 {
    font-family: var(--font-display);
    font-weight: 600;
    font-size: 20px;
    margin: 0 0 18px;
    color: var(--ink-900);
    font-variation-settings: "opsz" 144;
    letter-spacing: -0.01em;
}
.card .card-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 18px;
    gap: 12px;
}
.card .card-head h2 { margin: 0; }

/* ---- Dropzone (paper) ---- */
.dropzone {
    position: relative;
    border: 2px dashed var(--ink-300);
    border-radius: var(--r-lg);
    background: var(--cream-50);
    padding: 44px 24px;
    text-align: center;
    cursor: pointer;
    transition: all 0.25s var(--ease-soft);
    overflow: hidden;
}
.dropzone::before {
    content: "";
    position: absolute;
    inset: 6px;
    border: 1px dashed transparent;
    border-radius: calc(var(--r-lg) - 6px);
    pointer-events: none;
    transition: border-color 0.25s;
}
.dropzone:hover,
.dropzone.drag {
    border-color: var(--coral-400);
    background: var(--peach-soft);
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
}
.dropzone.drag::before { border-color: var(--coral-300); }
.dropzone .dz-icon {
    display: inline-block;
    width: 56px; height: 56px;
    margin-bottom: 12px;
    color: var(--coral-500);
    animation: gentle-float 4s ease-in-out infinite;
}
.dropzone .dz-big {
    font-family: var(--font-display);
    font-weight: 600;
    font-size: 22px;
    color: var(--ink-900);
    margin: 0 0 6px;
    letter-spacing: -0.01em;
}
.dropzone .dz-small {
    color: var(--ink-500);
    font-size: 13px;
    margin: 0;
}
.dz-folder-label {
    color: var(--coral-600);
    font-weight: 600;
}
#fileInput { display: none; }

/* ---- Buttons ---- */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    background: var(--coral-500);
    color: var(--paper);
    border: none;
    padding: 11px 20px;
    border-radius: var(--r-full);
    cursor: pointer;
    font-size: 14px;
    font-weight: 600;
    transition: all 0.2s var(--ease-spring);
    box-shadow: var(--shadow-coral);
    font-family: inherit;
    text-decoration: none;
    line-height: 1.2;
}
.btn:hover {
    background: var(--coral-600);
    transform: translateY(-1px);
    box-shadow: 0 12px 28px rgba(255, 107, 92, 0.35);
}
.btn:active {
    transform: translateY(0) scale(0.97);
}
.btn:disabled {
    opacity: 0.5;
    cursor: wait;
    transform: none;
}

.btn.ghost {
    background: var(--paper);
    color: var(--ink-900);
    border: 1px solid var(--ink-200);
    box-shadow: var(--shadow-xs);
}
.btn.ghost:hover {
    background: var(--cream-100);
    border-color: var(--ink-300);
    box-shadow: var(--shadow-sm);
}

.btn.danger {
    background: transparent;
    color: var(--danger);
    border: 1px solid var(--ink-200);
    box-shadow: none;
    padding: 7px 14px;
    font-size: 13px;
}
.btn.danger:hover {
    background: #FBEAE7;
    border-color: var(--danger);
    box-shadow: var(--shadow-xs);
}

.btn.big {
    padding: 14px 28px;
    font-size: 15px;
    width: 100%;
}

.btn.google {
    background: var(--paper);
    color: var(--ink-900);
    border: 1px solid var(--ink-200);
    box-shadow: var(--shadow-sm);
    padding: 13px 20px;
    font-weight: 500;
}
.btn.google:hover {
    background: var(--cream-100);
    border-color: var(--ink-300);
    box-shadow: var(--shadow-md);
}
.btn.google svg { width: 18px; height: 18px; }

/* ---- Forms ---- */
label {
    display: block;
    font-size: 13px;
    color: var(--ink-500);
    margin-bottom: 6px;
    font-weight: 500;
}
input[type=email], input[type=text] {
    width: 100%;
    background: var(--cream-50);
    border: 1.5px solid var(--ink-200);
    color: var(--ink-900);
    padding: 13px 16px;
    border-radius: var(--r-md);
    font-size: 15px;
    font-family: inherit;
    outline: none;
    transition: all 0.18s var(--ease-soft);
}
input[type=email]:focus, input[type=text]:focus {
    border-color: var(--coral-400);
    background: var(--paper);
    box-shadow: 0 0 0 4px rgba(255, 107, 92, 0.12);
}
input::placeholder { color: var(--ink-400); }

/* ---- Crumbs ---- */
.crumbs {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 18px;
    font-size: 14px;
}
.crumbs a {
    cursor: pointer;
    color: var(--coral-600);
    font-weight: 500;
    padding: 4px 10px;
    border-radius: var(--r-full);
    transition: background 0.15s;
}
.crumbs a:hover { background: var(--peach-soft); }
.crumbs .sep { color: var(--ink-400); }
.crumbs .current {
    color: var(--ink-900);
    font-weight: 600;
    font-family: var(--font-display);
    letter-spacing: -0.01em;
}

/* ---- Drawer cards (folders) ---- */
.drawers {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: 14px;
    margin-bottom: 24px;
}
.drawer {
    position: relative;
    background: var(--paper);
    border: 1px solid var(--ink-100);
    border-radius: var(--r-lg);
    padding: 18px 18px 20px;
    cursor: pointer;
    text-align: left;
    transition: all 0.25s var(--ease-spring);
    box-shadow: var(--shadow-xs);
    overflow: hidden;
    isolation: isolate;
}
.drawer::after {
    /* paper "tab" at top — looks like file folder */
    content: "";
    position: absolute;
    top: -1px; left: 14px;
    width: 56px; height: 10px;
    background: var(--peach);
    border-radius: 0 0 6px 6px;
    z-index: -1;
}
.drawer:hover {
    transform: translateY(-4px) rotate(-0.6deg);
    border-color: var(--peach);
    box-shadow: var(--shadow-md);
}
.drawer:hover::after {
    background: var(--coral-400);
    height: 14px;
}
.drawer .drawer-icon {
    font-size: 24px;
    margin-bottom: 8px;
    display: block;
}
.drawer .drawer-name {
    font-family: var(--font-display);
    font-weight: 600;
    font-size: 16px;
    color: var(--ink-900);
    margin: 0 0 4px;
    letter-spacing: -0.005em;
    word-break: break-word;
}
.drawer .drawer-count {
    font-size: 12px;
    color: var(--ink-500);
}
.drawer .drawer-delete {
    position: absolute;
    top: 10px;
    right: 10px;
    background: var(--paper);
    border: 1px solid var(--ink-200);
    border-radius: var(--r-full);
    width: 26px; height: 26px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    color: var(--ink-400);
    opacity: 0;
    transition: all 0.18s var(--ease-soft);
    font-size: 14px;
    line-height: 1;
}
.drawer:hover .drawer-delete {
    opacity: 1;
}
.drawer .drawer-delete:hover {
    background: var(--danger);
    color: white;
    border-color: var(--danger);
}

/* ---- File rows ---- */
.files-section .files-label {
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--ink-500);
    font-weight: 600;
    margin: 8px 0 12px;
}
.files {
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.file-row {
    display: grid;
    grid-template-columns: auto 1fr auto auto auto;
    align-items: center;
    gap: 14px;
    padding: 12px 16px;
    background: var(--paper);
    border: 1px solid var(--ink-100);
    border-radius: var(--r-md);
    transition: all 0.18s var(--ease-soft);
}
.file-row:hover {
    border-color: var(--peach);
    background: #FFFCF5;
    transform: translateX(2px);
}
.file-row .file-icon {
    width: 32px; height: 32px;
    flex-shrink: 0;
    color: var(--coral-500);
}
.file-row .file-name {
    font-weight: 500;
    color: var(--ink-900);
    font-size: 15px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.file-row .file-size,
.file-row .file-date {
    font-size: 13px;
    color: var(--ink-500);
    font-variant-numeric: tabular-nums;
}
.file-row .file-delete-wrap {
    opacity: 0;
    transition: opacity 0.18s;
}
.file-row:hover .file-delete-wrap { opacity: 1; }

/* ---- Empty state ---- */
.empty {
    text-align: center;
    padding: 48px 24px;
    color: var(--ink-500);
    font-size: 15px;
}
.empty .empty-art {
    font-size: 44px;
    margin-bottom: 12px;
    display: block;
    opacity: 0.7;
}
.empty .empty-text {
    font-family: var(--font-display);
    font-style: italic;
    font-size: 18px;
    color: var(--ink-700);
}

/* ---- Upload progress items ---- */
#uploads { margin-top: 18px; display: flex; flex-direction: column; gap: 8px; }
.upload-item {
    background: var(--cream-100);
    border: 1px solid var(--ink-100);
    border-radius: var(--r-md);
    padding: 12px 16px;
    animation: pop-in 0.25s var(--ease-spring);
}
.upload-item .row { display: flex; justify-content: space-between; align-items: center; gap: 12px; }
.upload-item .name {
    font-weight: 500;
    color: var(--ink-900);
    font-size: 14px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.upload-item .status { font-size: 12px; color: var(--ink-500); white-space: nowrap; }
.upload-item.error .status { color: var(--danger); }
.upload-item.done .status { color: var(--success); }
.progress {
    height: 4px;
    background: var(--ink-100);
    border-radius: var(--r-full);
    margin-top: 8px;
    overflow: hidden;
}
.progress > div {
    height: 100%;
    background: linear-gradient(90deg, var(--coral-500), var(--peach));
    transition: width 0.3s ease-out;
    width: 0%;
}

/* ---- Toast ---- */
.toast {
    position: fixed;
    bottom: 28px;
    left: 50%;
    transform: translate(-50%, 30px);
    background: var(--ink-900);
    color: var(--paper);
    padding: 12px 22px;
    border-radius: var(--r-full);
    font-size: 14px;
    font-weight: 500;
    opacity: 0;
    transition: all 0.3s var(--ease-spring);
    pointer-events: none;
    z-index: 100;
    box-shadow: var(--shadow-lg);
}
.toast.show {
    opacity: 1;
    transform: translate(-50%, 0);
}
.toast.error {
    background: var(--danger);
}

/* ---- Messages (success/error inline) ---- */
.msg {
    padding: 13px 16px;
    border-radius: var(--r-md);
    font-size: 14px;
    margin-bottom: 16px;
    line-height: 1.45;
}
.msg.error { background: #FBEAE7; color: var(--coral-700); border: 1px solid #F5C8C0; }
.msg.ok { background: #E8F4ED; color: var(--success); border: 1px solid #BFE0CD; }

/* ---- Divider ---- */
.divider {
    display: flex;
    align-items: center;
    gap: 12px;
    margin: 18px 0;
    color: var(--ink-400);
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}
.divider::before, .divider::after {
    content: "";
    flex: 1;
    height: 1px;
    background: var(--ink-200);
}

/* ---- Login decorations ---- */
.deco {
    position: absolute;
    pointer-events: none;
}
.deco.sun {
    top: -40px; right: -20px;
    width: 110px;
    color: var(--lemon);
    animation: spin-slow 24s linear infinite;
}
.deco.squiggle {
    bottom: -30px; left: -30px;
    width: 130px;
    color: var(--coral-300);
    opacity: 0.7;
}

/* ---- Consent (oauth) ---- */
.consent .client-name {
    font-family: var(--font-display);
    font-weight: 700;
    font-size: 22px;
    color: var(--coral-600);
    letter-spacing: -0.01em;
}
.consent .perms {
    background: var(--cream-100);
    border-radius: var(--r-md);
    padding: 16px 18px;
    margin: 16px 0;
    font-size: 14px;
}
.consent .perms-title {
    font-weight: 600;
    color: var(--ink-700);
    margin-bottom: 8px;
}
.consent .perms ul {
    list-style: none;
    margin: 0;
    padding: 0;
}
.consent .perms li {
    padding: 4px 0 4px 24px;
    position: relative;
    color: var(--ink-700);
}
.consent .perms li::before {
    content: "✓";
    position: absolute;
    left: 0;
    color: var(--success);
    font-weight: 700;
}
.consent .perms li.no::before {
    content: "✕";
    color: var(--ink-400);
}
.consent .actions {
    display: flex;
    gap: 10px;
    margin-top: 22px;
}
.consent .actions .btn { flex: 1; }

/* ---- Animations ---- */
@keyframes gentle-float {
    0%, 100% { transform: translateY(0) rotate(-2deg); }
    50% { transform: translateY(-6px) rotate(2deg); }
}
@keyframes straw-wobble {
    0%, 100% { transform: rotate(-4deg); }
    50% { transform: rotate(4deg); }
}
@keyframes spin-slow {
    from { transform: rotate(0); }
    to { transform: rotate(360deg); }
}
@keyframes pop-in {
    from { transform: translateY(8px); opacity: 0; }
    to { transform: translateY(0); opacity: 1; }
}
@keyframes fade-in {
    from { opacity: 0; transform: translateY(6px); }
    to { opacity: 1; transform: translateY(0); }
}

.stagger > * {
    opacity: 0;
    animation: fade-in 0.4s var(--ease-soft) forwards;
}
.stagger > *:nth-child(1) { animation-delay: 0.05s; }
.stagger > *:nth-child(2) { animation-delay: 0.10s; }
.stagger > *:nth-child(3) { animation-delay: 0.15s; }
.stagger > *:nth-child(4) { animation-delay: 0.20s; }
.stagger > *:nth-child(5) { animation-delay: 0.25s; }
.stagger > *:nth-child(6) { animation-delay: 0.30s; }
.stagger > *:nth-child(n+7) { animation-delay: 0.35s; }

/* ---- Responsive ---- */
@media (max-width: 600px) {
    .wrap { padding: 20px 16px 60px; }
    .hero h1 { font-size: 44px; }
    .hero p { font-size: 16px; }
    .card { padding: 20px; border-radius: var(--r-lg); }
    .file-row { grid-template-columns: auto 1fr auto; gap: 10px; padding: 10px 12px; }
    .file-row .file-date { display: none; }
    .drawers { grid-template-columns: repeat(2, 1fr); }
    .topbar { flex-wrap: wrap; }
}

/* ================================================================
   Trychtýř-maskot: kompaktní hero + how.php + connect.php (2026-05-30)
   ================================================================ */

/* top nav uprostřed lišty */
.topnav { display: flex; gap: 22px; align-items: center; font-size: 14px; }
.topnav a { color: var(--ink-500); font-weight: 500; }
.topnav a:hover { color: var(--coral-600); }
@media (max-width: 640px) { .topnav { display: none; } }

/* kompaktní hero: vlevo maskot, vpravo nadpis + tlačítka */
.home-hero { display: grid; grid-template-columns: auto 1fr; gap: 30px; align-items: center; margin: 8px 0 34px; }
@media (max-width: 760px) { .home-hero { grid-template-columns: 1fr; justify-items: center; text-align: center; gap: 16px; } }
.hero-left { display: flex; flex-direction: column; align-items: center; gap: 6px; }
.mascot { position: relative; width: clamp(120px, 14vw, 152px); }
.mascot svg { width: 100%; height: auto; overflow: visible; display: block; }

.says { position: relative; width: 210px; height: 48px; }
.say { position: absolute; left: 0; right: 0; top: 0; background: var(--paper); border: 1px solid var(--ink-100); border-radius: 14px; padding: 8px 12px; font-family: var(--font-display); font-size: 13.5px; font-weight: 500; line-height: 1.25; color: var(--ink-900); text-align: center; box-shadow: var(--shadow-md); opacity: 0; }
.say b { color: var(--coral-500); }
.say::after { content: ""; position: absolute; bottom: -7px; left: 50%; margin-left: -6px; width: 12px; height: 12px; background: var(--paper); border-right: 1px solid var(--ink-100); border-bottom: 1px solid var(--ink-100); transform: rotate(45deg); }
.say.one { animation: say1 9s ease-in-out infinite both; }
.say.two { animation: say2 9s ease-in-out infinite both; }

.hero-copy h1 { font-family: var(--font-display); font-weight: 700; font-variation-settings: "opsz" 144, "SOFT" 80; font-size: clamp(30px, 4.2vw, 52px); line-height: 1.04; letter-spacing: -0.02em; margin: 0 0 12px; color: var(--ink-900); }
.hero-copy .hl { color: var(--coral-500); position: relative; white-space: nowrap; }
.hero-copy .hl::after { content: ""; position: absolute; left: 0; right: 0; bottom: 0.06em; height: 0.18em; background: var(--lemon); opacity: 0.55; border-radius: var(--r-full); z-index: -1; }
.hero-copy .sub { font-size: clamp(15px, 1.4vw, 18px); color: var(--ink-500); max-width: 460px; margin: 0 0 18px; }
@media (max-width: 760px) { .hero-copy .sub { margin-inline: auto; } }
.btn-row { display: flex; gap: 12px; flex-wrap: wrap; }
@media (max-width: 760px) { .btn-row { justify-content: center; } }

/* animace maskota */
.fn-bob { animation: bob 4.2s ease-in-out infinite; transform-box: fill-box; }
.eye { transform-box: fill-box; transform-origin: center; animation: blink 5s infinite; }
.pupil { transform-box: fill-box; animation: look 6s ease-in-out infinite; }
.wave { transform-box: view-box; transform-origin: 206px 178px; animation: wave 4s ease-in-out infinite; }
.swirl circle { animation: swirl 2.4s ease-in infinite; }
.swirl .s2 { animation-delay: 0.8s; } .swirl .s3 { animation-delay: 1.5s; }
.nf { transform-box: fill-box; transform-origin: center; animation: notefall 3s ease-in infinite both; }
.nf.n1 { animation-delay: 3s; } .nf.n2 { animation-delay: 4.6s; }
.pg { transform-box: fill-box; transform-origin: center; }
.pgA { animation: fallA 3.2s ease-in infinite both; }
.pgB { animation: fallB 3.2s ease-in infinite both; animation-delay: 1.05s; }
.pgC { animation: fallC 3.2s ease-in infinite both; animation-delay: 2.1s; }
@keyframes bob { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-7px); } }
@keyframes blink { 0%,93%,100% { transform: scaleY(1); } 96% { transform: scaleY(.08); } }
@keyframes look { 0%,100% { transform: translate(0,0); } 40% { transform: translate(0,-2px); } 70% { transform: translate(2px,-1px); } }
@keyframes wave { 0%,58%,100% { transform: rotate(0); } 66% { transform: rotate(-20deg); } 74% { transform: rotate(6deg); } 82% { transform: rotate(-14deg); } 90% { transform: rotate(0); } }
@keyframes swirl { 0% { transform: translateY(0); opacity: 0; } 20% { opacity: 1; } 100% { transform: translateY(84px); opacity: 0; } }
@keyframes notefall { 0% { opacity: 0; transform: translateY(0) rotate(-7deg); } 18% { opacity: 1; } 80% { opacity: .95; } 100% { opacity: 0; transform: translateY(56px) rotate(9deg); } }
@keyframes fallA { 0% { opacity: 0; transform: translate(-44px,4px) rotate(-15deg) scale(.66); } 14% { opacity: 1; } 84% { opacity: .96; } 100% { opacity: 0; transform: translate(-6px,128px) rotate(14deg) scale(.3); } }
@keyframes fallB { 0% { opacity: 0; transform: translate(40px,8px) rotate(13deg) scale(.6); } 14% { opacity: 1; } 84% { opacity: .96; } 100% { opacity: 0; transform: translate(4px,128px) rotate(-12deg) scale(.28); } }
@keyframes fallC { 0% { opacity: 0; transform: translate(0px,-2px) rotate(-6deg) scale(.7); } 14% { opacity: 1; } 84% { opacity: .96; } 100% { opacity: 0; transform: translate(2px,130px) rotate(18deg) scale(.32); } }
@keyframes say1 { 0% { opacity: 0; transform: translateY(5px); } 6%,44% { opacity: 1; transform: none; } 50%,100% { opacity: 0; transform: translateY(-5px); } }
@keyframes say2 { 0%,50% { opacity: 0; transform: translateY(5px); } 56%,94% { opacity: 1; transform: none; } 100% { opacity: 0; transform: translateY(-5px); } }

/* stránkové hero (how.php / connect.php) */
.page-hero { text-align: center; margin: 16px 0 34px; }
.page-hero h1 { font-family: var(--font-display); font-weight: 700; font-variation-settings: "opsz" 144, "SOFT" 80; font-size: clamp(34px, 5vw, 58px); line-height: 1.05; letter-spacing: -0.02em; margin: 0 0 12px; }
.page-hero p { font-size: 18px; color: var(--ink-500); max-width: 580px; margin: 0 auto; }

/* how.php — kroky */
.steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin: 10px 0 36px; }
@media (max-width: 760px) { .steps { grid-template-columns: 1fr; } }
.step { background: var(--paper); border: 1px solid var(--ink-100); border-radius: var(--r-xl); padding: 26px 24px; box-shadow: var(--shadow-sm); }
.step .num { display: inline-flex; align-items: center; justify-content: center; width: 38px; height: 38px; border-radius: var(--r-full); background: var(--coral-500); color: #fff; font-family: var(--font-display); font-weight: 700; font-size: 18px; box-shadow: var(--shadow-coral); margin-bottom: 14px; }
.step h3 { font-family: var(--font-display); font-weight: 600; font-size: 20px; margin: 0 0 8px; color: var(--ink-900); }
.step p { margin: 0; color: var(--ink-500); font-size: 15px; line-height: 1.5; }
.reveal { opacity: 0; transform: translateY(18px); transition: opacity .6s var(--ease-soft), transform .6s var(--ease-soft); }
.reveal.in { opacity: 1; transform: none; }

/* connect.php — provideři + copy */
.providers { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; margin: 6px 0 22px; }
@media (max-width: 620px) { .providers { grid-template-columns: 1fr; } }
.provider { text-align: left; background: var(--paper); border: 1.5px solid var(--ink-200); border-radius: var(--r-lg); padding: 18px; cursor: pointer; transition: all .2s var(--ease-spring); }
.provider:hover { border-color: var(--peach); transform: translateY(-2px); box-shadow: var(--shadow-md); }
.provider.active { border-color: var(--coral-500); box-shadow: 0 0 0 4px rgba(255,107,92,.12); }
.provider .pname { font-family: var(--font-display); font-weight: 600; font-size: 17px; color: var(--ink-900); margin-bottom: 4px; }
.provider .pnote { font-size: 13px; color: var(--ink-500); }
.provider .ptag { display: inline-block; margin-top: 10px; font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: .06em; padding: 3px 8px; border-radius: var(--r-full); }
.ptag.ok { background: #E8F4ED; color: var(--success); }
.ptag.warn { background: var(--lemon-soft); color: #9a7b1a; }
.copybox { display: flex; align-items: center; gap: 10px; background: var(--cream-100); border: 1px solid var(--ink-200); border-radius: var(--r-md); padding: 12px 14px; margin: 14px 0; }
.copybox code { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: 14px; color: var(--ink-900); flex: 1; overflow: auto; white-space: nowrap; }
.steps-list { counter-reset: s; list-style: none; padding: 0; margin: 8px 0 0; }
.steps-list li { position: relative; padding: 11px 0 11px 42px; border-bottom: 1px solid var(--ink-100); color: var(--ink-700); }
.steps-list li:last-child { border-bottom: none; }
.steps-list li::before { counter-increment: s; content: counter(s); position: absolute; left: 0; top: 9px; width: 28px; height: 28px; border-radius: var(--r-full); background: var(--peach-soft); color: var(--coral-700); font-weight: 700; font-size: 13px; display: flex; align-items: center; justify-content: center; }

@media (prefers-reduced-motion: reduce) {
    .fn-bob, .eye, .pupil, .wave, .swirl circle, .nf, .pg, .say { animation: none !important; }
    .say.one { opacity: 1; } .say.two { display: none; }
}
